json-as 1.3.0 → 1.3.2

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (295) hide show
  1. package/CHANGELOG.md +400 -0
  2. package/README.md +137 -32
  3. package/assembly/deserialize/index/arbitrary.ts +1 -1
  4. package/assembly/deserialize/index/array.ts +6 -1
  5. package/assembly/deserialize/index/float.ts +1 -1
  6. package/assembly/deserialize/index/integer.ts +1 -1
  7. package/assembly/deserialize/index/typedarray.ts +14 -0
  8. package/assembly/deserialize/index/unsigned.ts +1 -1
  9. package/assembly/deserialize/simd/string.ts +20 -16
  10. package/assembly/deserialize/simple/arbitrary.ts +1 -1
  11. package/assembly/deserialize/simple/array/generic.ts +42 -0
  12. package/assembly/deserialize/simple/array.ts +8 -1
  13. package/assembly/deserialize/{float.ts → simple/float.ts} +22 -2
  14. package/assembly/deserialize/{integer.ts → simple/integer.ts} +3 -2
  15. package/assembly/deserialize/simple/map.ts +60 -12
  16. package/assembly/deserialize/simple/object.ts +1 -1
  17. package/assembly/deserialize/simple/set.ts +119 -134
  18. package/assembly/deserialize/simple/staticarray.ts +12 -1
  19. package/assembly/deserialize/simple/string.ts +93 -2
  20. package/assembly/deserialize/simple/struct.ts +7 -157
  21. package/assembly/deserialize/simple/typedarray.ts +1 -1
  22. package/assembly/deserialize/{unsigned.ts → simple/unsigned.ts} +3 -2
  23. package/assembly/deserialize/swar/array/array.ts +42 -7
  24. package/assembly/deserialize/swar/array/bool.ts +5 -2
  25. package/assembly/deserialize/swar/array/float.ts +7 -3
  26. package/assembly/deserialize/swar/array/generic.ts +40 -0
  27. package/assembly/deserialize/swar/array/integer.ts +7 -4
  28. package/assembly/deserialize/swar/array/object.ts +20 -4
  29. package/assembly/deserialize/swar/array/shared.ts +18 -4
  30. package/assembly/deserialize/swar/array/string.ts +5 -2
  31. package/assembly/deserialize/swar/array/struct.ts +20 -4
  32. package/assembly/deserialize/swar/array.ts +56 -2
  33. package/assembly/deserialize/swar/string.ts +245 -370
  34. package/assembly/index.ts +207 -194
  35. package/assembly/serialize/index/arbitrary.ts +8 -3
  36. package/assembly/serialize/index/float.ts +1 -1
  37. package/assembly/serialize/index/object.ts +1 -5
  38. package/assembly/serialize/index/typedarray.ts +65 -0
  39. package/assembly/serialize/simd/string.ts +7 -16
  40. package/assembly/serialize/simple/arbitrary.ts +9 -3
  41. package/assembly/serialize/simple/array.ts +17 -6
  42. package/assembly/serialize/simple/float.ts +18 -4
  43. package/assembly/serialize/simple/map.ts +10 -27
  44. package/assembly/serialize/simple/object.ts +1 -5
  45. package/assembly/serialize/simple/set.ts +3 -4
  46. package/assembly/serialize/simple/staticarray.ts +4 -3
  47. package/assembly/serialize/simple/string.ts +3 -11
  48. package/assembly/serialize/simple/typedarray.ts +9 -7
  49. package/assembly/serialize/swar/string.ts +3 -12
  50. package/assembly/tsconfig.json +3 -2
  51. package/assembly/util/dragonbox-cache.ts +1322 -0
  52. package/assembly/util/dragonbox.ts +596 -0
  53. package/assembly/util/swar.ts +49 -0
  54. package/lib/as-bs.ts +92 -70
  55. package/package.json +35 -10
  56. package/transform/lib/index.d.ts +1 -0
  57. package/transform/lib/index.d.ts.map +1 -1
  58. package/transform/lib/index.js +559 -221
  59. package/transform/lib/index.js.map +1 -1
  60. package/transform/lib/linkers/custom.d.ts.map +1 -1
  61. package/transform/lib/linkers/custom.js +7 -3
  62. package/transform/lib/linkers/custom.js.map +1 -1
  63. package/transform/lib/types.d.ts +2 -0
  64. package/transform/lib/types.d.ts.map +1 -1
  65. package/transform/lib/types.js +13 -0
  66. package/transform/lib/types.js.map +1 -1
  67. package/.as-test/coverage/naive/coverage.arbitrary.spec.ts.log.json +0 -5628
  68. package/.as-test/coverage/naive/coverage.array.spec.ts.log.json +0 -5187
  69. package/.as-test/coverage/naive/coverage.bool.spec.ts.log.json +0 -5187
  70. package/.as-test/coverage/naive/coverage.box.spec.ts.log.json +0 -5187
  71. package/.as-test/coverage/naive/coverage.custom.spec.ts.log.json +0 -5187
  72. package/.as-test/coverage/naive/coverage.date.spec.ts.log.json +0 -5187
  73. package/.as-test/coverage/naive/coverage.enum.spec.ts.log.json +0 -5187
  74. package/.as-test/coverage/naive/coverage.float.spec.ts.log.json +0 -5187
  75. package/.as-test/coverage/naive/coverage.generics.spec.ts.log.json +0 -5187
  76. package/.as-test/coverage/naive/coverage.hierarchy.spec.ts.log.json +0 -5187
  77. package/.as-test/coverage/naive/coverage.integer.spec.ts.log.json +0 -5187
  78. package/.as-test/coverage/naive/coverage.map.spec.ts.log.json +0 -5187
  79. package/.as-test/coverage/naive/coverage.namespace.spec.ts.log.json +0 -5187
  80. package/.as-test/coverage/naive/coverage.null.spec.ts.log.json +0 -5187
  81. package/.as-test/coverage/naive/coverage.raw.spec.ts.log.json +0 -5187
  82. package/.as-test/coverage/naive/coverage.resolving.spec.ts.log.json +0 -5628
  83. package/.as-test/coverage/naive/coverage.set.spec.ts.log.json +0 -5187
  84. package/.as-test/coverage/naive/coverage.staticarray.spec.ts.log.json +0 -5187
  85. package/.as-test/coverage/naive/coverage.string.spec.ts.log.json +0 -5187
  86. package/.as-test/coverage/naive/coverage.struct.spec.ts.log.json +0 -5187
  87. package/.as-test/coverage/naive/coverage.types.spec.ts.log.json +0 -5187
  88. package/.as-test/coverage/simd/coverage.arbitrary.spec.ts.log.json +0 -5628
  89. package/.as-test/coverage/simd/coverage.array.spec.ts.log.json +0 -5187
  90. package/.as-test/coverage/simd/coverage.bool.spec.ts.log.json +0 -5187
  91. package/.as-test/coverage/simd/coverage.box.spec.ts.log.json +0 -5187
  92. package/.as-test/coverage/simd/coverage.custom.spec.ts.log.json +0 -5187
  93. package/.as-test/coverage/simd/coverage.date.spec.ts.log.json +0 -5187
  94. package/.as-test/coverage/simd/coverage.enum.spec.ts.log.json +0 -5187
  95. package/.as-test/coverage/simd/coverage.float.spec.ts.log.json +0 -5187
  96. package/.as-test/coverage/simd/coverage.generics.spec.ts.log.json +0 -5187
  97. package/.as-test/coverage/simd/coverage.hierarchy.spec.ts.log.json +0 -5187
  98. package/.as-test/coverage/simd/coverage.integer.spec.ts.log.json +0 -5187
  99. package/.as-test/coverage/simd/coverage.map.spec.ts.log.json +0 -5187
  100. package/.as-test/coverage/simd/coverage.namespace.spec.ts.log.json +0 -5187
  101. package/.as-test/coverage/simd/coverage.null.spec.ts.log.json +0 -5187
  102. package/.as-test/coverage/simd/coverage.raw.spec.ts.log.json +0 -5187
  103. package/.as-test/coverage/simd/coverage.resolving.spec.ts.log.json +0 -5628
  104. package/.as-test/coverage/simd/coverage.set.spec.ts.log.json +0 -5187
  105. package/.as-test/coverage/simd/coverage.staticarray.spec.ts.log.json +0 -5187
  106. package/.as-test/coverage/simd/coverage.string.spec.ts.log.json +0 -5187
  107. package/.as-test/coverage/simd/coverage.struct.spec.ts.log.json +0 -5187
  108. package/.as-test/coverage/simd/coverage.types.spec.ts.log.json +0 -5187
  109. package/.as-test/coverage/swar/coverage.arbitrary.spec.ts.log.json +0 -5628
  110. package/.as-test/coverage/swar/coverage.array.spec.ts.log.json +0 -5187
  111. package/.as-test/coverage/swar/coverage.bool.spec.ts.log.json +0 -5187
  112. package/.as-test/coverage/swar/coverage.box.spec.ts.log.json +0 -5187
  113. package/.as-test/coverage/swar/coverage.custom.spec.ts.log.json +0 -5187
  114. package/.as-test/coverage/swar/coverage.date.spec.ts.log.json +0 -5187
  115. package/.as-test/coverage/swar/coverage.enum.spec.ts.log.json +0 -5187
  116. package/.as-test/coverage/swar/coverage.float.spec.ts.log.json +0 -5187
  117. package/.as-test/coverage/swar/coverage.generics.spec.ts.log.json +0 -5187
  118. package/.as-test/coverage/swar/coverage.hierarchy.spec.ts.log.json +0 -5187
  119. package/.as-test/coverage/swar/coverage.integer.spec.ts.log.json +0 -5187
  120. package/.as-test/coverage/swar/coverage.map.spec.ts.log.json +0 -5187
  121. package/.as-test/coverage/swar/coverage.namespace.spec.ts.log.json +0 -5187
  122. package/.as-test/coverage/swar/coverage.null.spec.ts.log.json +0 -5187
  123. package/.as-test/coverage/swar/coverage.raw.spec.ts.log.json +0 -5187
  124. package/.as-test/coverage/swar/coverage.resolving.spec.ts.log.json +0 -5628
  125. package/.as-test/coverage/swar/coverage.set.spec.ts.log.json +0 -5187
  126. package/.as-test/coverage/swar/coverage.staticarray.spec.ts.log.json +0 -5187
  127. package/.as-test/coverage/swar/coverage.string.spec.ts.log.json +0 -5187
  128. package/.as-test/coverage/swar/coverage.struct.spec.ts.log.json +0 -5187
  129. package/.as-test/coverage/swar/coverage.types.spec.ts.log.json +0 -5187
  130. package/.as-test/logs/naive/run.arbitrary.spec.ts.log.json +0 -943
  131. package/.as-test/logs/naive/run.array.spec.ts.log.json +0 -1053
  132. package/.as-test/logs/naive/run.bool.spec.ts.log.json +0 -257
  133. package/.as-test/logs/naive/run.box.spec.ts.log.json +0 -353
  134. package/.as-test/logs/naive/run.custom.spec.ts.log.json +0 -309
  135. package/.as-test/logs/naive/run.date.spec.ts.log.json +0 -397
  136. package/.as-test/logs/naive/run.enum.spec.ts.log.json +0 -343
  137. package/.as-test/logs/naive/run.float.spec.ts.log.json +0 -453
  138. package/.as-test/logs/naive/run.generics.spec.ts.log.json +0 -393
  139. package/.as-test/logs/naive/run.hierarchy.spec.ts.log.json +0 -325
  140. package/.as-test/logs/naive/run.integer.spec.ts.log.json +0 -373
  141. package/.as-test/logs/naive/run.map.spec.ts.log.json +0 -247
  142. package/.as-test/logs/naive/run.namespace.spec.ts.log.json +0 -361
  143. package/.as-test/logs/naive/run.null.spec.ts.log.json +0 -273
  144. package/.as-test/logs/naive/run.raw.spec.ts.log.json +0 -309
  145. package/.as-test/logs/naive/run.resolving.spec.ts.log.json +0 -273
  146. package/.as-test/logs/naive/run.set.spec.ts.log.json +0 -733
  147. package/.as-test/logs/naive/run.staticarray.spec.ts.log.json +0 -931
  148. package/.as-test/logs/naive/run.string.spec.ts.log.json +0 -2289
  149. package/.as-test/logs/naive/run.struct.spec.ts.log.json +0 -523
  150. package/.as-test/logs/naive/run.types.spec.ts.log.json +0 -273
  151. package/.as-test/logs/naive/test.arbitrary.spec.ts.log.json +0 -943
  152. package/.as-test/logs/naive/test.array.spec.ts.log.json +0 -1053
  153. package/.as-test/logs/naive/test.bool.spec.ts.log.json +0 -257
  154. package/.as-test/logs/naive/test.box.spec.ts.log.json +0 -353
  155. package/.as-test/logs/naive/test.custom.spec.ts.log.json +0 -309
  156. package/.as-test/logs/naive/test.date.spec.ts.log.json +0 -397
  157. package/.as-test/logs/naive/test.enum.spec.ts.log.json +0 -343
  158. package/.as-test/logs/naive/test.float.spec.ts.log.json +0 -453
  159. package/.as-test/logs/naive/test.generics.spec.ts.log.json +0 -393
  160. package/.as-test/logs/naive/test.hierarchy.spec.ts.log.json +0 -325
  161. package/.as-test/logs/naive/test.integer.spec.ts.log.json +0 -373
  162. package/.as-test/logs/naive/test.log.json +0 -2289
  163. package/.as-test/logs/naive/test.map.spec.ts.log.json +0 -247
  164. package/.as-test/logs/naive/test.namespace.spec.ts.log.json +0 -361
  165. package/.as-test/logs/naive/test.null.spec.ts.log.json +0 -273
  166. package/.as-test/logs/naive/test.raw.spec.ts.log.json +0 -309
  167. package/.as-test/logs/naive/test.resolving.spec.ts.log.json +0 -273
  168. package/.as-test/logs/naive/test.set.spec.ts.log.json +0 -733
  169. package/.as-test/logs/naive/test.staticarray.spec.ts.log.json +0 -931
  170. package/.as-test/logs/naive/test.string.spec.ts.log.json +0 -2345
  171. package/.as-test/logs/naive/test.struct.spec.ts.log.json +0 -523
  172. package/.as-test/logs/naive/test.types.spec.ts.log.json +0 -273
  173. package/.as-test/logs/simd/run.arbitrary.spec.ts.log.json +0 -943
  174. package/.as-test/logs/simd/run.array.spec.ts.log.json +0 -1053
  175. package/.as-test/logs/simd/run.bool.spec.ts.log.json +0 -257
  176. package/.as-test/logs/simd/run.box.spec.ts.log.json +0 -353
  177. package/.as-test/logs/simd/run.custom.spec.ts.log.json +0 -309
  178. package/.as-test/logs/simd/run.date.spec.ts.log.json +0 -397
  179. package/.as-test/logs/simd/run.enum.spec.ts.log.json +0 -343
  180. package/.as-test/logs/simd/run.float.spec.ts.log.json +0 -453
  181. package/.as-test/logs/simd/run.generics.spec.ts.log.json +0 -393
  182. package/.as-test/logs/simd/run.hierarchy.spec.ts.log.json +0 -325
  183. package/.as-test/logs/simd/run.integer.spec.ts.log.json +0 -373
  184. package/.as-test/logs/simd/run.map.spec.ts.log.json +0 -247
  185. package/.as-test/logs/simd/run.namespace.spec.ts.log.json +0 -361
  186. package/.as-test/logs/simd/run.null.spec.ts.log.json +0 -273
  187. package/.as-test/logs/simd/run.raw.spec.ts.log.json +0 -309
  188. package/.as-test/logs/simd/run.resolving.spec.ts.log.json +0 -273
  189. package/.as-test/logs/simd/run.set.spec.ts.log.json +0 -733
  190. package/.as-test/logs/simd/run.staticarray.spec.ts.log.json +0 -931
  191. package/.as-test/logs/simd/run.string.spec.ts.log.json +0 -2289
  192. package/.as-test/logs/simd/run.struct.spec.ts.log.json +0 -523
  193. package/.as-test/logs/simd/run.types.spec.ts.log.json +0 -273
  194. package/.as-test/logs/simd/test.arbitrary.spec.ts.log.json +0 -943
  195. package/.as-test/logs/simd/test.array.spec.ts.log.json +0 -1053
  196. package/.as-test/logs/simd/test.bool.spec.ts.log.json +0 -257
  197. package/.as-test/logs/simd/test.box.spec.ts.log.json +0 -353
  198. package/.as-test/logs/simd/test.custom.spec.ts.log.json +0 -309
  199. package/.as-test/logs/simd/test.date.spec.ts.log.json +0 -397
  200. package/.as-test/logs/simd/test.enum.spec.ts.log.json +0 -343
  201. package/.as-test/logs/simd/test.float.spec.ts.log.json +0 -453
  202. package/.as-test/logs/simd/test.generics.spec.ts.log.json +0 -393
  203. package/.as-test/logs/simd/test.hierarchy.spec.ts.log.json +0 -325
  204. package/.as-test/logs/simd/test.integer.spec.ts.log.json +0 -373
  205. package/.as-test/logs/simd/test.log.json +0 -11371
  206. package/.as-test/logs/simd/test.map.spec.ts.log.json +0 -247
  207. package/.as-test/logs/simd/test.namespace.spec.ts.log.json +0 -361
  208. package/.as-test/logs/simd/test.null.spec.ts.log.json +0 -273
  209. package/.as-test/logs/simd/test.raw.spec.ts.log.json +0 -309
  210. package/.as-test/logs/simd/test.resolving.spec.ts.log.json +0 -273
  211. package/.as-test/logs/simd/test.set.spec.ts.log.json +0 -733
  212. package/.as-test/logs/simd/test.staticarray.spec.ts.log.json +0 -931
  213. package/.as-test/logs/simd/test.string.spec.ts.log.json +0 -2345
  214. package/.as-test/logs/simd/test.struct.spec.ts.log.json +0 -523
  215. package/.as-test/logs/simd/test.types.spec.ts.log.json +0 -273
  216. package/.as-test/logs/swar/run.arbitrary.spec.ts.log.json +0 -943
  217. package/.as-test/logs/swar/run.array.spec.ts.log.json +0 -1053
  218. package/.as-test/logs/swar/run.bool.spec.ts.log.json +0 -257
  219. package/.as-test/logs/swar/run.box.spec.ts.log.json +0 -353
  220. package/.as-test/logs/swar/run.custom.spec.ts.log.json +0 -309
  221. package/.as-test/logs/swar/run.date.spec.ts.log.json +0 -397
  222. package/.as-test/logs/swar/run.enum.spec.ts.log.json +0 -343
  223. package/.as-test/logs/swar/run.float.spec.ts.log.json +0 -453
  224. package/.as-test/logs/swar/run.generics.spec.ts.log.json +0 -393
  225. package/.as-test/logs/swar/run.hierarchy.spec.ts.log.json +0 -325
  226. package/.as-test/logs/swar/run.integer.spec.ts.log.json +0 -373
  227. package/.as-test/logs/swar/run.map.spec.ts.log.json +0 -247
  228. package/.as-test/logs/swar/run.namespace.spec.ts.log.json +0 -361
  229. package/.as-test/logs/swar/run.null.spec.ts.log.json +0 -273
  230. package/.as-test/logs/swar/run.raw.spec.ts.log.json +0 -309
  231. package/.as-test/logs/swar/run.resolving.spec.ts.log.json +0 -273
  232. package/.as-test/logs/swar/run.set.spec.ts.log.json +0 -733
  233. package/.as-test/logs/swar/run.staticarray.spec.ts.log.json +0 -931
  234. package/.as-test/logs/swar/run.string.spec.ts.log.json +0 -2289
  235. package/.as-test/logs/swar/run.struct.spec.ts.log.json +0 -523
  236. package/.as-test/logs/swar/run.types.spec.ts.log.json +0 -273
  237. package/.as-test/logs/swar/test.arbitrary.spec.ts.log.json +0 -943
  238. package/.as-test/logs/swar/test.array.spec.ts.log.json +0 -1053
  239. package/.as-test/logs/swar/test.bool.spec.ts.log.json +0 -257
  240. package/.as-test/logs/swar/test.box.spec.ts.log.json +0 -353
  241. package/.as-test/logs/swar/test.custom.spec.ts.log.json +0 -309
  242. package/.as-test/logs/swar/test.date.spec.ts.log.json +0 -397
  243. package/.as-test/logs/swar/test.enum.spec.ts.log.json +0 -343
  244. package/.as-test/logs/swar/test.float.spec.ts.log.json +0 -453
  245. package/.as-test/logs/swar/test.generics.spec.ts.log.json +0 -393
  246. package/.as-test/logs/swar/test.hierarchy.spec.ts.log.json +0 -325
  247. package/.as-test/logs/swar/test.integer.spec.ts.log.json +0 -373
  248. package/.as-test/logs/swar/test.log.json +0 -11371
  249. package/.as-test/logs/swar/test.map.spec.ts.log.json +0 -247
  250. package/.as-test/logs/swar/test.namespace.spec.ts.log.json +0 -361
  251. package/.as-test/logs/swar/test.null.spec.ts.log.json +0 -273
  252. package/.as-test/logs/swar/test.raw.spec.ts.log.json +0 -309
  253. package/.as-test/logs/swar/test.resolving.spec.ts.log.json +0 -273
  254. package/.as-test/logs/swar/test.set.spec.ts.log.json +0 -733
  255. package/.as-test/logs/swar/test.staticarray.spec.ts.log.json +0 -931
  256. package/.as-test/logs/swar/test.string.spec.ts.log.json +0 -2345
  257. package/.as-test/logs/swar/test.struct.spec.ts.log.json +0 -523
  258. package/.as-test/logs/swar/test.types.spec.ts.log.json +0 -273
  259. package/.as-test/logs/test.arbitrary.spec.ts.log.json +0 -943
  260. package/.as-test/logs/test.array.spec.ts.log.json +0 -1053
  261. package/.as-test/logs/test.bool.spec.ts.log.json +0 -257
  262. package/.as-test/logs/test.box.spec.ts.log.json +0 -353
  263. package/.as-test/logs/test.custom.spec.ts.log.json +0 -309
  264. package/.as-test/logs/test.date.spec.ts.log.json +0 -397
  265. package/.as-test/logs/test.enum.spec.ts.log.json +0 -343
  266. package/.as-test/logs/test.float.spec.ts.log.json +0 -453
  267. package/.as-test/logs/test.generics.spec.ts.log.json +0 -393
  268. package/.as-test/logs/test.hierarchy.spec.ts.log.json +0 -325
  269. package/.as-test/logs/test.integer.spec.ts.log.json +0 -373
  270. package/.as-test/logs/test.log.json +0 -11371
  271. package/.as-test/logs/test.map.spec.ts.log.json +0 -247
  272. package/.as-test/logs/test.namespace.spec.ts.log.json +0 -361
  273. package/.as-test/logs/test.null.spec.ts.log.json +0 -273
  274. package/.as-test/logs/test.raw.spec.ts.log.json +0 -309
  275. package/.as-test/logs/test.resolving.spec.ts.log.json +0 -273
  276. package/.as-test/logs/test.set.spec.ts.log.json +0 -733
  277. package/.as-test/logs/test.staticarray.spec.ts.log.json +0 -931
  278. package/.as-test/logs/test.string.spec.ts.log.json +0 -2289
  279. package/.as-test/logs/test.struct.spec.ts.log.json +0 -523
  280. package/.as-test/logs/test.types.spec.ts.log.json +0 -273
  281. package/.as-test/runners/default.bindings.js +0 -68
  282. package/.as-test/runners/default.wasi.js +0 -38
  283. package/ARCHITECTURE.md +0 -323
  284. package/CONTRIBUTING.md +0 -244
  285. package/TODO +0 -1
  286. package/as-test.config.json +0 -40
  287. package/assembly/test.ts +0 -24
  288. package/eslint.config.js +0 -68
  289. package/lib/tsconfig.json +0 -8
  290. package/test.ts +0 -99
  291. package/tools/assemblyscript-eslint-local.js +0 -6
  292. package/tools/assemblyscript-eslint.js +0 -53
  293. package/tools/assemblyscript-prettier-plugin.js +0 -33
  294. package/tools/replacer.js +0 -63
  295. package/transform/tsconfig.json +0 -35
