Commit 868948ba authored by Rob Pike's avatar Rob Pike

encoding/gob: fix 386 build

LGTM=ruiu
R=golang-codereviews, ruiu
CC=golang-codereviews
https://golang.org/cl/146320043
parent 9c3fc838
...@@ -536,18 +536,15 @@ func (dec *Decoder) ignoreMap(state *decoderState, keyOp, elemOp decOp) { ...@@ -536,18 +536,15 @@ func (dec *Decoder) ignoreMap(state *decoderState, keyOp, elemOp decOp) {
// Slices are encoded as an unsigned length followed by the elements. // Slices are encoded as an unsigned length followed by the elements.
func (dec *Decoder) decodeSlice(state *decoderState, value reflect.Value, elemOp decOp, ovfl error) { func (dec *Decoder) decodeSlice(state *decoderState, value reflect.Value, elemOp decOp, ovfl error) {
u := state.decodeUint() u := state.decodeUint()
n := int(u)
if n < 0 || uint64(n) != u {
// We don't check n against buffer length here because if it's a slice
// of interfaces, there will be buffer reloads.
errorf("length of %s is negative (%d bytes)", value.Type(), u)
}
typ := value.Type() typ := value.Type()
size := uint64(typ.Elem().Size()) size := uint64(typ.Elem().Size())
// Take care with overflow in this calculation.
nBytes := u * size nBytes := u * size
if nBytes > tooBig || (size > 0 && nBytes/size != u) { n := int(u)
errorf("%s slice too big: %d elements of %d bytes", typ.Elem(), n, size) // Take care with overflow in this calculation.
if n < 0 || uint64(n) != u || nBytes > tooBig || (size > 0 && nBytes/size != u) {
// We don't check n against buffer length here because if it's a slice
// of interfaces, there will be buffer reloads.
errorf("%s slice too big: %d elements of %d bytes", typ.Elem(), u, size)
} }
if value.Cap() < n { if value.Cap() < n {
value.Set(reflect.MakeSlice(typ, n, n)) value.Set(reflect.MakeSlice(typ, n, n))
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment