mirror of
https://github.com/golang/go
synced 2024-11-18 16:04:44 -07:00
a48de745b2
Benchmark results: benchmark old ns/op new ns/op delta BenchmarkEndToEndPipe-4 7547 7294 -3.35% BenchmarkEndToEndByteBuffer-4 5146 5092 -1.05% BenchmarkEndToEndSliceByteBuffer-4 552779 439768 -20.44% BenchmarkEncodeComplex128Slice-4 266370 266184 -0.07% BenchmarkEncodeFloat64Slice-4 111891 110258 -1.46% BenchmarkEncodeInt32Slice-4 74482 74080 -0.54% BenchmarkEncodeStringSlice-4 84404 84279 -0.15% BenchmarkEncodeInterfaceSlice-4 3942925 3045995 -22.75% BenchmarkDecodeComplex128Slice-4 451837 415282 -8.09% BenchmarkDecodeFloat64Slice-4 283584 262558 -7.41% BenchmarkDecodeInt32Slice-4 246571 237383 -3.73% BenchmarkDecodeStringSlice-4 734210 479625 -34.67% BenchmarkDecodeInterfaceSlice-4 4778225 4160935 -12.92% benchmark old allocs new allocs delta BenchmarkEndToEndPipe-4 3 2 -33.33% BenchmarkEndToEndByteBuffer-4 3 2 -33.33% BenchmarkEndToEndSliceByteBuffer-4 1002 402 -59.88% BenchmarkEncodeComplex128Slice-4 1 1 +0.00% BenchmarkEncodeFloat64Slice-4 1 1 +0.00% BenchmarkEncodeInt32Slice-4 1 1 +0.00% BenchmarkEncodeStringSlice-4 1 1 +0.00% BenchmarkEncodeInterfaceSlice-4 3001 1 -99.97% BenchmarkDecodeComplex128Slice-4 188 185 -1.60% BenchmarkDecodeFloat64Slice-4 188 185 -1.60% BenchmarkDecodeInt32Slice-4 188 185 -1.60% BenchmarkDecodeStringSlice-4 2188 1185 -45.84% BenchmarkDecodeInterfaceSlice-4 6197 4194 -32.32% benchmark old bytes new bytes delta BenchmarkEndToEndPipe-4 64 48 -25.00% BenchmarkEndToEndByteBuffer-4 64 48 -25.00% BenchmarkEndToEndSliceByteBuffer-4 34551 10554 -69.45% BenchmarkEncodeComplex128Slice-4 55 55 +0.00% BenchmarkEncodeFloat64Slice-4 33 33 +0.00% BenchmarkEncodeInt32Slice-4 32 32 +0.00% BenchmarkEncodeStringSlice-4 36 36 +0.00% BenchmarkEncodeInterfaceSlice-4 144555 347 -99.76% BenchmarkDecodeComplex128Slice-4 28240 28097 -0.51% BenchmarkDecodeFloat64Slice-4 11840 11697 -1.21% BenchmarkDecodeInt32Slice-4 10817 10673 -1.33% BenchmarkDecodeStringSlice-4 56128 39985 -28.76% BenchmarkDecodeInterfaceSlice-4 132565 100421 -24.25% Change-Id: Ief7c7706b1f2916486ab7190b81aafbb16b70f1e Reviewed-on: https://go-review.googlesource.com/13660 Reviewed-by: Russ Cox <rsc@golang.org>
470 lines
13 KiB
Go
470 lines
13 KiB
Go
// Created by decgen --output dec_helpers.go; DO NOT EDIT
|
|
|
|
// Copyright 2014 The Go Authors. All rights reserved.
|
|
// Use of this source code is governed by a BSD-style
|
|
// license that can be found in the LICENSE file.
|
|
|
|
package gob
|
|
|
|
import (
|
|
"math"
|
|
"reflect"
|
|
)
|
|
|
|
var decArrayHelper = map[reflect.Kind]decHelper{
|
|
reflect.Bool: decBoolArray,
|
|
reflect.Complex64: decComplex64Array,
|
|
reflect.Complex128: decComplex128Array,
|
|
reflect.Float32: decFloat32Array,
|
|
reflect.Float64: decFloat64Array,
|
|
reflect.Int: decIntArray,
|
|
reflect.Int16: decInt16Array,
|
|
reflect.Int32: decInt32Array,
|
|
reflect.Int64: decInt64Array,
|
|
reflect.Int8: decInt8Array,
|
|
reflect.String: decStringArray,
|
|
reflect.Uint: decUintArray,
|
|
reflect.Uint16: decUint16Array,
|
|
reflect.Uint32: decUint32Array,
|
|
reflect.Uint64: decUint64Array,
|
|
reflect.Uintptr: decUintptrArray,
|
|
}
|
|
|
|
var decSliceHelper = map[reflect.Kind]decHelper{
|
|
reflect.Bool: decBoolSlice,
|
|
reflect.Complex64: decComplex64Slice,
|
|
reflect.Complex128: decComplex128Slice,
|
|
reflect.Float32: decFloat32Slice,
|
|
reflect.Float64: decFloat64Slice,
|
|
reflect.Int: decIntSlice,
|
|
reflect.Int16: decInt16Slice,
|
|
reflect.Int32: decInt32Slice,
|
|
reflect.Int64: decInt64Slice,
|
|
reflect.Int8: decInt8Slice,
|
|
reflect.String: decStringSlice,
|
|
reflect.Uint: decUintSlice,
|
|
reflect.Uint16: decUint16Slice,
|
|
reflect.Uint32: decUint32Slice,
|
|
reflect.Uint64: decUint64Slice,
|
|
reflect.Uintptr: decUintptrSlice,
|
|
}
|
|
|
|
func decBoolArray(state *decoderState, v reflect.Value, length int, ovfl error) bool {
|
|
// Can only slice if it is addressable.
|
|
if !v.CanAddr() {
|
|
return false
|
|
}
|
|
return decBoolSlice(state, v.Slice(0, v.Len()), length, ovfl)
|
|
}
|
|
|
|
func decBoolSlice(state *decoderState, v reflect.Value, length int, ovfl error) bool {
|
|
slice, ok := v.Interface().([]bool)
|
|
if !ok {
|
|
// It is kind bool but not type bool. TODO: We can handle this unsafely.
|
|
return false
|
|
}
|
|
for i := 0; i < length; i++ {
|
|
if state.b.Len() == 0 {
|
|
errorf("decoding bool array or slice: length exceeds input size (%d elements)", length)
|
|
}
|
|
slice[i] = state.decodeUint() != 0
|
|
}
|
|
return true
|
|
}
|
|
|
|
func decComplex64Array(state *decoderState, v reflect.Value, length int, ovfl error) bool {
|
|
// Can only slice if it is addressable.
|
|
if !v.CanAddr() {
|
|
return false
|
|
}
|
|
return decComplex64Slice(state, v.Slice(0, v.Len()), length, ovfl)
|
|
}
|
|
|
|
func decComplex64Slice(state *decoderState, v reflect.Value, length int, ovfl error) bool {
|
|
slice, ok := v.Interface().([]complex64)
|
|
if !ok {
|
|
// It is kind complex64 but not type complex64. TODO: We can handle this unsafely.
|
|
return false
|
|
}
|
|
for i := 0; i < length; i++ {
|
|
if state.b.Len() == 0 {
|
|
errorf("decoding complex64 array or slice: length exceeds input size (%d elements)", length)
|
|
}
|
|
real := float32FromBits(state.decodeUint(), ovfl)
|
|
imag := float32FromBits(state.decodeUint(), ovfl)
|
|
slice[i] = complex(float32(real), float32(imag))
|
|
}
|
|
return true
|
|
}
|
|
|
|
func decComplex128Array(state *decoderState, v reflect.Value, length int, ovfl error) bool {
|
|
// Can only slice if it is addressable.
|
|
if !v.CanAddr() {
|
|
return false
|
|
}
|
|
return decComplex128Slice(state, v.Slice(0, v.Len()), length, ovfl)
|
|
}
|
|
|
|
func decComplex128Slice(state *decoderState, v reflect.Value, length int, ovfl error) bool {
|
|
slice, ok := v.Interface().([]complex128)
|
|
if !ok {
|
|
// It is kind complex128 but not type complex128. TODO: We can handle this unsafely.
|
|
return false
|
|
}
|
|
for i := 0; i < length; i++ {
|
|
if state.b.Len() == 0 {
|
|
errorf("decoding complex128 array or slice: length exceeds input size (%d elements)", length)
|
|
}
|
|
real := float64FromBits(state.decodeUint())
|
|
imag := float64FromBits(state.decodeUint())
|
|
slice[i] = complex(real, imag)
|
|
}
|
|
return true
|
|
}
|
|
|
|
func decFloat32Array(state *decoderState, v reflect.Value, length int, ovfl error) bool {
|
|
// Can only slice if it is addressable.
|
|
if !v.CanAddr() {
|
|
return false
|
|
}
|
|
return decFloat32Slice(state, v.Slice(0, v.Len()), length, ovfl)
|
|
}
|
|
|
|
func decFloat32Slice(state *decoderState, v reflect.Value, length int, ovfl error) bool {
|
|
slice, ok := v.Interface().([]float32)
|
|
if !ok {
|
|
// It is kind float32 but not type float32. TODO: We can handle this unsafely.
|
|
return false
|
|
}
|
|
for i := 0; i < length; i++ {
|
|
if state.b.Len() == 0 {
|
|
errorf("decoding float32 array or slice: length exceeds input size (%d elements)", length)
|
|
}
|
|
slice[i] = float32(float32FromBits(state.decodeUint(), ovfl))
|
|
}
|
|
return true
|
|
}
|
|
|
|
func decFloat64Array(state *decoderState, v reflect.Value, length int, ovfl error) bool {
|
|
// Can only slice if it is addressable.
|
|
if !v.CanAddr() {
|
|
return false
|
|
}
|
|
return decFloat64Slice(state, v.Slice(0, v.Len()), length, ovfl)
|
|
}
|
|
|
|
func decFloat64Slice(state *decoderState, v reflect.Value, length int, ovfl error) bool {
|
|
slice, ok := v.Interface().([]float64)
|
|
if !ok {
|
|
// It is kind float64 but not type float64. TODO: We can handle this unsafely.
|
|
return false
|
|
}
|
|
for i := 0; i < length; i++ {
|
|
if state.b.Len() == 0 {
|
|
errorf("decoding float64 array or slice: length exceeds input size (%d elements)", length)
|
|
}
|
|
slice[i] = float64FromBits(state.decodeUint())
|
|
}
|
|
return true
|
|
}
|
|
|
|
func decIntArray(state *decoderState, v reflect.Value, length int, ovfl error) bool {
|
|
// Can only slice if it is addressable.
|
|
if !v.CanAddr() {
|
|
return false
|
|
}
|
|
return decIntSlice(state, v.Slice(0, v.Len()), length, ovfl)
|
|
}
|
|
|
|
func decIntSlice(state *decoderState, v reflect.Value, length int, ovfl error) bool {
|
|
slice, ok := v.Interface().([]int)
|
|
if !ok {
|
|
// It is kind int but not type int. TODO: We can handle this unsafely.
|
|
return false
|
|
}
|
|
for i := 0; i < length; i++ {
|
|
if state.b.Len() == 0 {
|
|
errorf("decoding int array or slice: length exceeds input size (%d elements)", length)
|
|
}
|
|
x := state.decodeInt()
|
|
// MinInt and MaxInt
|
|
if x < ^int64(^uint(0)>>1) || int64(^uint(0)>>1) < x {
|
|
error_(ovfl)
|
|
}
|
|
slice[i] = int(x)
|
|
}
|
|
return true
|
|
}
|
|
|
|
func decInt16Array(state *decoderState, v reflect.Value, length int, ovfl error) bool {
|
|
// Can only slice if it is addressable.
|
|
if !v.CanAddr() {
|
|
return false
|
|
}
|
|
return decInt16Slice(state, v.Slice(0, v.Len()), length, ovfl)
|
|
}
|
|
|
|
func decInt16Slice(state *decoderState, v reflect.Value, length int, ovfl error) bool {
|
|
slice, ok := v.Interface().([]int16)
|
|
if !ok {
|
|
// It is kind int16 but not type int16. TODO: We can handle this unsafely.
|
|
return false
|
|
}
|
|
for i := 0; i < length; i++ {
|
|
if state.b.Len() == 0 {
|
|
errorf("decoding int16 array or slice: length exceeds input size (%d elements)", length)
|
|
}
|
|
x := state.decodeInt()
|
|
if x < math.MinInt16 || math.MaxInt16 < x {
|
|
error_(ovfl)
|
|
}
|
|
slice[i] = int16(x)
|
|
}
|
|
return true
|
|
}
|
|
|
|
func decInt32Array(state *decoderState, v reflect.Value, length int, ovfl error) bool {
|
|
// Can only slice if it is addressable.
|
|
if !v.CanAddr() {
|
|
return false
|
|
}
|
|
return decInt32Slice(state, v.Slice(0, v.Len()), length, ovfl)
|
|
}
|
|
|
|
func decInt32Slice(state *decoderState, v reflect.Value, length int, ovfl error) bool {
|
|
slice, ok := v.Interface().([]int32)
|
|
if !ok {
|
|
// It is kind int32 but not type int32. TODO: We can handle this unsafely.
|
|
return false
|
|
}
|
|
for i := 0; i < length; i++ {
|
|
if state.b.Len() == 0 {
|
|
errorf("decoding int32 array or slice: length exceeds input size (%d elements)", length)
|
|
}
|
|
x := state.decodeInt()
|
|
if x < math.MinInt32 || math.MaxInt32 < x {
|
|
error_(ovfl)
|
|
}
|
|
slice[i] = int32(x)
|
|
}
|
|
return true
|
|
}
|
|
|
|
func decInt64Array(state *decoderState, v reflect.Value, length int, ovfl error) bool {
|
|
// Can only slice if it is addressable.
|
|
if !v.CanAddr() {
|
|
return false
|
|
}
|
|
return decInt64Slice(state, v.Slice(0, v.Len()), length, ovfl)
|
|
}
|
|
|
|
func decInt64Slice(state *decoderState, v reflect.Value, length int, ovfl error) bool {
|
|
slice, ok := v.Interface().([]int64)
|
|
if !ok {
|
|
// It is kind int64 but not type int64. TODO: We can handle this unsafely.
|
|
return false
|
|
}
|
|
for i := 0; i < length; i++ {
|
|
if state.b.Len() == 0 {
|
|
errorf("decoding int64 array or slice: length exceeds input size (%d elements)", length)
|
|
}
|
|
slice[i] = state.decodeInt()
|
|
}
|
|
return true
|
|
}
|
|
|
|
func decInt8Array(state *decoderState, v reflect.Value, length int, ovfl error) bool {
|
|
// Can only slice if it is addressable.
|
|
if !v.CanAddr() {
|
|
return false
|
|
}
|
|
return decInt8Slice(state, v.Slice(0, v.Len()), length, ovfl)
|
|
}
|
|
|
|
func decInt8Slice(state *decoderState, v reflect.Value, length int, ovfl error) bool {
|
|
slice, ok := v.Interface().([]int8)
|
|
if !ok {
|
|
// It is kind int8 but not type int8. TODO: We can handle this unsafely.
|
|
return false
|
|
}
|
|
for i := 0; i < length; i++ {
|
|
if state.b.Len() == 0 {
|
|
errorf("decoding int8 array or slice: length exceeds input size (%d elements)", length)
|
|
}
|
|
x := state.decodeInt()
|
|
if x < math.MinInt8 || math.MaxInt8 < x {
|
|
error_(ovfl)
|
|
}
|
|
slice[i] = int8(x)
|
|
}
|
|
return true
|
|
}
|
|
|
|
func decStringArray(state *decoderState, v reflect.Value, length int, ovfl error) bool {
|
|
// Can only slice if it is addressable.
|
|
if !v.CanAddr() {
|
|
return false
|
|
}
|
|
return decStringSlice(state, v.Slice(0, v.Len()), length, ovfl)
|
|
}
|
|
|
|
func decStringSlice(state *decoderState, v reflect.Value, length int, ovfl error) bool {
|
|
slice, ok := v.Interface().([]string)
|
|
if !ok {
|
|
// It is kind string but not type string. TODO: We can handle this unsafely.
|
|
return false
|
|
}
|
|
for i := 0; i < length; i++ {
|
|
if state.b.Len() == 0 {
|
|
errorf("decoding string array or slice: length exceeds input size (%d elements)", length)
|
|
}
|
|
u := state.decodeUint()
|
|
n := int(u)
|
|
if n < 0 || uint64(n) != u || n > state.b.Len() {
|
|
errorf("length of string exceeds input size (%d bytes)", u)
|
|
}
|
|
if n > state.b.Len() {
|
|
errorf("string data too long for buffer: %d", n)
|
|
}
|
|
// Read the data.
|
|
data := state.b.Bytes()
|
|
if len(data) < n {
|
|
errorf("invalid string length %d: exceeds input size %d", n, len(data))
|
|
}
|
|
slice[i] = string(data[:n])
|
|
state.b.Drop(n)
|
|
}
|
|
return true
|
|
}
|
|
|
|
func decUintArray(state *decoderState, v reflect.Value, length int, ovfl error) bool {
|
|
// Can only slice if it is addressable.
|
|
if !v.CanAddr() {
|
|
return false
|
|
}
|
|
return decUintSlice(state, v.Slice(0, v.Len()), length, ovfl)
|
|
}
|
|
|
|
func decUintSlice(state *decoderState, v reflect.Value, length int, ovfl error) bool {
|
|
slice, ok := v.Interface().([]uint)
|
|
if !ok {
|
|
// It is kind uint but not type uint. TODO: We can handle this unsafely.
|
|
return false
|
|
}
|
|
for i := 0; i < length; i++ {
|
|
if state.b.Len() == 0 {
|
|
errorf("decoding uint array or slice: length exceeds input size (%d elements)", length)
|
|
}
|
|
x := state.decodeUint()
|
|
/*TODO if math.MaxUint32 < x {
|
|
error_(ovfl)
|
|
}*/
|
|
slice[i] = uint(x)
|
|
}
|
|
return true
|
|
}
|
|
|
|
func decUint16Array(state *decoderState, v reflect.Value, length int, ovfl error) bool {
|
|
// Can only slice if it is addressable.
|
|
if !v.CanAddr() {
|
|
return false
|
|
}
|
|
return decUint16Slice(state, v.Slice(0, v.Len()), length, ovfl)
|
|
}
|
|
|
|
func decUint16Slice(state *decoderState, v reflect.Value, length int, ovfl error) bool {
|
|
slice, ok := v.Interface().([]uint16)
|
|
if !ok {
|
|
// It is kind uint16 but not type uint16. TODO: We can handle this unsafely.
|
|
return false
|
|
}
|
|
for i := 0; i < length; i++ {
|
|
if state.b.Len() == 0 {
|
|
errorf("decoding uint16 array or slice: length exceeds input size (%d elements)", length)
|
|
}
|
|
x := state.decodeUint()
|
|
if math.MaxUint16 < x {
|
|
error_(ovfl)
|
|
}
|
|
slice[i] = uint16(x)
|
|
}
|
|
return true
|
|
}
|
|
|
|
func decUint32Array(state *decoderState, v reflect.Value, length int, ovfl error) bool {
|
|
// Can only slice if it is addressable.
|
|
if !v.CanAddr() {
|
|
return false
|
|
}
|
|
return decUint32Slice(state, v.Slice(0, v.Len()), length, ovfl)
|
|
}
|
|
|
|
func decUint32Slice(state *decoderState, v reflect.Value, length int, ovfl error) bool {
|
|
slice, ok := v.Interface().([]uint32)
|
|
if !ok {
|
|
// It is kind uint32 but not type uint32. TODO: We can handle this unsafely.
|
|
return false
|
|
}
|
|
for i := 0; i < length; i++ {
|
|
if state.b.Len() == 0 {
|
|
errorf("decoding uint32 array or slice: length exceeds input size (%d elements)", length)
|
|
}
|
|
x := state.decodeUint()
|
|
if math.MaxUint32 < x {
|
|
error_(ovfl)
|
|
}
|
|
slice[i] = uint32(x)
|
|
}
|
|
return true
|
|
}
|
|
|
|
func decUint64Array(state *decoderState, v reflect.Value, length int, ovfl error) bool {
|
|
// Can only slice if it is addressable.
|
|
if !v.CanAddr() {
|
|
return false
|
|
}
|
|
return decUint64Slice(state, v.Slice(0, v.Len()), length, ovfl)
|
|
}
|
|
|
|
func decUint64Slice(state *decoderState, v reflect.Value, length int, ovfl error) bool {
|
|
slice, ok := v.Interface().([]uint64)
|
|
if !ok {
|
|
// It is kind uint64 but not type uint64. TODO: We can handle this unsafely.
|
|
return false
|
|
}
|
|
for i := 0; i < length; i++ {
|
|
if state.b.Len() == 0 {
|
|
errorf("decoding uint64 array or slice: length exceeds input size (%d elements)", length)
|
|
}
|
|
slice[i] = state.decodeUint()
|
|
}
|
|
return true
|
|
}
|
|
|
|
func decUintptrArray(state *decoderState, v reflect.Value, length int, ovfl error) bool {
|
|
// Can only slice if it is addressable.
|
|
if !v.CanAddr() {
|
|
return false
|
|
}
|
|
return decUintptrSlice(state, v.Slice(0, v.Len()), length, ovfl)
|
|
}
|
|
|
|
func decUintptrSlice(state *decoderState, v reflect.Value, length int, ovfl error) bool {
|
|
slice, ok := v.Interface().([]uintptr)
|
|
if !ok {
|
|
// It is kind uintptr but not type uintptr. TODO: We can handle this unsafely.
|
|
return false
|
|
}
|
|
for i := 0; i < length; i++ {
|
|
if state.b.Len() == 0 {
|
|
errorf("decoding uintptr array or slice: length exceeds input size (%d elements)", length)
|
|
}
|
|
x := state.decodeUint()
|
|
if uint64(^uintptr(0)) < x {
|
|
error_(ovfl)
|
|
}
|
|
slice[i] = uintptr(x)
|
|
}
|
|
return true
|
|
}
|