reflect_extension.go 13 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447
  1. package jsoniter
  2. import (
  3. "fmt"
  4. "reflect"
  5. "sort"
  6. "strings"
  7. "unicode"
  8. "unsafe"
  9. )
  10. var typeDecoders = map[string]ValDecoder{}
  11. var fieldDecoders = map[string]ValDecoder{}
  12. var typeEncoders = map[string]ValEncoder{}
  13. var fieldEncoders = map[string]ValEncoder{}
  14. var extensions = []Extension{}
  15. // StructDescriptor describe how should we encode/decode the struct
  16. type StructDescriptor struct {
  17. Type reflect.Type
  18. Fields []*Binding
  19. }
  20. // GetField get one field from the descriptor by its name.
  21. // Can not use map here to keep field orders.
  22. func (structDescriptor *StructDescriptor) GetField(fieldName string) *Binding {
  23. for _, binding := range structDescriptor.Fields {
  24. if binding.Field.Name == fieldName {
  25. return binding
  26. }
  27. }
  28. return nil
  29. }
  30. // Binding describe how should we encode/decode the struct field
  31. type Binding struct {
  32. levels []int
  33. Field *reflect.StructField
  34. FromNames []string
  35. ToNames []string
  36. Encoder ValEncoder
  37. Decoder ValDecoder
  38. }
  39. // Extension the one for all SPI. Customize encoding/decoding by specifying alternate encoder/decoder.
  40. // Can also rename fields by UpdateStructDescriptor.
  41. type Extension interface {
  42. UpdateStructDescriptor(structDescriptor *StructDescriptor)
  43. CreateDecoder(typ reflect.Type) ValDecoder
  44. CreateEncoder(typ reflect.Type) ValEncoder
  45. DecorateDecoder(typ reflect.Type, decoder ValDecoder) ValDecoder
  46. DecorateEncoder(typ reflect.Type, encoder ValEncoder) ValEncoder
  47. }
  48. // DummyExtension embed this type get dummy implementation for all methods of Extension
  49. type DummyExtension struct {
  50. }
  51. // UpdateStructDescriptor No-op
  52. func (extension *DummyExtension) UpdateStructDescriptor(structDescriptor *StructDescriptor) {
  53. }
  54. // CreateDecoder No-op
  55. func (extension *DummyExtension) CreateDecoder(typ reflect.Type) ValDecoder {
  56. return nil
  57. }
  58. // CreateEncoder No-op
  59. func (extension *DummyExtension) CreateEncoder(typ reflect.Type) ValEncoder {
  60. return nil
  61. }
  62. // DecorateDecoder No-op
  63. func (extension *DummyExtension) DecorateDecoder(typ reflect.Type, decoder ValDecoder) ValDecoder {
  64. return decoder
  65. }
  66. // DecorateEncoder No-op
  67. func (extension *DummyExtension) DecorateEncoder(typ reflect.Type, encoder ValEncoder) ValEncoder {
  68. return encoder
  69. }
  70. type EncoderExtension map[reflect.Type]ValEncoder
  71. // UpdateStructDescriptor No-op
  72. func (extension EncoderExtension) UpdateStructDescriptor(structDescriptor *StructDescriptor) {
  73. }
  74. // CreateDecoder No-op
  75. func (extension EncoderExtension) CreateDecoder(typ reflect.Type) ValDecoder {
  76. return nil
  77. }
  78. // CreateEncoder get encoder from map
  79. func (extension EncoderExtension) CreateEncoder(typ reflect.Type) ValEncoder {
  80. return extension[typ]
  81. }
  82. // DecorateDecoder No-op
  83. func (extension EncoderExtension) DecorateDecoder(typ reflect.Type, decoder ValDecoder) ValDecoder {
  84. return decoder
  85. }
  86. // DecorateEncoder No-op
  87. func (extension EncoderExtension) DecorateEncoder(typ reflect.Type, encoder ValEncoder) ValEncoder {
  88. return encoder
  89. }
  90. type DecoderExtension map[reflect.Type]ValDecoder
  91. // UpdateStructDescriptor No-op
  92. func (extension DecoderExtension) UpdateStructDescriptor(structDescriptor *StructDescriptor) {
  93. }
  94. // CreateDecoder get decoder from map
  95. func (extension DecoderExtension) CreateDecoder(typ reflect.Type) ValDecoder {
  96. return extension[typ]
  97. }
  98. // CreateEncoder No-op
  99. func (extension DecoderExtension) CreateEncoder(typ reflect.Type) ValEncoder {
  100. return nil
  101. }
  102. // DecorateDecoder No-op
  103. func (extension DecoderExtension) DecorateDecoder(typ reflect.Type, decoder ValDecoder) ValDecoder {
  104. return decoder
  105. }
  106. // DecorateEncoder No-op
  107. func (extension DecoderExtension) DecorateEncoder(typ reflect.Type, encoder ValEncoder) ValEncoder {
  108. return encoder
  109. }
  110. type funcDecoder struct {
  111. fun DecoderFunc
  112. }
  113. func (decoder *funcDecoder) Decode(ptr unsafe.Pointer, iter *Iterator) {
  114. decoder.fun(ptr, iter)
  115. }
  116. type funcEncoder struct {
  117. fun EncoderFunc
  118. isEmptyFunc func(ptr unsafe.Pointer) bool
  119. }
  120. func (encoder *funcEncoder) Encode(ptr unsafe.Pointer, stream *Stream) {
  121. encoder.fun(ptr, stream)
  122. }
  123. func (encoder *funcEncoder) IsEmpty(ptr unsafe.Pointer) bool {
  124. if encoder.isEmptyFunc == nil {
  125. return false
  126. }
  127. return encoder.isEmptyFunc(ptr)
  128. }
  129. // DecoderFunc the function form of TypeDecoder
  130. type DecoderFunc func(ptr unsafe.Pointer, iter *Iterator)
  131. // EncoderFunc the function form of TypeEncoder
  132. type EncoderFunc func(ptr unsafe.Pointer, stream *Stream)
  133. // RegisterTypeDecoderFunc register TypeDecoder for a type with function
  134. func RegisterTypeDecoderFunc(typ string, fun DecoderFunc) {
  135. typeDecoders[typ] = &funcDecoder{fun}
  136. }
  137. // RegisterTypeDecoder register TypeDecoder for a typ
  138. func RegisterTypeDecoder(typ string, decoder ValDecoder) {
  139. typeDecoders[typ] = decoder
  140. }
  141. // RegisterFieldDecoderFunc register TypeDecoder for a struct field with function
  142. func RegisterFieldDecoderFunc(typ string, field string, fun DecoderFunc) {
  143. RegisterFieldDecoder(typ, field, &funcDecoder{fun})
  144. }
  145. // RegisterFieldDecoder register TypeDecoder for a struct field
  146. func RegisterFieldDecoder(typ string, field string, decoder ValDecoder) {
  147. fieldDecoders[fmt.Sprintf("%s/%s", typ, field)] = decoder
  148. }
  149. // RegisterTypeEncoderFunc register TypeEncoder for a type with encode/isEmpty function
  150. func RegisterTypeEncoderFunc(typ string, fun EncoderFunc, isEmptyFunc func(unsafe.Pointer) bool) {
  151. typeEncoders[typ] = &funcEncoder{fun, isEmptyFunc}
  152. }
  153. // RegisterTypeEncoder register TypeEncoder for a type
  154. func RegisterTypeEncoder(typ string, encoder ValEncoder) {
  155. typeEncoders[typ] = encoder
  156. }
  157. // RegisterFieldEncoderFunc register TypeEncoder for a struct field with encode/isEmpty function
  158. func RegisterFieldEncoderFunc(typ string, field string, fun EncoderFunc, isEmptyFunc func(unsafe.Pointer) bool) {
  159. RegisterFieldEncoder(typ, field, &funcEncoder{fun, isEmptyFunc})
  160. }
  161. // RegisterFieldEncoder register TypeEncoder for a struct field
  162. func RegisterFieldEncoder(typ string, field string, encoder ValEncoder) {
  163. fieldEncoders[fmt.Sprintf("%s/%s", typ, field)] = encoder
  164. }
  165. // RegisterExtension register extension
  166. func RegisterExtension(extension Extension) {
  167. extensions = append(extensions, extension)
  168. }
  169. func getTypeDecoderFromExtension(cfg *frozenConfig, typ reflect.Type) ValDecoder {
  170. decoder := _getTypeDecoderFromExtension(cfg, typ)
  171. if decoder != nil {
  172. for _, extension := range extensions {
  173. decoder = extension.DecorateDecoder(typ, decoder)
  174. }
  175. for _, extension := range cfg.extensions {
  176. decoder = extension.DecorateDecoder(typ, decoder)
  177. }
  178. }
  179. return decoder
  180. }
  181. func _getTypeDecoderFromExtension(cfg *frozenConfig, typ reflect.Type) ValDecoder {
  182. for _, extension := range extensions {
  183. decoder := extension.CreateDecoder(typ)
  184. if decoder != nil {
  185. return decoder
  186. }
  187. }
  188. for _, extension := range cfg.extensions {
  189. decoder := extension.CreateDecoder(typ)
  190. if decoder != nil {
  191. return decoder
  192. }
  193. }
  194. typeName := typ.String()
  195. decoder := typeDecoders[typeName]
  196. if decoder != nil {
  197. return decoder
  198. }
  199. if typ.Kind() == reflect.Ptr {
  200. decoder := typeDecoders[typ.Elem().String()]
  201. if decoder != nil {
  202. return &OptionalDecoder{typ.Elem(), decoder}
  203. }
  204. }
  205. return nil
  206. }
  207. func getTypeEncoderFromExtension(cfg *frozenConfig, typ reflect.Type) ValEncoder {
  208. encoder := _getTypeEncoderFromExtension(cfg, typ)
  209. if encoder != nil {
  210. for _, extension := range extensions {
  211. encoder = extension.DecorateEncoder(typ, encoder)
  212. }
  213. for _, extension := range cfg.extensions {
  214. encoder = extension.DecorateEncoder(typ, encoder)
  215. }
  216. }
  217. return encoder
  218. }
  219. func _getTypeEncoderFromExtension(cfg *frozenConfig, typ reflect.Type) ValEncoder {
  220. for _, extension := range extensions {
  221. encoder := extension.CreateEncoder(typ)
  222. if encoder != nil {
  223. return encoder
  224. }
  225. }
  226. for _, extension := range cfg.extensions {
  227. encoder := extension.CreateEncoder(typ)
  228. if encoder != nil {
  229. return encoder
  230. }
  231. }
  232. typeName := typ.String()
  233. encoder := typeEncoders[typeName]
  234. if encoder != nil {
  235. return encoder
  236. }
  237. if typ.Kind() == reflect.Ptr {
  238. encoder := typeEncoders[typ.Elem().String()]
  239. if encoder != nil {
  240. return &OptionalEncoder{encoder}
  241. }
  242. }
  243. return nil
  244. }
  245. func describeStruct(cfg *frozenConfig, prefix string, typ reflect.Type) *StructDescriptor {
  246. embeddedBindings := []*Binding{}
  247. bindings := []*Binding{}
  248. for i := 0; i < typ.NumField(); i++ {
  249. field := typ.Field(i)
  250. tag, hastag := field.Tag.Lookup(cfg.getTagKey())
  251. if cfg.onlyTaggedField && !hastag {
  252. continue
  253. }
  254. tagParts := strings.Split(tag, ",")
  255. if tag == "-" {
  256. continue
  257. }
  258. if field.Anonymous && (tag == "" || tagParts[0] == "") {
  259. if field.Type.Kind() == reflect.Struct {
  260. structDescriptor := describeStruct(cfg, prefix, field.Type)
  261. for _, binding := range structDescriptor.Fields {
  262. binding.levels = append([]int{i}, binding.levels...)
  263. omitempty := binding.Encoder.(*structFieldEncoder).omitempty
  264. binding.Encoder = &structFieldEncoder{&field, binding.Encoder, omitempty}
  265. binding.Decoder = &structFieldDecoder{&field, binding.Decoder}
  266. embeddedBindings = append(embeddedBindings, binding)
  267. }
  268. continue
  269. } else if field.Type.Kind() == reflect.Ptr && field.Type.Elem().Kind() == reflect.Struct {
  270. structDescriptor := describeStruct(cfg, prefix, field.Type.Elem())
  271. for _, binding := range structDescriptor.Fields {
  272. binding.levels = append([]int{i}, binding.levels...)
  273. omitempty := binding.Encoder.(*structFieldEncoder).omitempty
  274. binding.Encoder = &dereferenceEncoder{binding.Encoder}
  275. binding.Encoder = &structFieldEncoder{&field, binding.Encoder, omitempty}
  276. binding.Decoder = &dereferenceDecoder{field.Type.Elem(), binding.Decoder}
  277. binding.Decoder = &structFieldDecoder{&field, binding.Decoder}
  278. embeddedBindings = append(embeddedBindings, binding)
  279. }
  280. continue
  281. }
  282. }
  283. fieldNames := calcFieldNames(field.Name, tagParts[0], tag)
  284. fieldCacheKey := fmt.Sprintf("%s/%s", typ.String(), field.Name)
  285. decoder := fieldDecoders[fieldCacheKey]
  286. if decoder == nil {
  287. decoder = decoderOfType(cfg, prefix+typ.String()+"."+field.Name+"->", field.Type)
  288. }
  289. encoder := fieldEncoders[fieldCacheKey]
  290. if encoder == nil {
  291. encoder = encoderOfType(cfg, prefix+typ.String()+"."+field.Name+"->", field.Type)
  292. }
  293. binding := &Binding{
  294. Field: &field,
  295. FromNames: fieldNames,
  296. ToNames: fieldNames,
  297. Decoder: decoder,
  298. Encoder: encoder,
  299. }
  300. binding.levels = []int{i}
  301. bindings = append(bindings, binding)
  302. }
  303. return createStructDescriptor(cfg, typ, bindings, embeddedBindings)
  304. }
  305. func createStructDescriptor(cfg *frozenConfig, typ reflect.Type, bindings []*Binding, embeddedBindings []*Binding) *StructDescriptor {
  306. structDescriptor := &StructDescriptor{
  307. Type: typ,
  308. Fields: bindings,
  309. }
  310. for _, extension := range extensions {
  311. extension.UpdateStructDescriptor(structDescriptor)
  312. }
  313. for _, extension := range cfg.extensions {
  314. extension.UpdateStructDescriptor(structDescriptor)
  315. }
  316. processTags(structDescriptor, cfg)
  317. // merge normal & embedded bindings & sort with original order
  318. allBindings := sortableBindings(append(embeddedBindings, structDescriptor.Fields...))
  319. sort.Sort(allBindings)
  320. structDescriptor.Fields = allBindings
  321. return structDescriptor
  322. }
  323. func isStructOnePtr(typ reflect.Type) bool {
  324. if typ.NumField() == 1 {
  325. firstField := typ.Field(0)
  326. switch firstField.Type.Kind() {
  327. case reflect.Ptr:
  328. return true
  329. case reflect.Map:
  330. return true
  331. case reflect.Struct:
  332. return isStructOnePtr(firstField.Type)
  333. }
  334. }
  335. return false
  336. }
  337. type sortableBindings []*Binding
  338. func (bindings sortableBindings) Len() int {
  339. return len(bindings)
  340. }
  341. func (bindings sortableBindings) Less(i, j int) bool {
  342. left := bindings[i].levels
  343. right := bindings[j].levels
  344. k := 0
  345. for {
  346. if left[k] < right[k] {
  347. return true
  348. } else if left[k] > right[k] {
  349. return false
  350. }
  351. k++
  352. }
  353. }
  354. func (bindings sortableBindings) Swap(i, j int) {
  355. bindings[i], bindings[j] = bindings[j], bindings[i]
  356. }
  357. func processTags(structDescriptor *StructDescriptor, cfg *frozenConfig) {
  358. for _, binding := range structDescriptor.Fields {
  359. shouldOmitEmpty := false
  360. tagParts := strings.Split(binding.Field.Tag.Get(cfg.getTagKey()), ",")
  361. for _, tagPart := range tagParts[1:] {
  362. if tagPart == "omitempty" {
  363. shouldOmitEmpty = true
  364. } else if tagPart == "string" {
  365. if binding.Field.Type.Kind() == reflect.String {
  366. binding.Decoder = &stringModeStringDecoder{binding.Decoder, cfg}
  367. binding.Encoder = &stringModeStringEncoder{binding.Encoder, cfg}
  368. } else {
  369. binding.Decoder = &stringModeNumberDecoder{binding.Decoder}
  370. binding.Encoder = &stringModeNumberEncoder{binding.Encoder}
  371. }
  372. }
  373. }
  374. binding.Decoder = &structFieldDecoder{binding.Field, binding.Decoder}
  375. binding.Encoder = &structFieldEncoder{binding.Field, binding.Encoder, shouldOmitEmpty}
  376. }
  377. }
  378. func calcFieldNames(originalFieldName string, tagProvidedFieldName string, wholeTag string) []string {
  379. // ignore?
  380. if wholeTag == "-" {
  381. return []string{}
  382. }
  383. // rename?
  384. var fieldNames []string
  385. if tagProvidedFieldName == "" {
  386. fieldNames = []string{originalFieldName}
  387. } else {
  388. fieldNames = []string{tagProvidedFieldName}
  389. }
  390. // private?
  391. isNotExported := unicode.IsLower(rune(originalFieldName[0]))
  392. if isNotExported {
  393. fieldNames = []string{}
  394. }
  395. return fieldNames
  396. }