Commit da69685e authored by Rob Pike's avatar Rob Pike

gob: a couple of tiny simplifications using Kind()

R=rsc
CC=golang-dev
https://golang.org/cl/1695046
parent 059c7ba9
...@@ -55,15 +55,16 @@ func (dec *Decoder) recvType(id typeId) { ...@@ -55,15 +55,16 @@ func (dec *Decoder) recvType(id typeId) {
// Decode reads the next value from the connection and stores // Decode reads the next value from the connection and stores
// it in the data represented by the empty interface value. // it in the data represented by the empty interface value.
// The value underlying e must be the correct type for the next // The value underlying e must be the correct type for the next
// data item received, which must be a pointer. // data item received, and must be a pointer.
func (dec *Decoder) Decode(e interface{}) os.Error { func (dec *Decoder) Decode(e interface{}) os.Error {
// If e represents a value, the answer won't get back to the value := reflect.NewValue(e)
// caller. Make sure it's a pointer. // If e represents a value as opposed to a pointer, the answer won't
if _, ok := reflect.Typeof(e).(*reflect.PtrType); !ok { // get back to the caller. Make sure it's a pointer.
if value.Type().Kind() != reflect.Ptr {
dec.state.err = os.ErrorString("gob: attempt to decode into a non-pointer") dec.state.err = os.ErrorString("gob: attempt to decode into a non-pointer")
return dec.state.err return dec.state.err
} }
return dec.DecodeValue(reflect.NewValue(e)) return dec.DecodeValue(value)
} }
// DecodeValue reads the next value from the connection and stores // DecodeValue reads the next value from the connection and stores
......
...@@ -15,11 +15,10 @@ ...@@ -15,11 +15,10 @@
recursive values (data with cycles) are problematic. This may change. recursive values (data with cycles) are problematic. This may change.
To use gobs, create an Encoder and present it with a series of data items as To use gobs, create an Encoder and present it with a series of data items as
values or addresses that can be dereferenced to values. (At the moment, these values or addresses that can be dereferenced to values. The Encoder makes sure
items must be structs (struct, *struct, **struct etc.), but this may change.) The all type information is sent before it is needed. At the receive side, a
Encoder makes sure all type information is sent before it is needed. At the Decoder retrieves values from the encoded stream and unpacks them into local
receive side, a Decoder retrieves values from the encoded stream and unpacks them variables.
into local variables.
The source and destination values/types need not correspond exactly. For structs, The source and destination values/types need not correspond exactly. For structs,
fields (identified by name) that are in the source but absent from the receiving fields (identified by name) that are in the source but absent from the receiving
...@@ -251,6 +250,20 @@ package gob ...@@ -251,6 +250,20 @@ package gob
output will be just: output will be just:
07 ff 82 01 2c 01 42 00 07 ff 82 01 2c 01 42 00
A single non-struct value at top level is transmitted like a field with
delta tag 0. For instance, a signed integer with value 3 presented as
the argument to Encode will emit:
03 04 00 06
Which represents:
03 // this value is 3 bytes long
04 // the type number, 2, represents an integer
00 // tag delta 0
06 // value 3
*/ */
import ( import (
...@@ -810,7 +823,7 @@ func encode(b *bytes.Buffer, value reflect.Value) os.Error { ...@@ -810,7 +823,7 @@ func encode(b *bytes.Buffer, value reflect.Value) os.Error {
if err != nil { if err != nil {
return err return err
} }
if _, ok := value.(*reflect.StructValue); ok { if value.Type().Kind() == reflect.Struct {
return encodeStruct(engine, b, value.Addr()) return encodeStruct(engine, b, value.Addr())
} }
return encodeSingle(engine, b, value.Addr()) return encodeSingle(engine, b, value.Addr())
......
...@@ -395,7 +395,7 @@ var typeInfoMap = make(map[reflect.Type]*typeInfo) // protected by typeLock ...@@ -395,7 +395,7 @@ var typeInfoMap = make(map[reflect.Type]*typeInfo) // protected by typeLock
// The reflection type must have all its indirections processed out. // The reflection type must have all its indirections processed out.
// typeLock must be held. // typeLock must be held.
func getTypeInfo(rt reflect.Type) (*typeInfo, os.Error) { func getTypeInfo(rt reflect.Type) (*typeInfo, os.Error) {
if _, ok := rt.(*reflect.PtrType); ok { if rt.Kind() == reflect.Ptr {
panic("pointer type in getTypeInfo: " + rt.String()) panic("pointer type in getTypeInfo: " + rt.String())
} }
info, ok := typeInfoMap[rt] info, ok := typeInfoMap[rt]
......
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