// Decode reads the next value from the connection and stores
// it in the data represented by the empty interface value.
// 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 {
- // If e represents a value, the answer won't get back to the
- // caller. Make sure it's a pointer.
- if _, ok := reflect.Typeof(e).(*reflect.PtrType); !ok {
+ value := reflect.NewValue(e)
+ // If e represents a value as opposed to a pointer, the answer won't
+ // 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")
return dec.state.err
}
- return dec.DecodeValue(reflect.NewValue(e))
+ return dec.DecodeValue(value)
}
// DecodeValue reads the next value from the connection and stores
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
- values or addresses that can be dereferenced to values. (At the moment, these
- items must be structs (struct, *struct, **struct etc.), but this may change.) The
- Encoder makes sure all type information is sent before it is needed. At the
- receive side, a Decoder retrieves values from the encoded stream and unpacks them
- into local variables.
+ values or addresses that can be dereferenced to values. The Encoder makes sure
+ all type information is sent before it is needed. At the receive side, a
+ Decoder retrieves values from the encoded stream and unpacks them into local
+ variables.
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
output will be just:
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 (
if err != nil {
return err
}
- if _, ok := value.(*reflect.StructValue); ok {
+ if value.Type().Kind() == reflect.Struct {
return encodeStruct(engine, b, value.Addr())
}
return encodeSingle(engine, b, value.Addr())
// The reflection type must have all its indirections processed out.
// typeLock must be held.
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())
}
info, ok := typeInfoMap[rt]