diff options
author | Ondrej Fabry <ofabry@cisco.com> | 2020-07-22 04:40:55 +0200 |
---|---|---|
committer | Ondrej Fabry <ofabry@cisco.com> | 2020-07-22 04:40:55 +0200 |
commit | 58da9ac6e691a8c660eb8ca838a154e11da0db68 (patch) | |
tree | a1bbda04c6d0621ce0fc20779276620f1820190b /codec/codec.go | |
parent | a155cd438c6558da266c1c5931361ea088b35653 (diff) |
Fix binapigen decoding and minor improvements
- fixed allocating byte slices before copying decoded data
- simplified encoding functions
- several minor improvements
Change-Id: I6669424b89eb86333805cb1b57e4551169980cc2
Signed-off-by: Ondrej Fabry <ofabry@cisco.com>
Diffstat (limited to 'codec/codec.go')
-rw-r--r-- | codec/codec.go | 70 |
1 files changed, 48 insertions, 22 deletions
diff --git a/codec/codec.go b/codec/codec.go index 4178e12..3ae578b 100644 --- a/codec/codec.go +++ b/codec/codec.go @@ -18,8 +18,6 @@ import ( "bytes" "encoding/binary" "math" - "reflect" - "unsafe" ) // Buffer provides buffer for encoding and decoding data on wire. @@ -28,12 +26,14 @@ type Buffer struct { pos int } +// NewBuffer creates new buffer using b as data. func NewBuffer(b []byte) *Buffer { return &Buffer{ buf: b, } } +// Bytes returns buffer data up to current position. func (b *Buffer) Bytes() []byte { return b.buf[:b.pos] } @@ -68,12 +68,12 @@ func (b *Buffer) DecodeBool() bool { } func (b *Buffer) EncodeUint8(v uint8) { - b.buf[b.pos] = v + b.buf[b.pos] = byte(v) b.pos += 1 } func (b *Buffer) DecodeUint8() uint8 { - v := b.buf[b.pos] + v := uint8(b.buf[b.pos]) b.pos += 1 return v } @@ -111,6 +111,50 @@ func (b *Buffer) DecodeUint64() uint64 { return v } +func (b *Buffer) EncodeInt8(v int8) { + b.buf[b.pos] = byte(v) + b.pos += 1 +} + +func (b *Buffer) DecodeInt8() int8 { + v := int8(b.buf[b.pos]) + b.pos += 1 + return v +} + +func (b *Buffer) EncodeInt16(v int16) { + binary.BigEndian.PutUint16(b.buf[b.pos:b.pos+2], uint16(v)) + b.pos += 2 +} + +func (b *Buffer) DecodeInt16() int16 { + v := int16(binary.BigEndian.Uint16(b.buf[b.pos : b.pos+2])) + b.pos += 2 + return v +} + +func (b *Buffer) EncodeInt32(v int32) { + binary.BigEndian.PutUint32(b.buf[b.pos:b.pos+4], uint32(v)) + b.pos += 4 +} + +func (b *Buffer) DecodeInt32() int32 { + v := int32(binary.BigEndian.Uint32(b.buf[b.pos : b.pos+4])) + b.pos += 4 + return v +} + +func (b *Buffer) EncodeInt64(v int64) { + binary.BigEndian.PutUint64(b.buf[b.pos:b.pos+8], uint64(v)) + b.pos += 8 +} + +func (b *Buffer) DecodeInt64() int64 { + v := int64(binary.BigEndian.Uint64(b.buf[b.pos : b.pos+8])) + b.pos += 8 + return v +} + func (b *Buffer) EncodeFloat64(v float64) { binary.BigEndian.PutUint64(b.buf[b.pos:b.pos+8], math.Float64bits(v)) b.pos += 8 @@ -145,21 +189,3 @@ func (b *Buffer) DecodeString(length int) string { b.pos += length return string(v) } - -func BytesToString(b []byte) string { - sliceHeader := (*reflect.SliceHeader)(unsafe.Pointer(&b)) - stringHeader := reflect.StringHeader{Data: sliceHeader.Data, Len: sliceHeader.Len} - return *(*string)(unsafe.Pointer(&stringHeader)) -} - -func DecodeString(b []byte) string { - return string(b) -} - -func DecodeStringZero(b []byte) string { - nul := bytes.Index(b, []byte{0x00}) - if nul >= 0 { - b = b[:nul] - } - return string(b) -} |