-
Notifications
You must be signed in to change notification settings - Fork 35
/
points_brio.go
63 lines (59 loc) · 1.46 KB
/
points_brio.go
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
// DO NOT EDIT; automatically generated by brio-gen
package hbook
import (
"encoding/binary"
"math"
)
// MarshalBinary implements encoding.BinaryMarshaler
func (o *Point2D) MarshalBinary() (data []byte, err error) {
var buf [8]byte
binary.LittleEndian.PutUint64(buf[:8], math.Float64bits(o.X))
data = append(data, buf[:8]...)
binary.LittleEndian.PutUint64(buf[:8], math.Float64bits(o.Y))
data = append(data, buf[:8]...)
{
sub, err := o.ErrX.MarshalBinary()
if err != nil {
return nil, err
}
binary.LittleEndian.PutUint64(buf[:8], uint64(len(sub)))
data = append(data, buf[:8]...)
data = append(data, sub...)
}
{
sub, err := o.ErrY.MarshalBinary()
if err != nil {
return nil, err
}
binary.LittleEndian.PutUint64(buf[:8], uint64(len(sub)))
data = append(data, buf[:8]...)
data = append(data, sub...)
}
return data, err
}
// UnmarshalBinary implements encoding.BinaryUnmarshaler
func (o *Point2D) UnmarshalBinary(data []byte) (err error) {
o.X = math.Float64frombits(binary.LittleEndian.Uint64(data[:8]))
data = data[8:]
o.Y = math.Float64frombits(binary.LittleEndian.Uint64(data[:8]))
data = data[8:]
{
n := int(binary.LittleEndian.Uint64(data[:8]))
data = data[8:]
err = o.ErrX.UnmarshalBinary(data[:n])
if err != nil {
return err
}
data = data[n:]
}
{
n := int(binary.LittleEndian.Uint64(data[:8]))
data = data[8:]
err = o.ErrY.UnmarshalBinary(data[:n])
if err != nil {
return err
}
data = data[n:]
}
return err
}