package gob
import (
"reflect"
)
var encArrayHelper = map [reflect .Kind ]encHelper {
reflect .Bool : encBoolArray ,
reflect .Complex64 : encComplex64Array ,
reflect .Complex128 : encComplex128Array ,
reflect .Float32 : encFloat32Array ,
reflect .Float64 : encFloat64Array ,
reflect .Int : encIntArray ,
reflect .Int16 : encInt16Array ,
reflect .Int32 : encInt32Array ,
reflect .Int64 : encInt64Array ,
reflect .Int8 : encInt8Array ,
reflect .String : encStringArray ,
reflect .Uint : encUintArray ,
reflect .Uint16 : encUint16Array ,
reflect .Uint32 : encUint32Array ,
reflect .Uint64 : encUint64Array ,
reflect .Uintptr : encUintptrArray ,
}
var encSliceHelper = map [reflect .Kind ]encHelper {
reflect .Bool : encBoolSlice ,
reflect .Complex64 : encComplex64Slice ,
reflect .Complex128 : encComplex128Slice ,
reflect .Float32 : encFloat32Slice ,
reflect .Float64 : encFloat64Slice ,
reflect .Int : encIntSlice ,
reflect .Int16 : encInt16Slice ,
reflect .Int32 : encInt32Slice ,
reflect .Int64 : encInt64Slice ,
reflect .Int8 : encInt8Slice ,
reflect .String : encStringSlice ,
reflect .Uint : encUintSlice ,
reflect .Uint16 : encUint16Slice ,
reflect .Uint32 : encUint32Slice ,
reflect .Uint64 : encUint64Slice ,
reflect .Uintptr : encUintptrSlice ,
}
func encBoolArray(state *encoderState , v reflect .Value ) bool {
if !v .CanAddr () {
return false
}
return encBoolSlice (state , v .Slice (0 , v .Len ()))
}
func encBoolSlice(state *encoderState , v reflect .Value ) bool {
slice , ok := v .Interface ().([]bool )
if !ok {
return false
}
for _ , x := range slice {
if x != false || state .sendZero {
if x {
state .encodeUint (1 )
} else {
state .encodeUint (0 )
}
}
}
return true
}
func encComplex64Array(state *encoderState , v reflect .Value ) bool {
if !v .CanAddr () {
return false
}
return encComplex64Slice (state , v .Slice (0 , v .Len ()))
}
func encComplex64Slice(state *encoderState , v reflect .Value ) bool {
slice , ok := v .Interface ().([]complex64 )
if !ok {
return false
}
for _ , x := range slice {
if x != 0 +0i || state .sendZero {
rpart := floatBits (float64 (real (x )))
ipart := floatBits (float64 (imag (x )))
state .encodeUint (rpart )
state .encodeUint (ipart )
}
}
return true
}
func encComplex128Array(state *encoderState , v reflect .Value ) bool {
if !v .CanAddr () {
return false
}
return encComplex128Slice (state , v .Slice (0 , v .Len ()))
}
func encComplex128Slice(state *encoderState , v reflect .Value ) bool {
slice , ok := v .Interface ().([]complex128 )
if !ok {
return false
}
for _ , x := range slice {
if x != 0 +0i || state .sendZero {
rpart := floatBits (real (x ))
ipart := floatBits (imag (x ))
state .encodeUint (rpart )
state .encodeUint (ipart )
}
}
return true
}
func encFloat32Array(state *encoderState , v reflect .Value ) bool {
if !v .CanAddr () {
return false
}
return encFloat32Slice (state , v .Slice (0 , v .Len ()))
}
func encFloat32Slice(state *encoderState , v reflect .Value ) bool {
slice , ok := v .Interface ().([]float32 )
if !ok {
return false
}
for _ , x := range slice {
if x != 0 || state .sendZero {
bits := floatBits (float64 (x ))
state .encodeUint (bits )
}
}
return true
}
func encFloat64Array(state *encoderState , v reflect .Value ) bool {
if !v .CanAddr () {
return false
}
return encFloat64Slice (state , v .Slice (0 , v .Len ()))
}
func encFloat64Slice(state *encoderState , v reflect .Value ) bool {
slice , ok := v .Interface ().([]float64 )
if !ok {
return false
}
for _ , x := range slice {
if x != 0 || state .sendZero {
bits := floatBits (x )
state .encodeUint (bits )
}
}
return true
}
func encIntArray(state *encoderState , v reflect .Value ) bool {
if !v .CanAddr () {
return false
}
return encIntSlice (state , v .Slice (0 , v .Len ()))
}
func encIntSlice(state *encoderState , v reflect .Value ) bool {
slice , ok := v .Interface ().([]int )
if !ok {
return false
}
for _ , x := range slice {
if x != 0 || state .sendZero {
state .encodeInt (int64 (x ))
}
}
return true
}
func encInt16Array(state *encoderState , v reflect .Value ) bool {
if !v .CanAddr () {
return false
}
return encInt16Slice (state , v .Slice (0 , v .Len ()))
}
func encInt16Slice(state *encoderState , v reflect .Value ) bool {
slice , ok := v .Interface ().([]int16 )
if !ok {
return false
}
for _ , x := range slice {
if x != 0 || state .sendZero {
state .encodeInt (int64 (x ))
}
}
return true
}
func encInt32Array(state *encoderState , v reflect .Value ) bool {
if !v .CanAddr () {
return false
}
return encInt32Slice (state , v .Slice (0 , v .Len ()))
}
func encInt32Slice(state *encoderState , v reflect .Value ) bool {
slice , ok := v .Interface ().([]int32 )
if !ok {
return false
}
for _ , x := range slice {
if x != 0 || state .sendZero {
state .encodeInt (int64 (x ))
}
}
return true
}
func encInt64Array(state *encoderState , v reflect .Value ) bool {
if !v .CanAddr () {
return false
}
return encInt64Slice (state , v .Slice (0 , v .Len ()))
}
func encInt64Slice(state *encoderState , v reflect .Value ) bool {
slice , ok := v .Interface ().([]int64 )
if !ok {
return false
}
for _ , x := range slice {
if x != 0 || state .sendZero {
state .encodeInt (x )
}
}
return true
}
func encInt8Array(state *encoderState , v reflect .Value ) bool {
if !v .CanAddr () {
return false
}
return encInt8Slice (state , v .Slice (0 , v .Len ()))
}
func encInt8Slice(state *encoderState , v reflect .Value ) bool {
slice , ok := v .Interface ().([]int8 )
if !ok {
return false
}
for _ , x := range slice {
if x != 0 || state .sendZero {
state .encodeInt (int64 (x ))
}
}
return true
}
func encStringArray(state *encoderState , v reflect .Value ) bool {
if !v .CanAddr () {
return false
}
return encStringSlice (state , v .Slice (0 , v .Len ()))
}
func encStringSlice(state *encoderState , v reflect .Value ) bool {
slice , ok := v .Interface ().([]string )
if !ok {
return false
}
for _ , x := range slice {
if x != "" || state .sendZero {
state .encodeUint (uint64 (len (x )))
state .b .WriteString (x )
}
}
return true
}
func encUintArray(state *encoderState , v reflect .Value ) bool {
if !v .CanAddr () {
return false
}
return encUintSlice (state , v .Slice (0 , v .Len ()))
}
func encUintSlice(state *encoderState , v reflect .Value ) bool {
slice , ok := v .Interface ().([]uint )
if !ok {
return false
}
for _ , x := range slice {
if x != 0 || state .sendZero {
state .encodeUint (uint64 (x ))
}
}
return true
}
func encUint16Array(state *encoderState , v reflect .Value ) bool {
if !v .CanAddr () {
return false
}
return encUint16Slice (state , v .Slice (0 , v .Len ()))
}
func encUint16Slice(state *encoderState , v reflect .Value ) bool {
slice , ok := v .Interface ().([]uint16 )
if !ok {
return false
}
for _ , x := range slice {
if x != 0 || state .sendZero {
state .encodeUint (uint64 (x ))
}
}
return true
}
func encUint32Array(state *encoderState , v reflect .Value ) bool {
if !v .CanAddr () {
return false
}
return encUint32Slice (state , v .Slice (0 , v .Len ()))
}
func encUint32Slice(state *encoderState , v reflect .Value ) bool {
slice , ok := v .Interface ().([]uint32 )
if !ok {
return false
}
for _ , x := range slice {
if x != 0 || state .sendZero {
state .encodeUint (uint64 (x ))
}
}
return true
}
func encUint64Array(state *encoderState , v reflect .Value ) bool {
if !v .CanAddr () {
return false
}
return encUint64Slice (state , v .Slice (0 , v .Len ()))
}
func encUint64Slice(state *encoderState , v reflect .Value ) bool {
slice , ok := v .Interface ().([]uint64 )
if !ok {
return false
}
for _ , x := range slice {
if x != 0 || state .sendZero {
state .encodeUint (x )
}
}
return true
}
func encUintptrArray(state *encoderState , v reflect .Value ) bool {
if !v .CanAddr () {
return false
}
return encUintptrSlice (state , v .Slice (0 , v .Len ()))
}
func encUintptrSlice(state *encoderState , v reflect .Value ) bool {
slice , ok := v .Interface ().([]uintptr )
if !ok {
return false
}
for _ , x := range slice {
if x != 0 || state .sendZero {
state .encodeUint (uint64 (x ))
}
}
return true
}
The pages are generated with Golds v0.7.3 . (GOOS=linux GOARCH=amd64)
Golds is a Go 101 project developed by Tapir Liu .
PR and bug reports are welcome and can be submitted to the issue list .
Please follow @zigo_101 (reachable from the left QR code) to get the latest news of Golds .