in java_sql_time.go [50:108]
func (JavaSqlTimeSerializer) EncObject(e *Encoder, vv POJO) error {
var (
idx int
err error
clsDef *ClassInfo
className string
ptrV reflect.Value
)
// ensure ptrV is pointer to know vv is type JavaSqlTime or not
ptrV = reflect.ValueOf(vv)
if reflect.TypeOf(vv).Kind() != reflect.Ptr {
ptrV = PackPtr(ptrV)
}
v, ok := ptrV.Interface().(java_sql_time.JavaSqlTime)
if !ok {
return perrors.New("can not be converted into java sql time object")
}
className = v.JavaClassName()
if className == "" {
return perrors.New("class name empty")
}
tValue := reflect.ValueOf(vv)
// check ref
if n, ok := e.checkRefMap(tValue); ok {
e.buffer = encRef(e.buffer, n)
return nil
}
// write object definition
idx = e.classIndex(v.JavaClassName())
if idx == -1 {
idx, ok = checkPOJORegistry(vv)
if !ok {
idx = RegisterPOJO(v)
}
_, clsDef, err = getStructDefByIndex(idx)
if err != nil {
return perrors.WithStack(err)
}
idx = len(e.classInfoList)
e.classInfoList = append(e.classInfoList, clsDef)
e.buffer = append(e.buffer, clsDef.buffer...)
}
e.buffer = e.buffer[0 : len(e.buffer)-1]
e.buffer = encInt32(e.buffer, 1)
e.buffer = encString(e.buffer, "value")
// write object instance
if byte(idx) <= OBJECT_DIRECT_MAX {
e.buffer = encByte(e.buffer, byte(idx)+BC_OBJECT_DIRECT)
} else {
e.buffer = encByte(e.buffer, BC_OBJECT)
e.buffer = encInt32(e.buffer, int32(idx))
}
e.buffer = encDateInMs(e.buffer, v.GetTime())
return nil
}