|
|
@ -74,6 +74,8 @@ func typeEncoder(t reflect.Type) encodeFn {
|
|
|
|
return encodeFloat32
|
|
|
|
return encodeFloat32
|
|
|
|
case reflect.Float64:
|
|
|
|
case reflect.Float64:
|
|
|
|
return encodeFloat64
|
|
|
|
return encodeFloat64
|
|
|
|
|
|
|
|
case reflect.Complex128:
|
|
|
|
|
|
|
|
return encodeComplex128
|
|
|
|
case reflect.String:
|
|
|
|
case reflect.String:
|
|
|
|
return encodeString
|
|
|
|
return encodeString
|
|
|
|
case reflect.Struct:
|
|
|
|
case reflect.Struct:
|
|
|
@ -222,3 +224,9 @@ func marshalerEncoder(e *encoder, v reflect.Value) {
|
|
|
|
}
|
|
|
|
}
|
|
|
|
e.Write(b)
|
|
|
|
e.Write(b)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
func encodeComplex128(e *encoder, v reflect.Value) {
|
|
|
|
|
|
|
|
c := v.Complex()
|
|
|
|
|
|
|
|
r, i := real(c), imag(c)
|
|
|
|
|
|
|
|
fmt.Fprintf(e, "%v+%vi", r, i)
|
|
|
|
|
|
|
|
}
|
|
|
|