/
encode_ref_4v2.go
101 lines (85 loc) · 2.71 KB
/
encode_ref_4v2.go
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
// nolint
// Copyright 20xx The Alipay Authors.
//
// @authors[0]: bingwu.ybw(bingwu.ybw@antfin.com|detailyang@gmail.com)
// @authors[1]: robotx(robotx@antfin.com)
//
// *Legal Disclaimer*
// Within this source code, the comments in Chinese shall be the original, governing version. Any comment in other languages are for reference only. In the event of any conflict between the Chinese language version comments and other language version comments, the Chinese language version shall prevail.
// *法律免责声明*
// 关于代码注释部分,中文注释为官方版本,其它语言注释仅做参考。中文注释可能与其它语言注释存在不一致,当中文注释与其它语言注释存在不一致时,请以中文注释为准。
//
//
package sofahessian
// EncodeRef4V2 encodes refid to dst.
//
// ref ::= x51 int
func EncodeRef4V2(o *EncodeContext, dst []byte, refid uint32) ([]byte, error) {
if o.tracer != nil {
o.tracer.OnTraceStart("encoderef")
defer o.tracer.OnTraceStop("encoderef")
}
dst = append(dst, "Q"...)
return EncodeInt32ToHessian4V2(o, dst, int32(refid))
}
func encodeObjectrefToHessian4V2(o *EncodeContext, dst []byte, obj interface{}) ([]byte, int, error) {
if o.tracer != nil {
o.tracer.OnTraceStart("encodeoobjectref")
defer o.tracer.OnTraceStop("encodeoobjectref")
}
if o.disableObjectrefs {
return dst, -1, nil
}
ref, err := o.getObjectrefs(obj)
if err != nil {
return dst, -1, err
}
if ref >= 0 {
dst, err = EncodeRef4V2(o, dst, uint32(ref))
return dst, ref, err
}
_, err = o.addObjectrefs(obj)
return dst, -1, err
}
func encodeClassrefToHessian4V2(o *EncodeContext, dst []byte, obj interface{}) ([]byte, error) {
if o.tracer != nil {
o.tracer.OnTraceStart("encodeoclassref")
defer o.tracer.OnTraceStop("encodeoclassref")
}
ref, err := o.getClassrefs(obj)
if err != nil {
return dst, err
}
if ref >= 0 {
return EncodeRef4V2(o, dst, uint32(ref))
}
_, _, err = o.addClassrefs(obj)
return dst, err
}
// encodeTyperefToHessian4V2 encodes type to dst.
// type ::= string
// ::= int
// Figure 30
// A map or list includes a type attribute indicating the type name of the map or list for object-oriented languages.
//
// Each type is added to the type map for future reference.
func encodeTyperefToHessian4V2(o *EncodeContext, dst []byte, typ string) ([]byte, error) {
if o.tracer != nil {
o.tracer.OnTraceStart("encodetyperef")
defer o.tracer.OnTraceStop("encodetyperef")
}
if typ == "" {
return dst, nil
}
v, ok, err := o.getTyperefs(typ)
if err != nil {
return dst, err
}
if !ok {
if err = o.addTyperefs(typ); err != nil {
return dst, err
}
return EncodeStringToHessian4V2(o, dst, typ)
}
return EncodeInt32ToHessian4V2(o, dst, int32(v))
}