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 64 65 66 67 68 69 70 71 72
|
package proto
import (
"fmt"
"math"
"unsafe"
)
var uint32Codec = codec{
wire: varint,
size: sizeOfUint32,
encode: encodeUint32,
decode: decodeUint32,
}
func sizeOfUint32(p unsafe.Pointer, flags flags) int {
if p != nil {
if v := *(*uint32)(p); v != 0 || flags.has(wantzero) {
return sizeOfVarint(uint64(v))
}
}
return 0
}
func encodeUint32(b []byte, p unsafe.Pointer, flags flags) (int, error) {
if p != nil {
if v := *(*uint32)(p); v != 0 || flags.has(wantzero) {
return encodeVarint(b, uint64(v))
}
}
return 0, nil
}
func decodeUint32(b []byte, p unsafe.Pointer, _ flags) (int, error) {
v, n, err := decodeVarint(b)
if v > math.MaxUint32 {
return n, fmt.Errorf("integer overflow decoding %v into uint32", v)
}
*(*uint32)(p) = uint32(v)
return n, err
}
var fixed32Codec = codec{
wire: fixed32,
size: sizeOfFixed32,
encode: encodeFixed32,
decode: decodeFixed32,
}
func sizeOfFixed32(p unsafe.Pointer, flags flags) int {
if p != nil {
if v := *(*uint32)(p); v != 0 || flags.has(wantzero) {
return 4
}
}
return 0
}
func encodeFixed32(b []byte, p unsafe.Pointer, flags flags) (int, error) {
if p != nil {
if v := *(*uint32)(p); v != 0 || flags.has(wantzero) {
return encodeLE32(b, v)
}
}
return 0, nil
}
func decodeFixed32(b []byte, p unsafe.Pointer, _ flags) (int, error) {
v, n, err := decodeLE32(b)
*(*uint32)(p) = v
return n, err
}
|