feature_any_array.go 4.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268
  1. package jsoniter
  2. import (
  3. "unsafe"
  4. )
  5. type arrayLazyAny struct {
  6. baseAny
  7. buf []byte
  8. iter *Iterator
  9. err error
  10. cache []Any
  11. remaining []byte
  12. }
  13. func (any *arrayLazyAny) parse() *Iterator {
  14. iter := any.iter
  15. if iter == nil {
  16. iter = NewIterator()
  17. any.iter = iter
  18. }
  19. iter.ResetBytes(any.remaining)
  20. return iter
  21. }
  22. func (any *arrayLazyAny) fillCacheUntil(target int) Any {
  23. if any.remaining == nil {
  24. if target >= len(any.cache) {
  25. return nil
  26. }
  27. return any.cache[target]
  28. }
  29. if any.cache == nil {
  30. any.cache = make([]Any, 0, 8)
  31. }
  32. i := len(any.cache)
  33. if target < i {
  34. return any.cache[target]
  35. }
  36. iter := any.parse()
  37. if (len(any.remaining) == len(any.buf)) {
  38. iter.head++
  39. c := iter.nextToken()
  40. if c != ']' {
  41. iter.unreadByte()
  42. element := iter.readAny(iter)
  43. any.cache = append(any.cache, element)
  44. if target == 0 {
  45. any.remaining = iter.buf[iter.head:]
  46. return element
  47. }
  48. i = 1
  49. } else {
  50. any.remaining = nil
  51. return nil
  52. }
  53. }
  54. for iter.nextToken() == ',' {
  55. element := iter.readAny(iter)
  56. any.cache = append(any.cache, element)
  57. if i == target {
  58. any.remaining = iter.buf[iter.head:]
  59. return element
  60. }
  61. i++
  62. }
  63. any.remaining = nil
  64. return nil
  65. }
  66. func (any *arrayLazyAny) fillCache() {
  67. if any.remaining == nil {
  68. return
  69. }
  70. if any.cache == nil {
  71. any.cache = make([]Any, 0, 8)
  72. }
  73. iter := any.parse()
  74. if len(any.remaining) == len(any.buf) {
  75. iter.head++
  76. c := iter.nextToken()
  77. if c != ']' {
  78. iter.unreadByte()
  79. any.cache = append(any.cache, iter.readAny(iter))
  80. } else {
  81. any.remaining = nil
  82. return
  83. }
  84. }
  85. for iter.nextToken() == ',' {
  86. any.cache = append(any.cache, iter.readAny(iter))
  87. }
  88. any.remaining = nil
  89. return
  90. }
  91. func (any *arrayLazyAny) LastError() error {
  92. return any.err
  93. }
  94. func (any *arrayLazyAny) ToBool() bool {
  95. if any.cache == nil {
  96. any.IterateArray() // trigger first element read
  97. }
  98. return len(any.cache) != 0
  99. }
  100. func (any *arrayLazyAny) ToInt() int {
  101. if any.cache == nil {
  102. any.IterateArray() // trigger first element read
  103. }
  104. if len(any.cache) == 0 {
  105. return 0
  106. }
  107. return 1
  108. }
  109. func (any *arrayLazyAny) ToInt32() int32 {
  110. if any.cache == nil {
  111. any.IterateArray() // trigger first element read
  112. }
  113. if len(any.cache) == 0 {
  114. return 0
  115. }
  116. return 1
  117. }
  118. func (any *arrayLazyAny) ToInt64() int64 {
  119. if any.cache == nil {
  120. any.IterateArray() // trigger first element read
  121. }
  122. if len(any.cache) == 0 {
  123. return 0
  124. }
  125. return 1
  126. }
  127. func (any *arrayLazyAny) ToFloat32() float32 {
  128. if any.cache == nil {
  129. any.IterateArray() // trigger first element read
  130. }
  131. if len(any.cache) == 0 {
  132. return 0
  133. }
  134. return 1
  135. }
  136. func (any *arrayLazyAny) ToFloat64() float64 {
  137. if any.cache == nil {
  138. any.IterateArray() // trigger first element read
  139. }
  140. if len(any.cache) == 0 {
  141. return 0
  142. }
  143. return 1
  144. }
  145. func (any *arrayLazyAny) ToString() string {
  146. if len(any.remaining) == len(any.buf) {
  147. // nothing has been parsed yet
  148. return *(*string)(unsafe.Pointer(&any.buf))
  149. } else {
  150. any.fillCache()
  151. str, err := MarshalToString(any.cache)
  152. any.err = err
  153. return str
  154. }
  155. }
  156. func (any *arrayLazyAny) Get(path ...interface{}) Any {
  157. if len(path) == 0 {
  158. return any
  159. }
  160. if len(path) == 1 {
  161. idx := path[0].(int)
  162. return any.fillCacheUntil(idx)
  163. } else {
  164. idx := path[0].(int)
  165. return any.fillCacheUntil(idx).Get(path[1:]...)
  166. }
  167. }
  168. func (any *arrayLazyAny) Size() int {
  169. any.fillCache()
  170. return len(any.cache)
  171. }
  172. func (any *arrayLazyAny) IterateArray() (func() (Any, bool), bool) {
  173. if any.cache == nil {
  174. any.cache = make([]Any, 0, 8)
  175. }
  176. remaining := any.remaining
  177. if len(remaining) == len(any.buf) {
  178. iter := any.parse()
  179. iter.head++
  180. c := iter.nextToken()
  181. if c != ']' {
  182. iter.unreadByte()
  183. v := iter.readAny(iter)
  184. any.cache = append(any.cache, v)
  185. remaining = iter.buf[iter.head:]
  186. any.remaining = remaining
  187. } else {
  188. remaining = nil
  189. any.remaining = nil
  190. return nil, false
  191. }
  192. }
  193. if len(any.cache) == 0 {
  194. return nil, false
  195. }
  196. arr := any.cache
  197. nextValue := arr[0]
  198. i := 1
  199. return func() (Any, bool) {
  200. value := nextValue
  201. if i < len(arr) {
  202. // read from cache
  203. nextValue = arr[i]
  204. i++
  205. return value, true
  206. } else {
  207. // read from buffer
  208. iter := any.iter
  209. if iter == nil {
  210. iter = NewIterator()
  211. any.iter = iter
  212. }
  213. iter.ResetBytes(remaining)
  214. c := iter.nextToken()
  215. if c == ',' {
  216. nextValue = iter.readAny(iter)
  217. any.cache = append(any.cache, nextValue)
  218. remaining = iter.buf[iter.head:]
  219. any.remaining = remaining
  220. return value, true
  221. } else {
  222. remaining = nil
  223. any.remaining = nil
  224. return value, false
  225. }
  226. }
  227. }, true
  228. }
  229. func (any *arrayLazyAny) GetArray() []Any {
  230. any.fillCache()
  231. return any.cache
  232. }
  233. func (any *arrayLazyAny) SetArray(newList []Any) bool {
  234. any.fillCache()
  235. any.cache = newList
  236. return true
  237. }
  238. func (any *arrayLazyAny) WriteTo(stream *Stream) {
  239. if len(any.remaining) == len(any.buf) {
  240. // nothing has been parsed yet
  241. stream.Write(any.buf)
  242. } else {
  243. any.fillCache()
  244. stream.WriteVal(any.cache)
  245. }
  246. }