diff --git a/ua/encode.go b/ua/encode.go index e02d1db2..2d6462f1 100644 --- a/ua/encode.go +++ b/ua/encode.go @@ -5,6 +5,7 @@ package ua import ( + "encoding/hex" "fmt" "math" "reflect" @@ -43,7 +44,7 @@ func encode(val reflect.Value, name string) ([]byte, error) { switch { case isBinaryEncoder(val): v := val.Interface().(BinaryEncoder) - return v.Encode() + return dump(v.Encode()) case isTime(val): buf.WriteTime(val.Convert(timeType).Interface().(time.Time)) @@ -78,18 +79,25 @@ func encode(val reflect.Value, name string) ([]byte, error) { if val.IsNil() { return nil, nil } - return encode(val.Elem(), name) + return dump(encode(val.Elem(), name)) case reflect.Struct: - return writeStruct(val, name) + return dump(writeStruct(val, name)) case reflect.Slice: - return writeSlice(val, name) + return dump(writeSlice(val, name)) case reflect.Array: - return writeArray(val, name) + return dump(writeArray(val, name)) default: return nil, errors.Errorf("unsupported type: %s", val.Type()) } } - return buf.Bytes(), buf.Error() + return dump(buf.Bytes(), buf.Error()) +} + +func dump(b []byte, err error) ([]byte, error) { + if debugCodec { + fmt.Printf("%s---\n", hex.Dump(b)) + } + return b, err } func writeStruct(val reflect.Value, name string) ([]byte, error) {