summaryrefslogtreecommitdiff
path: root/xgbgen/size.go
diff options
context:
space:
mode:
authorAndrew Gallant (Ocelot) <[email protected]>2012-05-06 02:21:31 -0400
committerAndrew Gallant (Ocelot) <[email protected]>2012-05-06 02:21:31 -0400
commit69ba151e407538b730dc31db3407cb61e7279160 (patch)
treee8a347d62aca985f21ace26ff0f7a143fae44a89 /xgbgen/size.go
parent65ab69dd1e32e52fb075072df7d520229d643e0b (diff)
added documentation and did some slight restructuring. it's party time.
Diffstat (limited to 'xgbgen/size.go')
-rw-r--r--xgbgen/size.go9
1 files changed, 9 insertions, 0 deletions
diff --git a/xgbgen/size.go b/xgbgen/size.go
index 70edb8f..d8d3ac3 100644
--- a/xgbgen/size.go
+++ b/xgbgen/size.go
@@ -1,21 +1,30 @@
package main
+// Size corresponds to an expression that represents the number of bytes
+// in some *thing*. Generally, sizes are used to allocate buffers and to
+// inform X how big requests are.
+// Size is basically a thin layer over an Expression that yields easy methods
+// for adding and multiplying sizes.
type Size struct {
Expression
}
+// newFixedSize creates a new Size with some fixed and known value.
func newFixedSize(fixed uint) Size {
return Size{&Value{v: fixed}}
}
+// newExpressionSize creates a new Size with some expression.
func newExpressionSize(variable Expression) Size {
return Size{variable}
}
+// Add adds s1 and s2 and returns a new Size.
func (s1 Size) Add(s2 Size) Size {
return Size{newBinaryOp("+", s1, s2)}
}
+// Multiply mupltiplies s1 and s2 and returns a new Size.
func (s1 Size) Multiply(s2 Size) Size {
return Size{newBinaryOp("*", s1, s2)}
}