1
2
3
4
5
6
7 package gob
8
9 import (
10 "encoding"
11 "errors"
12 "internal/saferio"
13 "io"
14 "math"
15 "math/bits"
16 "reflect"
17 )
18
19 var (
20 errBadUint = errors.New("gob: encoded unsigned integer out of range")
21 errBadType = errors.New("gob: unknown type id or corrupted data")
22 errRange = errors.New("gob: bad data: field numbers out of bounds")
23 )
24
25 type decHelper func(state *decoderState, v reflect.Value, length int, ovfl error) bool
26
27
28
29 type decoderState struct {
30 dec *Decoder
31
32
33 b *decBuffer
34 fieldnum int
35 next *decoderState
36 }
37
38
39
40 type decBuffer struct {
41 data []byte
42 offset int
43 }
44
45 func (d *decBuffer) Read(p []byte) (int, error) {
46 n := copy(p, d.data[d.offset:])
47 if n == 0 && len(p) != 0 {
48 return 0, io.EOF
49 }
50 d.offset += n
51 return n, nil
52 }
53
54 func (d *decBuffer) Drop(n int) {
55 if n > d.Len() {
56 panic("drop")
57 }
58 d.offset += n
59 }
60
61 func (d *decBuffer) ReadByte() (byte, error) {
62 if d.offset >= len(d.data) {
63 return 0, io.EOF
64 }
65 c := d.data[d.offset]
66 d.offset++
67 return c, nil
68 }
69
70 func (d *decBuffer) Len() int {
71 return len(d.data) - d.offset
72 }
73
74 func (d *decBuffer) Bytes() []byte {
75 return d.data[d.offset:]
76 }
77
78
79 func (d *decBuffer) SetBytes(data []byte) {
80 d.data = data
81 d.offset = 0
82 }
83
84 func (d *decBuffer) Reset() {
85 d.data = d.data[0:0]
86 d.offset = 0
87 }
88
89
90
91 func (dec *Decoder) newDecoderState(buf *decBuffer) *decoderState {
92 d := dec.freeList
93 if d == nil {
94 d = new(decoderState)
95 d.dec = dec
96 } else {
97 dec.freeList = d.next
98 }
99 d.b = buf
100 return d
101 }
102
103 func (dec *Decoder) freeDecoderState(d *decoderState) {
104 d.next = dec.freeList
105 dec.freeList = d
106 }
107
108 func overflow(name string) error {
109 return errors.New(`value for "` + name + `" out of range`)
110 }
111
112
113
114 func decodeUintReader(r io.Reader, buf []byte) (x uint64, width int, err error) {
115 width = 1
116 n, err := io.ReadFull(r, buf[0:width])
117 if n == 0 {
118 return
119 }
120 b := buf[0]
121 if b <= 0x7f {
122 return uint64(b), width, nil
123 }
124 n = -int(int8(b))
125 if n > uint64Size {
126 err = errBadUint
127 return
128 }
129 width, err = io.ReadFull(r, buf[0:n])
130 if err != nil {
131 if err == io.EOF {
132 err = io.ErrUnexpectedEOF
133 }
134 return
135 }
136
137 for _, b := range buf[0:width] {
138 x = x<<8 | uint64(b)
139 }
140 width++
141 return
142 }
143
144
145
146 func (state *decoderState) decodeUint() (x uint64) {
147 b, err := state.b.ReadByte()
148 if err != nil {
149 error_(err)
150 }
151 if b <= 0x7f {
152 return uint64(b)
153 }
154 n := -int(int8(b))
155 if n > uint64Size {
156 error_(errBadUint)
157 }
158 buf := state.b.Bytes()
159 if len(buf) < n {
160 errorf("invalid uint data length %d: exceeds input size %d", n, len(buf))
161 }
162
163
164 for _, b := range buf[0:n] {
165 x = x<<8 | uint64(b)
166 }
167 state.b.Drop(n)
168 return x
169 }
170
171
172
173 func (state *decoderState) decodeInt() int64 {
174 x := state.decodeUint()
175 if x&1 != 0 {
176 return ^int64(x >> 1)
177 }
178 return int64(x >> 1)
179 }
180
181
182
183
184 func (state *decoderState) getLength() (int, bool) {
185 n := int(state.decodeUint())
186 if n < 0 || state.b.Len() < n || tooBig <= n {
187 return 0, false
188 }
189 return n, true
190 }
191
192
193 type decOp func(i *decInstr, state *decoderState, v reflect.Value)
194
195
196 type decInstr struct {
197 op decOp
198 field int
199 index []int
200 ovfl error
201 }
202
203
204 func ignoreUint(i *decInstr, state *decoderState, v reflect.Value) {
205 state.decodeUint()
206 }
207
208
209
210 func ignoreTwoUints(i *decInstr, state *decoderState, v reflect.Value) {
211 state.decodeUint()
212 state.decodeUint()
213 }
214
215
216
217
218
219
220
221
222
223
224
225
226 func decAlloc(v reflect.Value) reflect.Value {
227 for v.Kind() == reflect.Pointer {
228 if v.IsNil() {
229 v.Set(reflect.New(v.Type().Elem()))
230 }
231 v = v.Elem()
232 }
233 return v
234 }
235
236
237 func decBool(i *decInstr, state *decoderState, value reflect.Value) {
238 value.SetBool(state.decodeUint() != 0)
239 }
240
241
242 func decInt8(i *decInstr, state *decoderState, value reflect.Value) {
243 v := state.decodeInt()
244 if v < math.MinInt8 || math.MaxInt8 < v {
245 error_(i.ovfl)
246 }
247 value.SetInt(v)
248 }
249
250
251 func decUint8(i *decInstr, state *decoderState, value reflect.Value) {
252 v := state.decodeUint()
253 if math.MaxUint8 < v {
254 error_(i.ovfl)
255 }
256 value.SetUint(v)
257 }
258
259
260 func decInt16(i *decInstr, state *decoderState, value reflect.Value) {
261 v := state.decodeInt()
262 if v < math.MinInt16 || math.MaxInt16 < v {
263 error_(i.ovfl)
264 }
265 value.SetInt(v)
266 }
267
268
269 func decUint16(i *decInstr, state *decoderState, value reflect.Value) {
270 v := state.decodeUint()
271 if math.MaxUint16 < v {
272 error_(i.ovfl)
273 }
274 value.SetUint(v)
275 }
276
277
278 func decInt32(i *decInstr, state *decoderState, value reflect.Value) {
279 v := state.decodeInt()
280 if v < math.MinInt32 || math.MaxInt32 < v {
281 error_(i.ovfl)
282 }
283 value.SetInt(v)
284 }
285
286
287 func decUint32(i *decInstr, state *decoderState, value reflect.Value) {
288 v := state.decodeUint()
289 if math.MaxUint32 < v {
290 error_(i.ovfl)
291 }
292 value.SetUint(v)
293 }
294
295
296 func decInt64(i *decInstr, state *decoderState, value reflect.Value) {
297 v := state.decodeInt()
298 value.SetInt(v)
299 }
300
301
302 func decUint64(i *decInstr, state *decoderState, value reflect.Value) {
303 v := state.decodeUint()
304 value.SetUint(v)
305 }
306
307
308
309
310
311
312 func float64FromBits(u uint64) float64 {
313 v := bits.ReverseBytes64(u)
314 return math.Float64frombits(v)
315 }
316
317
318
319
320
321 func float32FromBits(u uint64, ovfl error) float64 {
322 v := float64FromBits(u)
323 av := v
324 if av < 0 {
325 av = -av
326 }
327
328 if math.MaxFloat32 < av && av <= math.MaxFloat64 {
329 error_(ovfl)
330 }
331 return v
332 }
333
334
335
336 func decFloat32(i *decInstr, state *decoderState, value reflect.Value) {
337 value.SetFloat(float32FromBits(state.decodeUint(), i.ovfl))
338 }
339
340
341
342 func decFloat64(i *decInstr, state *decoderState, value reflect.Value) {
343 value.SetFloat(float64FromBits(state.decodeUint()))
344 }
345
346
347
348
349 func decComplex64(i *decInstr, state *decoderState, value reflect.Value) {
350 real := float32FromBits(state.decodeUint(), i.ovfl)
351 imag := float32FromBits(state.decodeUint(), i.ovfl)
352 value.SetComplex(complex(real, imag))
353 }
354
355
356
357
358 func decComplex128(i *decInstr, state *decoderState, value reflect.Value) {
359 real := float64FromBits(state.decodeUint())
360 imag := float64FromBits(state.decodeUint())
361 value.SetComplex(complex(real, imag))
362 }
363
364
365
366
367 func decUint8Slice(i *decInstr, state *decoderState, value reflect.Value) {
368 n, ok := state.getLength()
369 if !ok {
370 errorf("bad %s slice length: %d", value.Type(), n)
371 }
372 if value.Cap() < n {
373 safe := saferio.SliceCap[byte](uint64(n))
374 if safe < 0 {
375 errorf("%s slice too big: %d elements", value.Type(), n)
376 }
377 value.Set(reflect.MakeSlice(value.Type(), safe, safe))
378 ln := safe
379 i := 0
380 for i < n {
381 if i >= ln {
382
383
384
385
386
387 value.Grow(1)
388 }
389
390
391 ln = value.Cap()
392 if ln > n {
393 ln = n
394 }
395 value.SetLen(ln)
396 sub := value.Slice(i, ln)
397 if _, err := state.b.Read(sub.Bytes()); err != nil {
398 errorf("error decoding []byte at %d: %s", i, err)
399 }
400 i = ln
401 }
402 } else {
403 value.SetLen(n)
404 if _, err := state.b.Read(value.Bytes()); err != nil {
405 errorf("error decoding []byte: %s", err)
406 }
407 }
408 }
409
410
411
412
413 func decString(i *decInstr, state *decoderState, value reflect.Value) {
414 n, ok := state.getLength()
415 if !ok {
416 errorf("bad %s slice length: %d", value.Type(), n)
417 }
418
419 data := state.b.Bytes()
420 if len(data) < n {
421 errorf("invalid string length %d: exceeds input size %d", n, len(data))
422 }
423 s := string(data[:n])
424 state.b.Drop(n)
425 value.SetString(s)
426 }
427
428
429 func ignoreUint8Array(i *decInstr, state *decoderState, value reflect.Value) {
430 n, ok := state.getLength()
431 if !ok {
432 errorf("slice length too large")
433 }
434 bn := state.b.Len()
435 if bn < n {
436 errorf("invalid slice length %d: exceeds input size %d", n, bn)
437 }
438 state.b.Drop(n)
439 }
440
441
442
443
444
445 type decEngine struct {
446 instr []decInstr
447 numInstr int
448 }
449
450
451
452
453 func (dec *Decoder) decodeSingle(engine *decEngine, value reflect.Value) {
454 state := dec.newDecoderState(&dec.buf)
455 defer dec.freeDecoderState(state)
456 state.fieldnum = singletonField
457 if state.decodeUint() != 0 {
458 errorf("decode: corrupted data: non-zero delta for singleton")
459 }
460 instr := &engine.instr[singletonField]
461 instr.op(instr, state, value)
462 }
463
464
465
466
467
468
469 func (dec *Decoder) decodeStruct(engine *decEngine, value reflect.Value) {
470 state := dec.newDecoderState(&dec.buf)
471 defer dec.freeDecoderState(state)
472 state.fieldnum = -1
473 for state.b.Len() > 0 {
474 delta := int(state.decodeUint())
475 if delta < 0 {
476 errorf("decode: corrupted data: negative delta")
477 }
478 if delta == 0 {
479 break
480 }
481 if state.fieldnum >= len(engine.instr)-delta {
482 error_(errRange)
483 }
484 fieldnum := state.fieldnum + delta
485 instr := &engine.instr[fieldnum]
486 var field reflect.Value
487 if instr.index != nil {
488
489 field = value.FieldByIndex(instr.index)
490 if field.Kind() == reflect.Pointer {
491 field = decAlloc(field)
492 }
493 }
494 instr.op(instr, state, field)
495 state.fieldnum = fieldnum
496 }
497 }
498
499 var noValue reflect.Value
500
501
502 func (dec *Decoder) ignoreStruct(engine *decEngine) {
503 state := dec.newDecoderState(&dec.buf)
504 defer dec.freeDecoderState(state)
505 state.fieldnum = -1
506 for state.b.Len() > 0 {
507 delta := int(state.decodeUint())
508 if delta < 0 {
509 errorf("ignore decode: corrupted data: negative delta")
510 }
511 if delta == 0 {
512 break
513 }
514 fieldnum := state.fieldnum + delta
515 if fieldnum >= len(engine.instr) {
516 error_(errRange)
517 }
518 instr := &engine.instr[fieldnum]
519 instr.op(instr, state, noValue)
520 state.fieldnum = fieldnum
521 }
522 }
523
524
525
526 func (dec *Decoder) ignoreSingle(engine *decEngine) {
527 state := dec.newDecoderState(&dec.buf)
528 defer dec.freeDecoderState(state)
529 state.fieldnum = singletonField
530 delta := int(state.decodeUint())
531 if delta != 0 {
532 errorf("decode: corrupted data: non-zero delta for singleton")
533 }
534 instr := &engine.instr[singletonField]
535 instr.op(instr, state, noValue)
536 }
537
538
539 func (dec *Decoder) decodeArrayHelper(state *decoderState, value reflect.Value, elemOp decOp, length int, ovfl error, helper decHelper) {
540 if helper != nil && helper(state, value, length, ovfl) {
541 return
542 }
543 instr := &decInstr{elemOp, 0, nil, ovfl}
544 isPtr := value.Type().Elem().Kind() == reflect.Pointer
545 ln := value.Len()
546 for i := 0; i < length; i++ {
547 if state.b.Len() == 0 {
548 errorf("decoding array or slice: length exceeds input size (%d elements)", length)
549 }
550 if i >= ln {
551
552
553 value.Grow(1)
554 cp := value.Cap()
555 if cp > length {
556 cp = length
557 }
558 value.SetLen(cp)
559 ln = cp
560 }
561 v := value.Index(i)
562 if isPtr {
563 v = decAlloc(v)
564 }
565 elemOp(instr, state, v)
566 }
567 }
568
569
570
571
572 func (dec *Decoder) decodeArray(state *decoderState, value reflect.Value, elemOp decOp, length int, ovfl error, helper decHelper) {
573 if n := state.decodeUint(); n != uint64(length) {
574 errorf("length mismatch in decodeArray")
575 }
576 dec.decodeArrayHelper(state, value, elemOp, length, ovfl, helper)
577 }
578
579
580 func decodeIntoValue(state *decoderState, op decOp, isPtr bool, value reflect.Value, instr *decInstr) reflect.Value {
581 v := value
582 if isPtr {
583 v = decAlloc(value)
584 }
585
586 op(instr, state, v)
587 return value
588 }
589
590
591
592
593
594 func (dec *Decoder) decodeMap(mtyp reflect.Type, state *decoderState, value reflect.Value, keyOp, elemOp decOp, ovfl error) {
595 n := int(state.decodeUint())
596 if value.IsNil() {
597 value.Set(reflect.MakeMapWithSize(mtyp, n))
598 }
599 keyIsPtr := mtyp.Key().Kind() == reflect.Pointer
600 elemIsPtr := mtyp.Elem().Kind() == reflect.Pointer
601 keyInstr := &decInstr{keyOp, 0, nil, ovfl}
602 elemInstr := &decInstr{elemOp, 0, nil, ovfl}
603 keyP := reflect.New(mtyp.Key())
604 elemP := reflect.New(mtyp.Elem())
605 for i := 0; i < n; i++ {
606 key := decodeIntoValue(state, keyOp, keyIsPtr, keyP.Elem(), keyInstr)
607 elem := decodeIntoValue(state, elemOp, elemIsPtr, elemP.Elem(), elemInstr)
608 value.SetMapIndex(key, elem)
609 keyP.Elem().SetZero()
610 elemP.Elem().SetZero()
611 }
612 }
613
614
615 func (dec *Decoder) ignoreArrayHelper(state *decoderState, elemOp decOp, length int) {
616 instr := &decInstr{elemOp, 0, nil, errors.New("no error")}
617 for i := 0; i < length; i++ {
618 if state.b.Len() == 0 {
619 errorf("decoding array or slice: length exceeds input size (%d elements)", length)
620 }
621 elemOp(instr, state, noValue)
622 }
623 }
624
625
626 func (dec *Decoder) ignoreArray(state *decoderState, elemOp decOp, length int) {
627 if n := state.decodeUint(); n != uint64(length) {
628 errorf("length mismatch in ignoreArray")
629 }
630 dec.ignoreArrayHelper(state, elemOp, length)
631 }
632
633
634 func (dec *Decoder) ignoreMap(state *decoderState, keyOp, elemOp decOp) {
635 n := int(state.decodeUint())
636 keyInstr := &decInstr{keyOp, 0, nil, errors.New("no error")}
637 elemInstr := &decInstr{elemOp, 0, nil, errors.New("no error")}
638 for i := 0; i < n; i++ {
639 keyOp(keyInstr, state, noValue)
640 elemOp(elemInstr, state, noValue)
641 }
642 }
643
644
645
646 func (dec *Decoder) decodeSlice(state *decoderState, value reflect.Value, elemOp decOp, ovfl error, helper decHelper) {
647 u := state.decodeUint()
648 typ := value.Type()
649 size := uint64(typ.Elem().Size())
650 nBytes := u * size
651 n := int(u)
652
653 if n < 0 || uint64(n) != u || nBytes > tooBig || (size > 0 && nBytes/size != u) {
654
655
656 errorf("%s slice too big: %d elements of %d bytes", typ.Elem(), u, size)
657 }
658 if value.Cap() < n {
659 safe := saferio.SliceCapWithSize(size, uint64(n))
660 if safe < 0 {
661 errorf("%s slice too big: %d elements of %d bytes", typ.Elem(), u, size)
662 }
663 value.Set(reflect.MakeSlice(typ, safe, safe))
664 } else {
665 value.SetLen(n)
666 }
667 dec.decodeArrayHelper(state, value, elemOp, n, ovfl, helper)
668 }
669
670
671 func (dec *Decoder) ignoreSlice(state *decoderState, elemOp decOp) {
672 dec.ignoreArrayHelper(state, elemOp, int(state.decodeUint()))
673 }
674
675
676
677
678 func (dec *Decoder) decodeInterface(ityp reflect.Type, state *decoderState, value reflect.Value) {
679
680 nr := state.decodeUint()
681 if nr > 1<<31 {
682 errorf("invalid type name length %d", nr)
683 }
684 if nr > uint64(state.b.Len()) {
685 errorf("invalid type name length %d: exceeds input size", nr)
686 }
687 n := int(nr)
688 name := state.b.Bytes()[:n]
689 state.b.Drop(n)
690
691 if len(name) == 0 {
692
693 value.SetZero()
694 return
695 }
696 if len(name) > 1024 {
697 errorf("name too long (%d bytes): %.20q...", len(name), name)
698 }
699
700 typi, ok := nameToConcreteType.Load(string(name))
701 if !ok {
702 errorf("name not registered for interface: %q", name)
703 }
704 typ := typi.(reflect.Type)
705
706
707 concreteId := dec.decodeTypeSequence(true)
708 if concreteId < 0 {
709 error_(dec.err)
710 }
711
712
713 state.decodeUint()
714
715 v := allocValue(typ)
716 dec.decodeValue(concreteId, v)
717 if dec.err != nil {
718 error_(dec.err)
719 }
720
721
722 if !typ.AssignableTo(ityp) {
723 errorf("%s is not assignable to type %s", typ, ityp)
724 }
725
726 value.Set(v)
727 }
728
729
730 func (dec *Decoder) ignoreInterface(state *decoderState) {
731
732 n, ok := state.getLength()
733 if !ok {
734 errorf("bad interface encoding: name too large for buffer")
735 }
736 bn := state.b.Len()
737 if bn < n {
738 errorf("invalid interface value length %d: exceeds input size %d", n, bn)
739 }
740 state.b.Drop(n)
741 id := dec.decodeTypeSequence(true)
742 if id < 0 {
743 error_(dec.err)
744 }
745
746 n, ok = state.getLength()
747 if !ok {
748 errorf("bad interface encoding: data length too large for buffer")
749 }
750 state.b.Drop(n)
751 }
752
753
754
755 func (dec *Decoder) decodeGobDecoder(ut *userTypeInfo, state *decoderState, value reflect.Value) {
756
757 n, ok := state.getLength()
758 if !ok {
759 errorf("GobDecoder: length too large for buffer")
760 }
761 b := state.b.Bytes()
762 if len(b) < n {
763 errorf("GobDecoder: invalid data length %d: exceeds input size %d", n, len(b))
764 }
765 b = b[:n]
766 state.b.Drop(n)
767 var err error
768
769 switch ut.externalDec {
770 case xGob:
771 err = value.Interface().(GobDecoder).GobDecode(b)
772 case xBinary:
773 err = value.Interface().(encoding.BinaryUnmarshaler).UnmarshalBinary(b)
774 case xText:
775 err = value.Interface().(encoding.TextUnmarshaler).UnmarshalText(b)
776 }
777 if err != nil {
778 error_(err)
779 }
780 }
781
782
783 func (dec *Decoder) ignoreGobDecoder(state *decoderState) {
784
785 n, ok := state.getLength()
786 if !ok {
787 errorf("GobDecoder: length too large for buffer")
788 }
789 bn := state.b.Len()
790 if bn < n {
791 errorf("GobDecoder: invalid data length %d: exceeds input size %d", n, bn)
792 }
793 state.b.Drop(n)
794 }
795
796
797 var decOpTable = [...]decOp{
798 reflect.Bool: decBool,
799 reflect.Int8: decInt8,
800 reflect.Int16: decInt16,
801 reflect.Int32: decInt32,
802 reflect.Int64: decInt64,
803 reflect.Uint8: decUint8,
804 reflect.Uint16: decUint16,
805 reflect.Uint32: decUint32,
806 reflect.Uint64: decUint64,
807 reflect.Float32: decFloat32,
808 reflect.Float64: decFloat64,
809 reflect.Complex64: decComplex64,
810 reflect.Complex128: decComplex128,
811 reflect.String: decString,
812 }
813
814
815 var decIgnoreOpMap = map[typeId]decOp{
816 tBool: ignoreUint,
817 tInt: ignoreUint,
818 tUint: ignoreUint,
819 tFloat: ignoreUint,
820 tBytes: ignoreUint8Array,
821 tString: ignoreUint8Array,
822 tComplex: ignoreTwoUints,
823 }
824
825
826
827 func (dec *Decoder) decOpFor(wireId typeId, rt reflect.Type, name string, inProgress map[reflect.Type]*decOp) *decOp {
828 ut := userType(rt)
829
830 if ut.externalDec != 0 {
831 return dec.gobDecodeOpFor(ut)
832 }
833
834
835
836 if opPtr := inProgress[rt]; opPtr != nil {
837 return opPtr
838 }
839 typ := ut.base
840 var op decOp
841 k := typ.Kind()
842 if int(k) < len(decOpTable) {
843 op = decOpTable[k]
844 }
845 if op == nil {
846 inProgress[rt] = &op
847
848 switch t := typ; t.Kind() {
849 case reflect.Array:
850 name = "element of " + name
851 elemId := dec.wireType[wireId].ArrayT.Elem
852 elemOp := dec.decOpFor(elemId, t.Elem(), name, inProgress)
853 ovfl := overflow(name)
854 helper := decArrayHelper[t.Elem().Kind()]
855 op = func(i *decInstr, state *decoderState, value reflect.Value) {
856 state.dec.decodeArray(state, value, *elemOp, t.Len(), ovfl, helper)
857 }
858
859 case reflect.Map:
860 keyId := dec.wireType[wireId].MapT.Key
861 elemId := dec.wireType[wireId].MapT.Elem
862 keyOp := dec.decOpFor(keyId, t.Key(), "key of "+name, inProgress)
863 elemOp := dec.decOpFor(elemId, t.Elem(), "element of "+name, inProgress)
864 ovfl := overflow(name)
865 op = func(i *decInstr, state *decoderState, value reflect.Value) {
866 state.dec.decodeMap(t, state, value, *keyOp, *elemOp, ovfl)
867 }
868
869 case reflect.Slice:
870 name = "element of " + name
871 if t.Elem().Kind() == reflect.Uint8 {
872 op = decUint8Slice
873 break
874 }
875 var elemId typeId
876 if tt := builtinIdToType(wireId); tt != nil {
877 elemId = tt.(*sliceType).Elem
878 } else {
879 elemId = dec.wireType[wireId].SliceT.Elem
880 }
881 elemOp := dec.decOpFor(elemId, t.Elem(), name, inProgress)
882 ovfl := overflow(name)
883 helper := decSliceHelper[t.Elem().Kind()]
884 op = func(i *decInstr, state *decoderState, value reflect.Value) {
885 state.dec.decodeSlice(state, value, *elemOp, ovfl, helper)
886 }
887
888 case reflect.Struct:
889
890 ut := userType(typ)
891 enginePtr, err := dec.getDecEnginePtr(wireId, ut)
892 if err != nil {
893 error_(err)
894 }
895 op = func(i *decInstr, state *decoderState, value reflect.Value) {
896
897 dec.decodeStruct(*enginePtr, value)
898 }
899 case reflect.Interface:
900 op = func(i *decInstr, state *decoderState, value reflect.Value) {
901 state.dec.decodeInterface(t, state, value)
902 }
903 }
904 }
905 if op == nil {
906 errorf("decode can't handle type %s", rt)
907 }
908 return &op
909 }
910
911 var maxIgnoreNestingDepth = 10000
912
913
914 func (dec *Decoder) decIgnoreOpFor(wireId typeId, inProgress map[typeId]*decOp, depth int) *decOp {
915 if depth > maxIgnoreNestingDepth {
916 error_(errors.New("invalid nesting depth"))
917 }
918
919
920 if opPtr := inProgress[wireId]; opPtr != nil {
921 return opPtr
922 }
923 op, ok := decIgnoreOpMap[wireId]
924 if !ok {
925 inProgress[wireId] = &op
926 if wireId == tInterface {
927
928
929 op = func(i *decInstr, state *decoderState, value reflect.Value) {
930 state.dec.ignoreInterface(state)
931 }
932 return &op
933 }
934
935 wire := dec.wireType[wireId]
936 switch {
937 case wire == nil:
938 errorf("bad data: undefined type %s", wireId.string())
939 case wire.ArrayT != nil:
940 elemId := wire.ArrayT.Elem
941 elemOp := dec.decIgnoreOpFor(elemId, inProgress, depth+1)
942 op = func(i *decInstr, state *decoderState, value reflect.Value) {
943 state.dec.ignoreArray(state, *elemOp, wire.ArrayT.Len)
944 }
945
946 case wire.MapT != nil:
947 keyId := dec.wireType[wireId].MapT.Key
948 elemId := dec.wireType[wireId].MapT.Elem
949 keyOp := dec.decIgnoreOpFor(keyId, inProgress, depth+1)
950 elemOp := dec.decIgnoreOpFor(elemId, inProgress, depth+1)
951 op = func(i *decInstr, state *decoderState, value reflect.Value) {
952 state.dec.ignoreMap(state, *keyOp, *elemOp)
953 }
954
955 case wire.SliceT != nil:
956 elemId := wire.SliceT.Elem
957 elemOp := dec.decIgnoreOpFor(elemId, inProgress, depth+1)
958 op = func(i *decInstr, state *decoderState, value reflect.Value) {
959 state.dec.ignoreSlice(state, *elemOp)
960 }
961
962 case wire.StructT != nil:
963
964 enginePtr, err := dec.getIgnoreEnginePtr(wireId)
965 if err != nil {
966 error_(err)
967 }
968 op = func(i *decInstr, state *decoderState, value reflect.Value) {
969
970 state.dec.ignoreStruct(*enginePtr)
971 }
972
973 case wire.GobEncoderT != nil, wire.BinaryMarshalerT != nil, wire.TextMarshalerT != nil:
974 op = func(i *decInstr, state *decoderState, value reflect.Value) {
975 state.dec.ignoreGobDecoder(state)
976 }
977 }
978 }
979 if op == nil {
980 errorf("bad data: ignore can't handle type %s", wireId.string())
981 }
982 return &op
983 }
984
985
986
987 func (dec *Decoder) gobDecodeOpFor(ut *userTypeInfo) *decOp {
988 rcvrType := ut.user
989 if ut.decIndir == -1 {
990 rcvrType = reflect.PointerTo(rcvrType)
991 } else if ut.decIndir > 0 {
992 for i := int8(0); i < ut.decIndir; i++ {
993 rcvrType = rcvrType.Elem()
994 }
995 }
996 var op decOp
997 op = func(i *decInstr, state *decoderState, value reflect.Value) {
998
999 if value.Kind() != reflect.Pointer && rcvrType.Kind() == reflect.Pointer {
1000 value = value.Addr()
1001 }
1002 state.dec.decodeGobDecoder(ut, state, value)
1003 }
1004 return &op
1005 }
1006
1007
1008
1009
1010
1011 func (dec *Decoder) compatibleType(fr reflect.Type, fw typeId, inProgress map[reflect.Type]typeId) bool {
1012 if rhs, ok := inProgress[fr]; ok {
1013 return rhs == fw
1014 }
1015 inProgress[fr] = fw
1016 ut := userType(fr)
1017 wire, ok := dec.wireType[fw]
1018
1019
1020
1021
1022
1023
1024 if (ut.externalDec == xGob) != (ok && wire.GobEncoderT != nil) ||
1025 (ut.externalDec == xBinary) != (ok && wire.BinaryMarshalerT != nil) ||
1026 (ut.externalDec == xText) != (ok && wire.TextMarshalerT != nil) {
1027 return false
1028 }
1029 if ut.externalDec != 0 {
1030 return true
1031 }
1032 switch t := ut.base; t.Kind() {
1033 default:
1034
1035 return false
1036 case reflect.Bool:
1037 return fw == tBool
1038 case reflect.Int, reflect.Int8, reflect.Int16, reflect.Int32, reflect.Int64:
1039 return fw == tInt
1040 case reflect.Uint, reflect.Uint8, reflect.Uint16, reflect.Uint32, reflect.Uint64, reflect.Uintptr:
1041 return fw == tUint
1042 case reflect.Float32, reflect.Float64:
1043 return fw == tFloat
1044 case reflect.Complex64, reflect.Complex128:
1045 return fw == tComplex
1046 case reflect.String:
1047 return fw == tString
1048 case reflect.Interface:
1049 return fw == tInterface
1050 case reflect.Array:
1051 if !ok || wire.ArrayT == nil {
1052 return false
1053 }
1054 array := wire.ArrayT
1055 return t.Len() == array.Len && dec.compatibleType(t.Elem(), array.Elem, inProgress)
1056 case reflect.Map:
1057 if !ok || wire.MapT == nil {
1058 return false
1059 }
1060 MapType := wire.MapT
1061 return dec.compatibleType(t.Key(), MapType.Key, inProgress) && dec.compatibleType(t.Elem(), MapType.Elem, inProgress)
1062 case reflect.Slice:
1063
1064 if t.Elem().Kind() == reflect.Uint8 {
1065 return fw == tBytes
1066 }
1067
1068 var sw *sliceType
1069 if tt := builtinIdToType(fw); tt != nil {
1070 sw, _ = tt.(*sliceType)
1071 } else if wire != nil {
1072 sw = wire.SliceT
1073 }
1074 elem := userType(t.Elem()).base
1075 return sw != nil && dec.compatibleType(elem, sw.Elem, inProgress)
1076 case reflect.Struct:
1077 return true
1078 }
1079 }
1080
1081
1082 func (dec *Decoder) typeString(remoteId typeId) string {
1083 typeLock.Lock()
1084 defer typeLock.Unlock()
1085 if t := idToType(remoteId); t != nil {
1086
1087 return t.string()
1088 }
1089 return dec.wireType[remoteId].string()
1090 }
1091
1092
1093
1094 func (dec *Decoder) compileSingle(remoteId typeId, ut *userTypeInfo) (engine *decEngine, err error) {
1095 rt := ut.user
1096 engine = new(decEngine)
1097 engine.instr = make([]decInstr, 1)
1098 name := rt.String()
1099 if !dec.compatibleType(rt, remoteId, make(map[reflect.Type]typeId)) {
1100 remoteType := dec.typeString(remoteId)
1101
1102 if ut.base.Kind() == reflect.Interface && remoteId != tInterface {
1103 return nil, errors.New("gob: local interface type " + name + " can only be decoded from remote interface type; received concrete type " + remoteType)
1104 }
1105 return nil, errors.New("gob: decoding into local type " + name + ", received remote type " + remoteType)
1106 }
1107 op := dec.decOpFor(remoteId, rt, name, make(map[reflect.Type]*decOp))
1108 ovfl := errors.New(`value for "` + name + `" out of range`)
1109 engine.instr[singletonField] = decInstr{*op, singletonField, nil, ovfl}
1110 engine.numInstr = 1
1111 return
1112 }
1113
1114
1115 func (dec *Decoder) compileIgnoreSingle(remoteId typeId) *decEngine {
1116 engine := new(decEngine)
1117 engine.instr = make([]decInstr, 1)
1118 op := dec.decIgnoreOpFor(remoteId, make(map[typeId]*decOp), 0)
1119 ovfl := overflow(dec.typeString(remoteId))
1120 engine.instr[0] = decInstr{*op, 0, nil, ovfl}
1121 engine.numInstr = 1
1122 return engine
1123 }
1124
1125
1126
1127 func (dec *Decoder) compileDec(remoteId typeId, ut *userTypeInfo) (engine *decEngine, err error) {
1128 defer catchError(&err)
1129 rt := ut.base
1130 srt := rt
1131 if srt.Kind() != reflect.Struct || ut.externalDec != 0 {
1132 return dec.compileSingle(remoteId, ut)
1133 }
1134 var wireStruct *structType
1135
1136
1137 if t := builtinIdToType(remoteId); t != nil {
1138 wireStruct, _ = t.(*structType)
1139 } else {
1140 wire := dec.wireType[remoteId]
1141 if wire == nil {
1142 error_(errBadType)
1143 }
1144 wireStruct = wire.StructT
1145 }
1146 if wireStruct == nil {
1147 errorf("type mismatch in decoder: want struct type %s; got non-struct", rt)
1148 }
1149 engine = new(decEngine)
1150 engine.instr = make([]decInstr, len(wireStruct.Field))
1151 seen := make(map[reflect.Type]*decOp)
1152
1153 for fieldnum := 0; fieldnum < len(wireStruct.Field); fieldnum++ {
1154 wireField := wireStruct.Field[fieldnum]
1155 if wireField.Name == "" {
1156 errorf("empty name for remote field of type %s", wireStruct.Name)
1157 }
1158 ovfl := overflow(wireField.Name)
1159
1160 localField, present := srt.FieldByName(wireField.Name)
1161
1162 if !present || !isExported(wireField.Name) {
1163 op := dec.decIgnoreOpFor(wireField.Id, make(map[typeId]*decOp), 0)
1164 engine.instr[fieldnum] = decInstr{*op, fieldnum, nil, ovfl}
1165 continue
1166 }
1167 if !dec.compatibleType(localField.Type, wireField.Id, make(map[reflect.Type]typeId)) {
1168 errorf("wrong type (%s) for received field %s.%s", localField.Type, wireStruct.Name, wireField.Name)
1169 }
1170 op := dec.decOpFor(wireField.Id, localField.Type, localField.Name, seen)
1171 engine.instr[fieldnum] = decInstr{*op, fieldnum, localField.Index, ovfl}
1172 engine.numInstr++
1173 }
1174 return
1175 }
1176
1177
1178 func (dec *Decoder) getDecEnginePtr(remoteId typeId, ut *userTypeInfo) (enginePtr **decEngine, err error) {
1179 rt := ut.user
1180 decoderMap, ok := dec.decoderCache[rt]
1181 if !ok {
1182 decoderMap = make(map[typeId]**decEngine)
1183 dec.decoderCache[rt] = decoderMap
1184 }
1185 if enginePtr, ok = decoderMap[remoteId]; !ok {
1186
1187 enginePtr = new(*decEngine)
1188 decoderMap[remoteId] = enginePtr
1189 *enginePtr, err = dec.compileDec(remoteId, ut)
1190 if err != nil {
1191 delete(decoderMap, remoteId)
1192 }
1193 }
1194 return
1195 }
1196
1197
1198 type emptyStruct struct{}
1199
1200 var emptyStructType = reflect.TypeFor[emptyStruct]()
1201
1202
1203 func (dec *Decoder) getIgnoreEnginePtr(wireId typeId) (enginePtr **decEngine, err error) {
1204 var ok bool
1205 if enginePtr, ok = dec.ignorerCache[wireId]; !ok {
1206
1207 enginePtr = new(*decEngine)
1208 dec.ignorerCache[wireId] = enginePtr
1209 wire := dec.wireType[wireId]
1210 if wire != nil && wire.StructT != nil {
1211 *enginePtr, err = dec.compileDec(wireId, userType(emptyStructType))
1212 } else {
1213 *enginePtr = dec.compileIgnoreSingle(wireId)
1214 }
1215 if err != nil {
1216 delete(dec.ignorerCache, wireId)
1217 }
1218 }
1219 return
1220 }
1221
1222
1223 func (dec *Decoder) decodeValue(wireId typeId, value reflect.Value) {
1224 defer catchError(&dec.err)
1225
1226 if !value.IsValid() {
1227 dec.decodeIgnoredValue(wireId)
1228 return
1229 }
1230
1231 ut := userType(value.Type())
1232 base := ut.base
1233 var enginePtr **decEngine
1234 enginePtr, dec.err = dec.getDecEnginePtr(wireId, ut)
1235 if dec.err != nil {
1236 return
1237 }
1238 value = decAlloc(value)
1239 engine := *enginePtr
1240 if st := base; st.Kind() == reflect.Struct && ut.externalDec == 0 {
1241 wt := dec.wireType[wireId]
1242 if engine.numInstr == 0 && st.NumField() > 0 &&
1243 wt != nil && len(wt.StructT.Field) > 0 {
1244 name := base.Name()
1245 errorf("type mismatch: no fields matched compiling decoder for %s", name)
1246 }
1247 dec.decodeStruct(engine, value)
1248 } else {
1249 dec.decodeSingle(engine, value)
1250 }
1251 }
1252
1253
1254 func (dec *Decoder) decodeIgnoredValue(wireId typeId) {
1255 var enginePtr **decEngine
1256 enginePtr, dec.err = dec.getIgnoreEnginePtr(wireId)
1257 if dec.err != nil {
1258 return
1259 }
1260 wire := dec.wireType[wireId]
1261 if wire != nil && wire.StructT != nil {
1262 dec.ignoreStruct(*enginePtr)
1263 } else {
1264 dec.ignoreSingle(*enginePtr)
1265 }
1266 }
1267
1268 const (
1269 intBits = 32 << (^uint(0) >> 63)
1270 uintptrBits = 32 << (^uintptr(0) >> 63)
1271 )
1272
1273 func init() {
1274 var iop, uop decOp
1275 switch intBits {
1276 case 32:
1277 iop = decInt32
1278 uop = decUint32
1279 case 64:
1280 iop = decInt64
1281 uop = decUint64
1282 default:
1283 panic("gob: unknown size of int/uint")
1284 }
1285 decOpTable[reflect.Int] = iop
1286 decOpTable[reflect.Uint] = uop
1287
1288
1289 switch uintptrBits {
1290 case 32:
1291 uop = decUint32
1292 case 64:
1293 uop = decUint64
1294 default:
1295 panic("gob: unknown size of uintptr")
1296 }
1297 decOpTable[reflect.Uintptr] = uop
1298 }
1299
1300
1301
1302
1303
1304 func allocValue(t reflect.Type) reflect.Value {
1305 return reflect.New(t).Elem()
1306 }
1307
View as plain text