@@ -1,10 +1,10 @@
1
+ import { JSON } from "../../..";
1
2
  import { BRACKET_LEFT, BRACKET_RIGHT, COMMA } from "../../../custom/chars";
2
- import { deserializeArrayField } from "../array";
3
- import { ensureArrayElementSlot, ensureArrayField } from "./shared";
3
+ import { deserializeFloatArrayInto } from "./float";
4
+ import { ensureArrayField, scanValueEnd } from "./shared";
4
5
 
5
6
 
6
- @inline export function deserializeArrayArrayField<T extends unknown[][]>(srcStart: usize, srcEnd: usize, fieldPtr: usize): usize {
7
- const out = ensureArrayField<T>(fieldPtr);
7
+ @inline export function deserializeArrayArrayInto<T extends unknown[][]>(srcStart: usize, srcEnd: usize, out: T): usize {
8
8
  let index = 0;
9
9
 
10
10
  do {
@@ -17,9 +17,39 @@ import { ensureArrayElementSlot, ensureArrayField } from "./shared";
17
17
  }
18
18
 
19
19
  while (srcStart < srcEnd) {
20
- const slot = ensureArrayElementSlot<T>(out, index);
21
- srcStart = deserializeArrayField<valueof<T>>(srcStart, srcEnd, slot);
22
- if (!srcStart || srcStart >= srcEnd) break;
20
+ if (isFloat<valueof<valueof<T>>>()) {
21
+ let value: valueof<T>;
22
+ if (index < out.length) {
23
+ value = unchecked(out[index]);
24
+ } else {
25
+ value = changetype<valueof<T>>(instantiate<valueof<T>>());
26
+ out.push(value);
27
+ }
28
+ srcStart = deserializeFloatArrayInto<valueof<T>>(srcStart, srcEnd, value);
29
+ if (!srcStart || srcStart >= srcEnd) break;
30
+ } else if (isArray<valueof<valueof<T>>>()) {
31
+ let value: valueof<T>;
32
+ if (index < out.length) {
33
+ value = unchecked(out[index]);
34
+ } else {
35
+ value = changetype<valueof<T>>(instantiate<valueof<T>>());
36
+ out.push(value);
37
+ }
38
+ srcStart = deserializeArrayArrayInto<valueof<T>>(srcStart, srcEnd, value);
39
+ if (!srcStart || srcStart >= srcEnd) break;
40
+ } else {
41
+ const valueEnd = scanValueEnd(srcStart, srcEnd);
42
+ if (!valueEnd || valueEnd <= srcStart) break;
43
+
44
+ let valuePtr: usize = 0;
45
+ if (index < out.length) {
46
+ valuePtr = changetype<usize>(unchecked(out[index]));
47
+ }
48
+ const value = JSON.__deserialize<valueof<T>>(srcStart, valueEnd, valuePtr);
49
+ if (index < out.length) unchecked((out[index] = value));
50
+ else out.push(value);
51
+ srcStart = valueEnd;
52
+ }
23
53
 
24
54
  const code = load<u16>(srcStart);
25
55
  if (code == COMMA) {
@@ -37,3 +67,8 @@ import { ensureArrayElementSlot, ensureArrayField } from "./shared";
37
67
 
38
68
  throw new Error("Failed to parse JSON!");
39
69
  }
70
+
71
+
72
+ @inline export function deserializeArrayArrayField<T extends unknown[][]>(srcStart: usize, srcEnd: usize, fieldPtr: usize): usize {
73
+ return deserializeArrayArrayInto<T>(srcStart, srcEnd, ensureArrayField<T>(fieldPtr));
74
+ }
@@ -2,8 +2,7 @@ import { BRACKET_LEFT, BRACKET_RIGHT, COMMA, FALSE_WORD_U64, TRUE_WORD_U64 } fro
2
2
  import { ensureArrayElementSlot, ensureArrayField } from "./shared";
3
3
 
4
4
 
5
- @inline export function deserializeBooleanArrayField<T extends boolean[]>(srcStart: usize, srcEnd: usize, fieldPtr: usize): usize {
6
- const out = ensureArrayField<T>(fieldPtr);
5
+ @inline export function deserializeBooleanArrayInto<T extends boolean[]>(srcStart: usize, srcEnd: usize, out: T): usize {
7
6
  let index = 0;
8
7
 
9
8
  do {
@@ -45,3 +44,7 @@ import { ensureArrayElementSlot, ensureArrayField } from "./shared";
45
44
 
46
45
  throw new Error("Failed to parse JSON!");
47
46
  }
47
+
48
+ @inline export function deserializeBooleanArrayField<T extends boolean[]>(srcStart: usize, srcEnd: usize, fieldPtr: usize): usize {
49
+ return deserializeBooleanArrayInto<T>(srcStart, srcEnd, ensureArrayField<T>(fieldPtr));
50
+ }
@@ -1,10 +1,9 @@
1
- import { deserializeFloatField } from "../../float";
1
+ import { deserializeFloatField } from "../../simple/float";
2
2
  import { BRACKET_LEFT, BRACKET_RIGHT, COMMA } from "../../../custom/chars";
3
3
  import { ensureArrayElementSlot, ensureArrayField } from "./shared";
4
4
 
5
5
 
6
- @inline export function deserializeFloatArrayField<T extends number[]>(srcStart: usize, srcEnd: usize, fieldPtr: usize): usize {
7
- const out = ensureArrayField<T>(fieldPtr);
6
+ @inline export function deserializeFloatArrayInto<T extends number[]>(srcStart: usize, srcEnd: usize, out: T): usize {
8
7
  let index = 0;
9
8
 
10
9
  do {
@@ -37,3 +36,8 @@ import { ensureArrayElementSlot, ensureArrayField } from "./shared";
37
36
 
38
37
  throw new Error("Failed to parse JSON!");
39
38
  }
39
+
40
+
41
+ @inline export function deserializeFloatArrayField<T extends number[]>(srcStart: usize, srcEnd: usize, fieldPtr: usize): usize {
42
+ return deserializeFloatArrayInto<T>(srcStart, srcEnd, ensureArrayField<T>(fieldPtr));
43
+ }
@@ -0,0 +1,40 @@
1
+ import { JSON } from "../../..";
2
+ import { BRACKET_LEFT, BRACKET_RIGHT, COMMA } from "../../../custom/chars";
3
+ import { ensureArrayElementSlot, ensureArrayField, scanValueEnd } from "./shared";
4
+
5
+ @inline export function deserializeGenericArrayInto<T extends unknown[]>(srcStart: usize, srcEnd: usize, out: T): usize {
6
+
7
+ if (srcStart >= srcEnd || load<u16>(srcStart) != BRACKET_LEFT) throw new Error("Failed to parse JSON!");
8
+ srcStart += 2;
9
+ if (srcStart >= srcEnd) throw new Error("Failed to parse JSON!");
10
+ if (load<u16>(srcStart) == BRACKET_RIGHT) return srcStart + 2;
11
+
12
+ let index = 0;
13
+
14
+ while (srcStart < srcEnd) {
15
+ const valueEnd = scanValueEnd(srcStart, srcEnd);
16
+ if (!valueEnd || valueEnd <= srcStart) break;
17
+
18
+ const slot = ensureArrayElementSlot<T>(out, index++);
19
+ store<valueof<T>>(slot, JSON.__deserialize<valueof<T>>(srcStart, valueEnd));
20
+ srcStart = valueEnd;
21
+
22
+ if (srcStart >= srcEnd) break;
23
+ const code = load<u16>(srcStart);
24
+ if (code == COMMA) {
25
+ srcStart += 2;
26
+ continue;
27
+ }
28
+ if (code == BRACKET_RIGHT) {
29
+ out.length = index;
30
+ return srcStart + 2;
31
+ }
32
+ break;
33
+ }
34
+
35
+ throw new Error("Failed to parse JSON!");
36
+ }
37
+
38
+ @inline export function deserializeGenericArrayField<T extends unknown[]>(srcStart: usize, srcEnd: usize, fieldPtr: usize): usize {
39
+ return deserializeGenericArrayInto<T>(srcStart, srcEnd, ensureArrayField<T>(fieldPtr));
40
+ }
@@ -1,5 +1,5 @@
1
- import { deserializeIntegerField } from "../../integer";
2
- import { deserializeUnsignedField } from "../../unsigned";
1
+ import { deserializeIntegerField } from "../../simple/integer";
2
+ import { deserializeUnsignedField } from "../../simple/unsigned";
3
3
  import { BRACKET_LEFT, BRACKET_RIGHT, COMMA } from "../../../custom/chars";
4
4
  import { isSpace } from "../../../util";
5
5
  import { ensureArrayElementSlot, ensureArrayField } from "./shared";
@@ -425,8 +425,7 @@ export function deserializeIntegerArray_SWAR<T extends number[]>(srcStart: usize
425
425
  }
426
426
 
427
427
 
428
- @inline export function deserializeIntegerArrayField<T extends number[]>(srcStart: usize, srcEnd: usize, fieldPtr: usize): usize {
429
- const out = ensureArrayField<T>(fieldPtr);
428
+ @inline export function deserializeIntegerArrayInto<T extends number[]>(srcStart: usize, srcEnd: usize, out: T): usize {
430
429
  let index = 0;
431
430
 
432
431
  do {
@@ -459,3 +458,7 @@ export function deserializeIntegerArray_SWAR<T extends number[]>(srcStart: usize
459
458
 
460
459
  throw new Error("Failed to parse JSON!");
461
460
  }
461
+
462
+ @inline export function deserializeIntegerArrayField<T extends number[]>(srcStart: usize, srcEnd: usize, fieldPtr: usize): usize {
463
+ return deserializeIntegerArrayInto<T>(srcStart, srcEnd, ensureArrayField<T>(fieldPtr));
464
+ }
@@ -2,8 +2,7 @@ import { BRACKET_LEFT, BRACKET_RIGHT, COMMA } from "../../../custom/chars";
2
2
  import { ensureArrayElementSlot, ensureArrayField } from "./shared";
3
3
 
4
4
 
5
- @inline export function deserializeObjectArrayField<T extends unknown[]>(srcStart: usize, srcEnd: usize, fieldPtr: usize): usize {
6
- const out = ensureArrayField<T>(fieldPtr);
5
+ @inline export function deserializeObjectArrayInto<T extends unknown[]>(srcStart: usize, srcEnd: usize, out: T): usize {
7
6
  let index = 0;
8
7
 
9
8
  do {
@@ -19,11 +18,24 @@ import { ensureArrayElementSlot, ensureArrayField } from "./shared";
19
18
  const slot = ensureArrayElementSlot<T>(out, index);
20
19
  let value = load<valueof<T>>(slot);
21
20
  if (changetype<usize>(value) == 0) {
22
- value = changetype<valueof<T>>(instantiate<nonnull<valueof<T>>>());
21
+ value = changetype<valueof<T>>(__new(offsetof<nonnull<valueof<T>>>(), idof<nonnull<valueof<T>>>()));
22
+ // @ts-ignore: supplied by transform
23
+ if (isDefined(changetype<nonnull<valueof<T>>>(value).__INITIALIZE)) {
24
+ // @ts-ignore: supplied by transform
25
+ changetype<nonnull<valueof<T>>>(value).__INITIALIZE();
26
+ }
23
27
  store<valueof<T>>(slot, value);
24
28
  }
25
29
 
26
- srcStart = changetype<nonnull<valueof<T>>>(value).__DESERIALIZE<valueof<T>>(srcStart, srcEnd, value);
30
+ const valueStart = srcStart;
31
+ // @ts-ignore: supplied by transform
32
+ if (isDefined(changetype<nonnull<valueof<T>>>(value).__DESERIALIZE_FAST)) {
33
+ // @ts-ignore: supplied by transform
34
+ srcStart = changetype<nonnull<valueof<T>>>(value).__DESERIALIZE_FAST<valueof<T>>(valueStart, srcEnd, value);
35
+ } else {
36
+ // @ts-ignore: supplied by transform
37
+ srcStart = changetype<nonnull<valueof<T>>>(value).__DESERIALIZE_SLOW<valueof<T>>(valueStart, srcEnd, value);
38
+ }
27
39
  if (!srcStart || srcStart >= srcEnd) break;
28
40
 
29
41
  const code = load<u16>(srcStart);
@@ -42,3 +54,7 @@ import { ensureArrayElementSlot, ensureArrayField } from "./shared";
42
54
 
43
55
  throw new Error("Failed to parse JSON!");
44
56
  }
57
+
58
+ @inline export function deserializeObjectArrayField<T extends unknown[]>(srcStart: usize, srcEnd: usize, fieldPtr: usize): usize {
59
+ return deserializeObjectArrayInto<T>(srcStart, srcEnd, ensureArrayField<T>(fieldPtr));
60
+ }
@@ -6,8 +6,15 @@ import { BACK_SLASH, BRACE_LEFT, BRACE_RIGHT, BRACKET_LEFT, BRACKET_RIGHT, COMMA
6
6
  if (!changetype<usize>(out)) {
7
7
  out = changetype<T>(instantiate<T>());
8
8
  store<T>(fieldPtr, out);
9
- } else {
10
- out.length = 0;
9
+ }
10
+ return out;
11
+ }
12
+
13
+ @inline export function ensureArrayFieldAt<T extends Array<any>>(dstObj: usize, dstOffset: usize): T {
14
+ let out = load<T>(dstObj, dstOffset);
15
+ if (!changetype<usize>(out)) {
16
+ out = changetype<T>(instantiate<T>());
17
+ store<T>(dstObj, out, dstOffset);
11
18
  }
12
19
  return out;
13
20
  }
@@ -22,7 +29,14 @@ import { BACK_SLASH, BRACE_LEFT, BRACE_RIGHT, BRACKET_LEFT, BRACKET_RIGHT, COMMA
22
29
 
23
30
  @inline export function ensureArrayElementSlot<T extends Array<any>>(out: T, index: i32): usize {
24
31
  const nextLength = index + 1;
25
- if (out.length < nextLength) out.length = nextLength;
32
+ if (out.length < nextLength) {
33
+ out.length = nextLength;
34
+ const slot = out.dataStart + <usize>index * sizeof<valueof<T>>();
35
+ // Reference arrays can allocate recursively before the caller stores the new element.
36
+ // Zero the newly exposed slot immediately so incremental GC never observes a garbage pointer.
37
+ if (isManaged<valueof<T>>() || isReference<valueof<T>>()) store<usize>(slot, 0);
38
+ return slot;
39
+ }
26
40
  return out.dataStart + <usize>index * sizeof<valueof<T>>();
27
41
  }
28
42
 
@@ -88,7 +102,7 @@ import { BACK_SLASH, BRACE_LEFT, BRACE_RIGHT, BRACKET_LEFT, BRACKET_RIGHT, COMMA
88
102
 
89
103
  while (srcStart < srcEnd) {
90
104
  const code = load<u16>(srcStart);
91
- if (code == COMMA || code == BRACKET_RIGHT) return srcStart;
105
+ if (code == COMMA || code == BRACKET_RIGHT || code == BRACE_RIGHT) return srcStart;
92
106
  srcStart += 2;
93
107
  }
94
108
 
@@ -3,8 +3,7 @@ import { ensureArrayElementSlot, ensureArrayField } from "./shared";
3
3
  import { deserializeStringField_SWAR } from "../string";
4
4
 
5
5
 
6
- @inline export function deserializeStringArrayField<T extends string[]>(srcStart: usize, srcEnd: usize, fieldPtr: usize): usize {
7
- const out = ensureArrayField<T>(fieldPtr);
6
+ @inline export function deserializeStringArrayInto<T extends string[]>(srcStart: usize, srcEnd: usize, out: T): usize {
8
7
  let index = 0;
9
8
 
10
9
  do {
@@ -37,3 +36,7 @@ import { deserializeStringField_SWAR } from "../string";
37
36
 
38
37
  throw new Error("Failed to parse JSON!");
39
38
  }
39
+
40
+ @inline export function deserializeStringArrayField<T extends string[]>(srcStart: usize, srcEnd: usize, fieldPtr: usize): usize {
41
+ return deserializeStringArrayInto<T>(srcStart, srcEnd, ensureArrayField<T>(fieldPtr));
42
+ }
@@ -2,8 +2,7 @@ import { BRACKET_LEFT, BRACKET_RIGHT, COMMA } from "../../../custom/chars";
2
2
  import { ensureArrayElementSlot, ensureArrayField } from "./shared";
3
3
 
4
4
 
5
- @inline export function deserializeStructArrayField<T extends unknown[]>(srcStart: usize, srcEnd: usize, fieldPtr: usize): usize {
6
- const out = ensureArrayField<T>(fieldPtr);
5
+ @inline export function deserializeStructArrayInto<T extends unknown[]>(srcStart: usize, srcEnd: usize, out: T): usize {
7
6
  let index = 0;
8
7
 
9
8
  do {
@@ -19,11 +18,24 @@ import { ensureArrayElementSlot, ensureArrayField } from "./shared";
19
18
  const slot = ensureArrayElementSlot<T>(out, index);
20
19
  let value = load<valueof<T>>(slot);
21
20
  if (changetype<usize>(value) == 0) {
22
- value = changetype<valueof<T>>(instantiate<nonnull<valueof<T>>>());
21
+ value = changetype<valueof<T>>(__new(offsetof<nonnull<valueof<T>>>(), idof<nonnull<valueof<T>>>()));
22
+ // @ts-ignore: supplied by transform
23
+ if (isDefined(changetype<nonnull<valueof<T>>>(value).__INITIALIZE)) {
24
+ // @ts-ignore: supplied by transform
25
+ changetype<nonnull<valueof<T>>>(value).__INITIALIZE();
26
+ }
23
27
  store<valueof<T>>(slot, value);
24
28
  }
25
29
 
26
- srcStart = changetype<nonnull<valueof<T>>>(value).__DESERIALIZE<valueof<T>>(srcStart, srcEnd, value);
30
+ const valueStart = srcStart;
31
+ // @ts-ignore: supplied by transform
32
+ if (isDefined(changetype<nonnull<valueof<T>>>(value).__DESERIALIZE_FAST)) {
33
+ // @ts-ignore: supplied by transform
34
+ srcStart = changetype<nonnull<valueof<T>>>(value).__DESERIALIZE_FAST<valueof<T>>(valueStart, srcEnd, value);
35
+ } else {
36
+ // @ts-ignore: supplied by transform
37
+ srcStart = changetype<nonnull<valueof<T>>>(value).__DESERIALIZE_SLOW<valueof<T>>(valueStart, srcEnd, value);
38
+ }
27
39
  if (!srcStart || srcStart >= srcEnd) break;
28
40
 
29
41
  const code = load<u16>(srcStart);
@@ -42,3 +54,7 @@ import { ensureArrayElementSlot, ensureArrayField } from "./shared";
42
54
 
43
55
  throw new Error("Failed to parse JSON!");
44
56
  }
57
+
58
+ @inline export function deserializeStructArrayField<T extends unknown[]>(srcStart: usize, srcEnd: usize, fieldPtr: usize): usize {
59
+ return deserializeStructArrayInto<T>(srcStart, srcEnd, ensureArrayField<T>(fieldPtr));
60
+ }
@@ -4,15 +4,25 @@ import { deserializeArrayArrayField } from "./array/array";
4
4
  import { deserializeBooleanArrayField } from "./array/bool";
5
5
  import { deserializeBoxArrayField } from "./array/box";
6
6
  import { deserializeFloatArrayField } from "./array/float";
7
+ import { deserializeGenericArrayField } from "./array/generic";
7
8
  import { deserializeIntegerArrayField } from "./array/integer";
8
9
  import { deserializeMapArrayField } from "./array/map";
9
10
  import { deserializeObjectArrayField } from "./array/object";
10
11
  import { deserializeRawArrayField } from "./array/raw";
11
12
  import { deserializeStringArrayField } from "./array/string";
12
13
  import { deserializeStructArrayField } from "./array/struct";
14
+ import { deserializeArrayArrayInto } from "./array/array";
15
+ import { deserializeBooleanArrayInto } from "./array/bool";
16
+ import { deserializeFloatArrayInto } from "./array/float";
17
+ import { deserializeGenericArrayInto } from "./array/generic";
18
+ import { deserializeIntegerArrayInto } from "./array/integer";
19
+ import { deserializeObjectArrayInto } from "./array/object";
20
+ import { deserializeStringArrayInto } from "./array/string";
21
+ import { deserializeStructArrayInto } from "./array/struct";
13
22
 
14
23
 
15
- @inline export function deserializeArrayField<T extends unknown[]>(srcStart: usize, srcEnd: usize, fieldPtr: usize): usize {
24
+ @inline export function deserializeArrayField<T extends unknown[]>(srcStart: usize, srcEnd: usize, dstObj: usize, dstOffset: usize = 0): usize {
25
+ const fieldPtr = dstObj + dstOffset;
16
26
  if (isString<valueof<T>>()) {
17
27
  return deserializeStringArrayField<T>(srcStart, srcEnd, fieldPtr);
18
28
  } else if (isBoolean<valueof<T>>()) {
@@ -33,13 +43,17 @@ import { deserializeStructArrayField } from "./array/struct";
33
43
  return deserializeObjectArrayField<T>(srcStart, srcEnd, fieldPtr);
34
44
  } else if (type instanceof JSON.Raw) {
35
45
  return deserializeRawArrayField(srcStart, srcEnd, fieldPtr);
46
+ } else if (type instanceof Date) {
47
+ return deserializeGenericArrayField<T>(srcStart, srcEnd, fieldPtr);
48
+ } else if (type instanceof Set) {
49
+ return deserializeGenericArrayField<T>(srcStart, srcEnd, fieldPtr);
36
50
  } else if (type instanceof Map) {
37
51
  return deserializeMapArrayField<T>(srcStart, srcEnd, fieldPtr);
38
52
  // @ts-ignore: defined by transform
39
53
  } else if (isDefined(type.__DESERIALIZE_CUSTOM)) {
40
54
  return deserializeStructArrayField<T>(srcStart, srcEnd, fieldPtr);
41
55
  // @ts-ignore: defined by transform
42
- } else if (isDefined(type.__DESERIALIZE)) {
56
+ } else if (isDefined(type.__DESERIALIZE_SLOW) || isDefined(type.__DESERIALIZE_FAST)) {
43
57
  return deserializeStructArrayField<T>(srcStart, srcEnd, fieldPtr);
44
58
  }
45
59
  throw new Error("Could not parse array field of type " + nameof<T>() + "!");
@@ -47,3 +61,43 @@ import { deserializeStructArrayField } from "./array/struct";
47
61
  throw new Error("Could not parse array field of type " + nameof<T>() + "!");
48
62
  }
49
63
  }
64
+
65
+ @inline export function deserializeArrayInto_SWAR<T extends unknown[]>(srcStart: usize, srcEnd: usize, out: T): usize {
66
+ if (isString<valueof<T>>()) {
67
+ return deserializeStringArrayInto<T>(srcStart, srcEnd, out);
68
+ } else if (isBoolean<valueof<T>>()) {
69
+ return deserializeBooleanArrayInto<T>(srcStart, srcEnd, out);
70
+ } else if (isInteger<valueof<T>>()) {
71
+ return deserializeIntegerArrayInto<T>(srcStart, srcEnd, out);
72
+ } else if (isFloat<valueof<T>>()) {
73
+ return deserializeFloatArrayInto<T>(srcStart, srcEnd, out);
74
+ } else if (isArray<valueof<T>>()) {
75
+ return deserializeArrayArrayInto<T>(srcStart, srcEnd, out);
76
+ } else if (isManaged<valueof<T>>() || isReference<valueof<T>>()) {
77
+ const type = changetype<nonnull<valueof<T>>>(0);
78
+ if (type instanceof JSON.Value) {
79
+ return deserializeGenericArrayInto<T>(srcStart, srcEnd, out);
80
+ } else if (type instanceof JSON.Box) {
81
+ throw new Error("Failed to parse JSON!");
82
+ } else if (type instanceof JSON.Obj) {
83
+ return deserializeObjectArrayInto<T>(srcStart, srcEnd, out);
84
+ } else if (type instanceof JSON.Raw) {
85
+ throw new Error("Failed to parse JSON!");
86
+ } else if (type instanceof Date) {
87
+ return deserializeGenericArrayInto<T>(srcStart, srcEnd, out);
88
+ } else if (type instanceof Set) {
89
+ return deserializeGenericArrayInto<T>(srcStart, srcEnd, out);
90
+ } else if (type instanceof Map) {
91
+ throw new Error("Failed to parse JSON!");
92
+ // @ts-ignore: defined by transform
93
+ } else if (isDefined(type.__DESERIALIZE_CUSTOM)) {
94
+ return deserializeStructArrayInto<T>(srcStart, srcEnd, out);
95
+ // @ts-ignore: defined by transform
96
+ } else if (isDefined(type.__DESERIALIZE_SLOW) || isDefined(type.__DESERIALIZE_FAST)) {
97
+ return deserializeStructArrayInto<T>(srcStart, srcEnd, out);
98
+ }
99
+ throw new Error("Could not parse array field of type " + nameof<T>() + "!");
100
+ } else {
101
+ throw new Error("Could not parse array field of type " + nameof<T>() + "!");
102
+ }
103
+ }