func()

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
}