summaryrefslogtreecommitdiffstats
path: root/codec/codec.go
diff options
context:
space:
mode:
authorOndrej Fabry <ofabry@cisco.com>2020-07-22 04:40:55 +0200
committerOndrej Fabry <ofabry@cisco.com>2020-07-22 04:40:55 +0200
commit58da9ac6e691a8c660eb8ca838a154e11da0db68 (patch)
treea1bbda04c6d0621ce0fc20779276620f1820190b /codec/codec.go
parenta155cd438c6558da266c1c5931361ea088b35653 (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.go70
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)
-}