From: Rob Pike Date: Fri, 2 Dec 2011 08:02:24 +0000 (-0800) Subject: encoding/gob: don't send type info for unexported fields X-Git-Tag: weekly.2011-12-06~48 X-Git-Url: http://www.git.cypherpunks.su/?a=commitdiff_plain;h=30775f67e7d5e897d4d9aafe8ab84a5f65550ce4;p=gostls13.git encoding/gob: don't send type info for unexported fields Fixes #2517. R=golang-dev, dsymonds CC=golang-dev https://golang.org/cl/5440079 --- diff --git a/src/pkg/encoding/gob/encoder.go b/src/pkg/encoding/gob/encoder.go index e4a48dfc4f..a15b5a1f9a 100644 --- a/src/pkg/encoding/gob/encoder.go +++ b/src/pkg/encoding/gob/encoder.go @@ -119,7 +119,9 @@ func (enc *Encoder) sendActualType(w io.Writer, state *encoderState, ut *userTyp switch st := actual; st.Kind() { case reflect.Struct: for i := 0; i < st.NumField(); i++ { - enc.sendType(w, state, st.Field(i).Type) + if isExported(st.Field(i).Name) { + enc.sendType(w, state, st.Field(i).Type) + } } case reflect.Array, reflect.Slice: enc.sendType(w, state, st.Elem()) diff --git a/src/pkg/encoding/gob/encoder_test.go b/src/pkg/encoding/gob/encoder_test.go index bc5af120af..5bc957bb37 100644 --- a/src/pkg/encoding/gob/encoder_test.go +++ b/src/pkg/encoding/gob/encoder_test.go @@ -662,3 +662,19 @@ func TestSequentialDecoder(t *testing.T) { } } } + +// Should be able to have unrepresentable fields (chan, func) as long as they +// are unexported. +type Bug2 struct { + A int + b chan int +} + +func TestUnexportedChan(t *testing.T) { + b := Bug2{23, make(chan int)} + var stream bytes.Buffer + enc := NewEncoder(&stream) + if err := enc.Encode(b); err != nil { + t.Fatalf("error encoding unexported channel: %s", err) + } +}