@pezkuwi/types-codec 16.5.5 → 16.5.6

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 (424) hide show
  1. package/LICENSE +201 -0
  2. package/abstract/Array.js +166 -0
  3. package/abstract/Base.js +101 -0
  4. package/abstract/Int.js +226 -0
  5. package/abstract/Object.js +40 -0
  6. package/{src/abstract/index.ts → abstract/index.js} +0 -3
  7. package/base/Compact.js +159 -0
  8. package/base/DoNotConstruct.js +95 -0
  9. package/base/Enum.js +369 -0
  10. package/{build/base → base}/Int.d.ts +1 -1
  11. package/base/Int.js +26 -0
  12. package/base/Null.js +77 -0
  13. package/base/Option.js +232 -0
  14. package/base/Result.js +63 -0
  15. package/base/Tuple.js +110 -0
  16. package/{build/base → base}/UInt.d.ts +1 -1
  17. package/base/UInt.js +23 -0
  18. package/base/Vec.js +102 -0
  19. package/base/VecAny.js +17 -0
  20. package/base/VecFixed.js +67 -0
  21. package/{src/base/index.ts → base/index.js} +0 -3
  22. package/{src/bundle.ts → bundle.js} +0 -6
  23. package/cjs/abstract/Array.d.ts +89 -0
  24. package/cjs/abstract/Array.js +170 -0
  25. package/cjs/abstract/Base.d.ts +75 -0
  26. package/cjs/abstract/Base.js +105 -0
  27. package/cjs/abstract/Int.d.ts +80 -0
  28. package/cjs/abstract/Int.js +230 -0
  29. package/cjs/abstract/Object.d.ts +67 -0
  30. package/cjs/abstract/Object.js +44 -0
  31. package/cjs/abstract/index.d.ts +3 -0
  32. package/cjs/abstract/index.js +9 -0
  33. package/cjs/base/Compact.d.ts +88 -0
  34. package/cjs/base/Compact.js +163 -0
  35. package/cjs/base/DoNotConstruct.d.ts +63 -0
  36. package/cjs/base/DoNotConstruct.js +99 -0
  37. package/cjs/base/Enum.d.ts +118 -0
  38. package/cjs/base/Enum.js +373 -0
  39. package/cjs/base/Int.d.ts +16 -0
  40. package/cjs/base/Int.js +30 -0
  41. package/cjs/base/Null.d.ts +56 -0
  42. package/cjs/base/Null.js +81 -0
  43. package/cjs/base/Option.d.ts +94 -0
  44. package/cjs/base/Option.js +236 -0
  45. package/cjs/base/Result.d.ts +38 -0
  46. package/cjs/base/Result.js +67 -0
  47. package/cjs/base/Tuple.d.ts +42 -0
  48. package/cjs/base/Tuple.js +114 -0
  49. package/cjs/base/UInt.d.ts +15 -0
  50. package/cjs/base/UInt.js +27 -0
  51. package/cjs/base/Vec.d.ts +28 -0
  52. package/cjs/base/Vec.js +107 -0
  53. package/cjs/base/VecAny.d.ts +15 -0
  54. package/cjs/base/VecAny.js +21 -0
  55. package/cjs/base/VecFixed.d.ts +30 -0
  56. package/cjs/base/VecFixed.js +71 -0
  57. package/cjs/base/index.d.ts +12 -0
  58. package/cjs/base/index.js +27 -0
  59. package/cjs/bundle.d.ts +7 -0
  60. package/cjs/bundle.js +12 -0
  61. package/cjs/extended/BTreeMap.js +14 -0
  62. package/cjs/extended/BTreeSet.js +189 -0
  63. package/cjs/extended/BitVec.js +112 -0
  64. package/cjs/extended/Bytes.js +74 -0
  65. package/cjs/extended/HashMap.js +14 -0
  66. package/cjs/extended/Linkage.js +70 -0
  67. package/cjs/extended/Map.js +204 -0
  68. package/cjs/extended/OptionBool.js +76 -0
  69. package/cjs/extended/Range.js +42 -0
  70. package/cjs/extended/RangeInclusive.js +17 -0
  71. package/cjs/extended/Type.js +25 -0
  72. package/cjs/extended/U8aFixed.js +46 -0
  73. package/cjs/extended/WrapperKeepOpaque.js +103 -0
  74. package/cjs/extended/WrapperOpaque.js +23 -0
  75. package/cjs/extended/index.js +32 -0
  76. package/cjs/index.js +5 -0
  77. package/cjs/native/Bool.js +113 -0
  78. package/cjs/native/Date.js +144 -0
  79. package/cjs/native/Float.js +111 -0
  80. package/cjs/native/Json.js +121 -0
  81. package/cjs/native/Raw.js +144 -0
  82. package/cjs/native/Set.js +219 -0
  83. package/cjs/native/Struct.data.js +4 -0
  84. package/cjs/native/Struct.js +264 -0
  85. package/cjs/native/Text.js +154 -0
  86. package/cjs/native/index.js +22 -0
  87. package/cjs/package.json +3 -0
  88. package/cjs/packageDetect.js +5 -0
  89. package/cjs/packageInfo.js +4 -0
  90. package/cjs/primitive/F32.js +14 -0
  91. package/cjs/primitive/F64.js +14 -0
  92. package/cjs/primitive/I128.js +14 -0
  93. package/cjs/primitive/I16.js +14 -0
  94. package/cjs/primitive/I256.js +14 -0
  95. package/cjs/primitive/I32.js +14 -0
  96. package/cjs/primitive/I64.js +14 -0
  97. package/cjs/primitive/I8.js +14 -0
  98. package/cjs/primitive/ISize.js +18 -0
  99. package/cjs/primitive/U128.js +14 -0
  100. package/cjs/primitive/U16.js +14 -0
  101. package/cjs/primitive/U256.js +14 -0
  102. package/cjs/primitive/U32.js +14 -0
  103. package/cjs/primitive/U64.js +14 -0
  104. package/cjs/primitive/U8.js +14 -0
  105. package/cjs/primitive/USize.js +18 -0
  106. package/cjs/primitive/index.js +51 -0
  107. package/{build → cjs}/types/codec.d.ts +1 -1
  108. package/cjs/types/codec.js +2 -0
  109. package/cjs/types/helpers.js +2 -0
  110. package/cjs/types/index.js +7 -0
  111. package/cjs/types/interfaces.js +2 -0
  112. package/cjs/types/registry.js +2 -0
  113. package/cjs/utils/compareArray.js +13 -0
  114. package/cjs/utils/compareMap.js +30 -0
  115. package/cjs/utils/compareSet.js +20 -0
  116. package/cjs/utils/decodeU8a.js +105 -0
  117. package/cjs/utils/index.js +25 -0
  118. package/cjs/utils/sanitize.js +233 -0
  119. package/cjs/utils/sortValues.js +84 -0
  120. package/cjs/utils/toConstructors.js +40 -0
  121. package/cjs/utils/typesToMap.js +10 -0
  122. package/cjs/utils/util.js +7 -0
  123. package/extended/BTreeMap.d.ts +5 -0
  124. package/extended/BTreeMap.js +10 -0
  125. package/extended/BTreeSet.d.ts +64 -0
  126. package/extended/BTreeSet.js +185 -0
  127. package/extended/BitVec.d.ts +37 -0
  128. package/extended/BitVec.js +108 -0
  129. package/extended/Bytes.d.ts +29 -0
  130. package/extended/Bytes.js +70 -0
  131. package/extended/HashMap.d.ts +5 -0
  132. package/extended/HashMap.js +10 -0
  133. package/extended/Linkage.d.ts +37 -0
  134. package/extended/Linkage.js +65 -0
  135. package/extended/Map.d.ts +59 -0
  136. package/extended/Map.js +200 -0
  137. package/extended/OptionBool.d.ts +36 -0
  138. package/extended/OptionBool.js +72 -0
  139. package/extended/Range.d.ts +29 -0
  140. package/extended/Range.js +38 -0
  141. package/extended/RangeInclusive.d.ts +6 -0
  142. package/extended/RangeInclusive.js +13 -0
  143. package/extended/Type.d.ts +16 -0
  144. package/extended/Type.js +21 -0
  145. package/extended/U8aFixed.d.ts +16 -0
  146. package/extended/U8aFixed.js +42 -0
  147. package/extended/WrapperKeepOpaque.d.ts +40 -0
  148. package/extended/WrapperKeepOpaque.js +99 -0
  149. package/extended/WrapperOpaque.d.ts +10 -0
  150. package/extended/WrapperOpaque.js +19 -0
  151. package/{src/extended/index.ts → extended/index.d.ts} +0 -3
  152. package/extended/index.js +14 -0
  153. package/index.d.ts +2 -0
  154. package/index.js +2 -0
  155. package/native/Bool.d.ts +71 -0
  156. package/native/Bool.js +109 -0
  157. package/native/Date.d.ts +84 -0
  158. package/native/Date.js +140 -0
  159. package/native/Float.d.ts +68 -0
  160. package/native/Float.js +107 -0
  161. package/native/Json.d.ts +69 -0
  162. package/native/Json.js +117 -0
  163. package/native/Raw.d.ts +87 -0
  164. package/native/Raw.js +140 -0
  165. package/native/Set.d.ts +84 -0
  166. package/native/Set.js +215 -0
  167. package/native/Struct.d.ts +106 -0
  168. package/{src/native/Struct.data.ts → native/Struct.data.js} +0 -3
  169. package/native/Struct.js +260 -0
  170. package/native/Text.d.ts +77 -0
  171. package/native/Text.js +150 -0
  172. package/{src/native/index.ts → native/index.d.ts} +0 -3
  173. package/native/index.js +8 -0
  174. package/package.json +1126 -11
  175. package/packageDetect.d.ts +1 -0
  176. package/packageDetect.js +3 -0
  177. package/packageInfo.d.ts +6 -0
  178. package/packageInfo.js +1 -0
  179. package/primitive/F32.d.ts +11 -0
  180. package/primitive/F32.js +10 -0
  181. package/primitive/F64.d.ts +11 -0
  182. package/primitive/F64.js +10 -0
  183. package/primitive/I128.d.ts +11 -0
  184. package/primitive/I128.js +10 -0
  185. package/primitive/I16.d.ts +11 -0
  186. package/primitive/I16.js +10 -0
  187. package/primitive/I256.d.ts +11 -0
  188. package/primitive/I256.js +10 -0
  189. package/primitive/I32.d.ts +11 -0
  190. package/primitive/I32.js +10 -0
  191. package/primitive/I64.d.ts +11 -0
  192. package/primitive/I64.js +10 -0
  193. package/primitive/I8.d.ts +11 -0
  194. package/primitive/I8.js +10 -0
  195. package/primitive/ISize.d.ts +12 -0
  196. package/primitive/ISize.js +14 -0
  197. package/primitive/U128.d.ts +11 -0
  198. package/primitive/U128.js +10 -0
  199. package/primitive/U16.d.ts +11 -0
  200. package/primitive/U16.js +10 -0
  201. package/primitive/U256.d.ts +11 -0
  202. package/primitive/U256.js +10 -0
  203. package/primitive/U32.d.ts +11 -0
  204. package/primitive/U32.js +10 -0
  205. package/primitive/U64.d.ts +11 -0
  206. package/primitive/U64.js +10 -0
  207. package/primitive/U8.d.ts +11 -0
  208. package/primitive/U8.js +10 -0
  209. package/primitive/USize.d.ts +12 -0
  210. package/primitive/USize.js +14 -0
  211. package/{src/primitive/index.ts → primitive/index.d.ts} +0 -3
  212. package/primitive/index.js +16 -0
  213. package/types/codec.d.ts +113 -0
  214. package/types/codec.js +1 -0
  215. package/{src/types/helpers.ts → types/helpers.d.ts} +8 -31
  216. package/types/helpers.js +1 -0
  217. package/{src/types/index.ts → types/index.d.ts} +0 -3
  218. package/types/index.js +4 -0
  219. package/types/interfaces.d.ts +74 -0
  220. package/types/interfaces.js +1 -0
  221. package/types/registry.d.ts +67 -0
  222. package/types/registry.js +1 -0
  223. package/utils/compareArray.d.ts +1 -0
  224. package/utils/compareArray.js +10 -0
  225. package/utils/compareMap.d.ts +1 -0
  226. package/utils/compareMap.js +27 -0
  227. package/utils/compareSet.d.ts +1 -0
  228. package/utils/compareSet.js +17 -0
  229. package/utils/decodeU8a.d.ts +26 -0
  230. package/utils/decodeU8a.js +100 -0
  231. package/{src/utils/index.ts → utils/index.d.ts} +0 -3
  232. package/utils/index.js +8 -0
  233. package/utils/sanitize.d.ts +15 -0
  234. package/utils/sanitize.js +219 -0
  235. package/utils/sortValues.d.ts +12 -0
  236. package/utils/sortValues.js +79 -0
  237. package/utils/toConstructors.d.ts +16 -0
  238. package/utils/toConstructors.js +35 -0
  239. package/utils/typesToMap.d.ts +2 -0
  240. package/utils/typesToMap.js +7 -0
  241. package/utils/util.d.ts +3 -0
  242. package/utils/util.js +4 -0
  243. package/src/abstract/Array.ts +0 -213
  244. package/src/abstract/Base.ts +0 -129
  245. package/src/abstract/Int.ts +0 -271
  246. package/src/abstract/Object.ts +0 -99
  247. package/src/base/Compact.spec.ts +0 -99
  248. package/src/base/Compact.ts +0 -198
  249. package/src/base/DoNotConstruct.spec.ts +0 -23
  250. package/src/base/DoNotConstruct.ts +0 -118
  251. package/src/base/Enum.spec.ts +0 -487
  252. package/src/base/Enum.ts +0 -460
  253. package/src/base/Int.spec.ts +0 -225
  254. package/src/base/Int.ts +0 -34
  255. package/src/base/Null.spec.ts +0 -41
  256. package/src/base/Null.ts +0 -96
  257. package/src/base/Option.spec.ts +0 -216
  258. package/src/base/Option.ts +0 -275
  259. package/src/base/Result.spec.ts +0 -64
  260. package/src/base/Result.ts +0 -79
  261. package/src/base/Tuple.spec.ts +0 -161
  262. package/src/base/Tuple.ts +0 -149
  263. package/src/base/UInt.spec.ts +0 -192
  264. package/src/base/UInt.ts +0 -30
  265. package/src/base/Vec.spec.ts +0 -224
  266. package/src/base/Vec.ts +0 -133
  267. package/src/base/VecAny.ts +0 -23
  268. package/src/base/VecFixed.spec.ts +0 -78
  269. package/src/base/VecFixed.ts +0 -92
  270. package/src/checkTypes.manual.ts +0 -12
  271. package/src/extended/BTreeMap.spec.ts +0 -245
  272. package/src/extended/BTreeMap.ts +0 -16
  273. package/src/extended/BTreeSet.spec.ts +0 -260
  274. package/src/extended/BTreeSet.ts +0 -233
  275. package/src/extended/BitVec.spec.ts +0 -97
  276. package/src/extended/BitVec.ts +0 -137
  277. package/src/extended/Bytes.spec.ts +0 -75
  278. package/src/extended/Bytes.ts +0 -88
  279. package/src/extended/HashMap.spec.ts +0 -36
  280. package/src/extended/HashMap.ts +0 -16
  281. package/src/extended/Linkage.spec.ts +0 -43
  282. package/src/extended/Linkage.ts +0 -81
  283. package/src/extended/Map.spec.ts +0 -123
  284. package/src/extended/Map.ts +0 -255
  285. package/src/extended/OptionBool.spec.ts +0 -49
  286. package/src/extended/OptionBool.ts +0 -93
  287. package/src/extended/Range.spec.ts +0 -37
  288. package/src/extended/Range.ts +0 -56
  289. package/src/extended/RangeInclusive.ts +0 -20
  290. package/src/extended/Type.spec.ts +0 -118
  291. package/src/extended/Type.ts +0 -29
  292. package/src/extended/U8aFixed.spec.ts +0 -117
  293. package/src/extended/U8aFixed.ts +0 -57
  294. package/src/extended/WrapperKeepOpaque.spec.ts +0 -101
  295. package/src/extended/WrapperKeepOpaque.ts +0 -128
  296. package/src/extended/WrapperOpaque.spec.ts +0 -58
  297. package/src/extended/WrapperOpaque.ts +0 -27
  298. package/src/index.ts +0 -6
  299. package/src/mod.ts +0 -4
  300. package/src/native/Bool.spec.ts +0 -74
  301. package/src/native/Bool.ts +0 -137
  302. package/src/native/Date.spec.ts +0 -85
  303. package/src/native/Date.ts +0 -169
  304. package/src/native/Float.spec.ts +0 -51
  305. package/src/native/Float.ts +0 -136
  306. package/src/native/Json.ts +0 -147
  307. package/src/native/Raw.spec.ts +0 -113
  308. package/src/native/Raw.ts +0 -171
  309. package/src/native/Set.spec.ts +0 -116
  310. package/src/native/Set.ts +0 -269
  311. package/src/native/Struct.spec.ts +0 -411
  312. package/src/native/Struct.ts +0 -338
  313. package/src/native/Text.spec.ts +0 -85
  314. package/src/native/Text.ts +0 -184
  315. package/src/packageDetect.ts +0 -11
  316. package/src/packageInfo.ts +0 -6
  317. package/src/primitive/F32.ts +0 -14
  318. package/src/primitive/F64.ts +0 -14
  319. package/src/primitive/I128.ts +0 -14
  320. package/src/primitive/I16.ts +0 -14
  321. package/src/primitive/I256.ts +0 -14
  322. package/src/primitive/I32.ts +0 -14
  323. package/src/primitive/I64.ts +0 -14
  324. package/src/primitive/I8.ts +0 -14
  325. package/src/primitive/ISize.ts +0 -21
  326. package/src/primitive/U128.ts +0 -14
  327. package/src/primitive/U16.ts +0 -14
  328. package/src/primitive/U256.ts +0 -14
  329. package/src/primitive/U32.ts +0 -14
  330. package/src/primitive/U64.ts +0 -14
  331. package/src/primitive/U8.ts +0 -14
  332. package/src/primitive/USize.ts +0 -21
  333. package/src/test/performance.ts +0 -61
  334. package/src/types/codec.ts +0 -140
  335. package/src/types/interfaces.ts +0 -98
  336. package/src/types/registry.ts +0 -86
  337. package/src/utils/compareArray.ts +0 -22
  338. package/src/utils/compareMap.ts +0 -40
  339. package/src/utils/compareSet.ts +0 -23
  340. package/src/utils/decodeU8a.ts +0 -123
  341. package/src/utils/sanitize.spec.ts +0 -89
  342. package/src/utils/sanitize.ts +0 -290
  343. package/src/utils/sortValues.ts +0 -103
  344. package/src/utils/toConstructors.ts +0 -46
  345. package/src/utils/typesToMap.ts +0 -14
  346. package/src/utils/util.ts +0 -8
  347. package/tsconfig.build.json +0 -16
  348. package/tsconfig.build.tsbuildinfo +0 -1
  349. package/tsconfig.spec.json +0 -21
  350. /package/{build/abstract → abstract}/Array.d.ts +0 -0
  351. /package/{build/abstract → abstract}/Base.d.ts +0 -0
  352. /package/{build/abstract → abstract}/Int.d.ts +0 -0
  353. /package/{build/abstract → abstract}/Object.d.ts +0 -0
  354. /package/{build/abstract → abstract}/index.d.ts +0 -0
  355. /package/{build/base → base}/Compact.d.ts +0 -0
  356. /package/{build/base → base}/DoNotConstruct.d.ts +0 -0
  357. /package/{build/base → base}/Enum.d.ts +0 -0
  358. /package/{build/base → base}/Null.d.ts +0 -0
  359. /package/{build/base → base}/Option.d.ts +0 -0
  360. /package/{build/base → base}/Result.d.ts +0 -0
  361. /package/{build/base → base}/Tuple.d.ts +0 -0
  362. /package/{build/base → base}/Vec.d.ts +0 -0
  363. /package/{build/base → base}/VecAny.d.ts +0 -0
  364. /package/{build/base → base}/VecFixed.d.ts +0 -0
  365. /package/{build/base → base}/index.d.ts +0 -0
  366. /package/{build/bundle.d.ts → bundle.d.ts} +0 -0
  367. /package/{build → cjs}/extended/BTreeMap.d.ts +0 -0
  368. /package/{build → cjs}/extended/BTreeSet.d.ts +0 -0
  369. /package/{build → cjs}/extended/BitVec.d.ts +0 -0
  370. /package/{build → cjs}/extended/Bytes.d.ts +0 -0
  371. /package/{build → cjs}/extended/HashMap.d.ts +0 -0
  372. /package/{build → cjs}/extended/Linkage.d.ts +0 -0
  373. /package/{build → cjs}/extended/Map.d.ts +0 -0
  374. /package/{build → cjs}/extended/OptionBool.d.ts +0 -0
  375. /package/{build → cjs}/extended/Range.d.ts +0 -0
  376. /package/{build → cjs}/extended/RangeInclusive.d.ts +0 -0
  377. /package/{build → cjs}/extended/Type.d.ts +0 -0
  378. /package/{build → cjs}/extended/U8aFixed.d.ts +0 -0
  379. /package/{build → cjs}/extended/WrapperKeepOpaque.d.ts +0 -0
  380. /package/{build → cjs}/extended/WrapperOpaque.d.ts +0 -0
  381. /package/{build → cjs}/extended/index.d.ts +0 -0
  382. /package/{build → cjs}/index.d.ts +0 -0
  383. /package/{build → cjs}/native/Bool.d.ts +0 -0
  384. /package/{build → cjs}/native/Date.d.ts +0 -0
  385. /package/{build → cjs}/native/Float.d.ts +0 -0
  386. /package/{build → cjs}/native/Json.d.ts +0 -0
  387. /package/{build → cjs}/native/Raw.d.ts +0 -0
  388. /package/{build → cjs}/native/Set.d.ts +0 -0
  389. /package/{build → cjs}/native/Struct.d.ts +0 -0
  390. /package/{build → cjs}/native/Text.d.ts +0 -0
  391. /package/{build → cjs}/native/index.d.ts +0 -0
  392. /package/{build → cjs}/packageDetect.d.ts +0 -0
  393. /package/{build → cjs}/packageInfo.d.ts +0 -0
  394. /package/{build → cjs}/primitive/F32.d.ts +0 -0
  395. /package/{build → cjs}/primitive/F64.d.ts +0 -0
  396. /package/{build → cjs}/primitive/I128.d.ts +0 -0
  397. /package/{build → cjs}/primitive/I16.d.ts +0 -0
  398. /package/{build → cjs}/primitive/I256.d.ts +0 -0
  399. /package/{build → cjs}/primitive/I32.d.ts +0 -0
  400. /package/{build → cjs}/primitive/I64.d.ts +0 -0
  401. /package/{build → cjs}/primitive/I8.d.ts +0 -0
  402. /package/{build → cjs}/primitive/ISize.d.ts +0 -0
  403. /package/{build → cjs}/primitive/U128.d.ts +0 -0
  404. /package/{build → cjs}/primitive/U16.d.ts +0 -0
  405. /package/{build → cjs}/primitive/U256.d.ts +0 -0
  406. /package/{build → cjs}/primitive/U32.d.ts +0 -0
  407. /package/{build → cjs}/primitive/U64.d.ts +0 -0
  408. /package/{build → cjs}/primitive/U8.d.ts +0 -0
  409. /package/{build → cjs}/primitive/USize.d.ts +0 -0
  410. /package/{build → cjs}/primitive/index.d.ts +0 -0
  411. /package/{build → cjs}/types/helpers.d.ts +0 -0
  412. /package/{build → cjs}/types/index.d.ts +0 -0
  413. /package/{build → cjs}/types/interfaces.d.ts +0 -0
  414. /package/{build → cjs}/types/registry.d.ts +0 -0
  415. /package/{build → cjs}/utils/compareArray.d.ts +0 -0
  416. /package/{build → cjs}/utils/compareMap.d.ts +0 -0
  417. /package/{build → cjs}/utils/compareSet.d.ts +0 -0
  418. /package/{build → cjs}/utils/decodeU8a.d.ts +0 -0
  419. /package/{build → cjs}/utils/index.d.ts +0 -0
  420. /package/{build → cjs}/utils/sanitize.d.ts +0 -0
  421. /package/{build → cjs}/utils/sortValues.d.ts +0 -0
  422. /package/{build → cjs}/utils/toConstructors.d.ts +0 -0
  423. /package/{build → cjs}/utils/typesToMap.d.ts +0 -0
  424. /package/{build → cjs}/utils/util.d.ts +0 -0
@@ -0,0 +1,40 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.typeToConstructor = typeToConstructor;
4
+ exports.typesToConstructors = typesToConstructors;
5
+ exports.mapToTypeMap = mapToTypeMap;
6
+ /**
7
+ * @internal
8
+ * From a type string or class, return the associated type class
9
+ */
10
+ function typeToConstructor(registry, type) {
11
+ return typeof type === 'function'
12
+ ? type
13
+ : registry.createClassUnsafe(type);
14
+ }
15
+ /**
16
+ * @internal
17
+ * Takes an input array of types and returns the associated classes for it
18
+ */
19
+ function typesToConstructors(registry, types) {
20
+ const count = types.length;
21
+ const result = new Array(count);
22
+ for (let i = 0; i < count; i++) {
23
+ result[i] = typeToConstructor(registry, types[i]);
24
+ }
25
+ return result;
26
+ }
27
+ /**
28
+ * @internal
29
+ * Takes an input map of the form `{ [string]: string | CodecClass }` and returns a map of `{ [string]: CodecClass }`
30
+ */
31
+ function mapToTypeMap(registry, input) {
32
+ const entries = Object.entries(input);
33
+ const count = entries.length;
34
+ const output = [new Array(count), new Array(count)];
35
+ for (let i = 0; i < count; i++) {
36
+ output[1][i] = entries[i][0];
37
+ output[0][i] = typeToConstructor(registry, entries[i][1]);
38
+ }
39
+ return output;
40
+ }
@@ -0,0 +1,10 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.typesToMap = typesToMap;
4
+ function typesToMap(registry, [Types, keys]) {
5
+ const result = {};
6
+ for (let i = 0, count = keys.length; i < count; i++) {
7
+ result[keys[i]] = registry.getClassName(Types[i]) || new Types[i](registry).toRawType();
8
+ }
9
+ return result;
10
+ }
@@ -0,0 +1,7 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.hasEq = hasEq;
4
+ const util_1 = require("@pezkuwi/util");
5
+ function hasEq(o) {
6
+ return (0, util_1.isFunction)(o.eq);
7
+ }
@@ -0,0 +1,5 @@
1
+ import type { Codec, CodecClass } from '../types/index.js';
2
+ import { CodecMap } from './Map.js';
3
+ export declare class BTreeMap<K extends Codec = Codec, V extends Codec = Codec> extends CodecMap<K, V> {
4
+ static with<K extends Codec, V extends Codec>(keyType: CodecClass<K> | string, valType: CodecClass<V> | string): CodecClass<CodecMap<K, V>>;
5
+ }
@@ -0,0 +1,10 @@
1
+ import { CodecMap } from './Map.js';
2
+ export class BTreeMap extends CodecMap {
3
+ static with(keyType, valType) {
4
+ return class extends BTreeMap {
5
+ constructor(registry, value) {
6
+ super(registry, keyType, valType, value, 'BTreeMap');
7
+ }
8
+ };
9
+ }
10
+ }
@@ -0,0 +1,64 @@
1
+ import type { HexString } from '@pezkuwi/util/types';
2
+ import type { AnyJson, Codec, CodecClass, Inspect, ISet, IU8a, Registry } from '../types/index.js';
3
+ export declare class BTreeSet<V extends Codec = Codec> extends Set<V> implements ISet<V> {
4
+ #private;
5
+ readonly registry: Registry;
6
+ createdAtHash?: IU8a;
7
+ initialU8aLength?: number;
8
+ isStorageFallback?: boolean;
9
+ constructor(registry: Registry, valType: CodecClass<V> | string, rawValue?: Uint8Array | string | string[] | Set<any>);
10
+ static with<V extends Codec>(valType: CodecClass<V> | string): CodecClass<BTreeSet<V>>;
11
+ /**
12
+ * @description The length of the value when encoded as a Uint8Array
13
+ */
14
+ get encodedLength(): number;
15
+ /**
16
+ * @description Returns a hash of the value
17
+ */
18
+ get hash(): IU8a;
19
+ /**
20
+ * @description Checks if the value is an empty value
21
+ */
22
+ get isEmpty(): boolean;
23
+ /**
24
+ * @description The actual set values as a string[]
25
+ */
26
+ get strings(): string[];
27
+ /**
28
+ * @description Compares the value of the input to see if there is a match
29
+ */
30
+ eq(other?: unknown): boolean;
31
+ /**
32
+ * @description Returns a breakdown of the hex encoding for this Codec
33
+ */
34
+ inspect(): Inspect;
35
+ /**
36
+ * @description Returns a hex string representation of the value. isLe returns a LE (number-only) representation
37
+ */
38
+ toHex(): HexString;
39
+ /**
40
+ * @description Converts the Object to to a human-friendly JSON, with additional fields, expansion and formatting of information
41
+ */
42
+ toHuman(isExtended?: boolean, disableAscii?: boolean): AnyJson;
43
+ /**
44
+ * @description Converts the Object to JSON, typically used for RPC transfers
45
+ */
46
+ toJSON(): AnyJson;
47
+ /**
48
+ * @description Returns the base runtime type name for this instance
49
+ */
50
+ toRawType(): string;
51
+ /**
52
+ * @description Converts the value in a best-fit primitive form
53
+ */
54
+ toPrimitive(disableAscii?: boolean): AnyJson;
55
+ /**
56
+ * @description Returns the string representation of the value
57
+ */
58
+ toString(): string;
59
+ /**
60
+ * @description Encodes the value as a Uint8Array as per the SCALE specifications
61
+ * @param isBare true when the value has none of the type-specific prefixes (internal)
62
+ */
63
+ toU8a(isBare?: boolean): Uint8Array;
64
+ }
@@ -0,0 +1,185 @@
1
+ import { compactFromU8aLim, compactToU8a, isHex, isU8a, logger, stringify, u8aConcatStrict, u8aToHex, u8aToU8a } from '@pezkuwi/util';
2
+ import { compareSet, decodeU8aVec, sortSet, typeToConstructor } from '../utils/index.js';
3
+ const l = logger('BTreeSet');
4
+ /** @internal */
5
+ function decodeSetFromU8a(registry, ValClass, u8a) {
6
+ const output = new Set();
7
+ const [offset, count] = compactFromU8aLim(u8a);
8
+ const result = new Array(count);
9
+ const [decodedLength] = decodeU8aVec(registry, result, u8a, offset, ValClass);
10
+ for (let i = 0; i < count; i++) {
11
+ output.add(result[i]);
12
+ }
13
+ return [ValClass, output, decodedLength];
14
+ }
15
+ /** @internal */
16
+ function decodeSetFromSet(registry, ValClass, value) {
17
+ const output = new Set();
18
+ value.forEach((val) => {
19
+ try {
20
+ output.add((val instanceof ValClass) ? val : new ValClass(registry, val));
21
+ }
22
+ catch (error) {
23
+ l.error('Failed to decode key or value:', error.message);
24
+ throw error;
25
+ }
26
+ });
27
+ return [ValClass, output, 0];
28
+ }
29
+ /**
30
+ * Decode input to pass into constructor.
31
+ *
32
+ * @param ValClass - Type of the map value
33
+ * @param value - Value to decode, one of:
34
+ * - null
35
+ * - undefined
36
+ * - hex
37
+ * - Uint8Array
38
+ * - Set<any>, where both key and value types are either
39
+ * constructors or decodeable values for their types.
40
+ * @param jsonSet
41
+ * @internal
42
+ */
43
+ function decodeSet(registry, valType, value) {
44
+ const ValClass = typeToConstructor(registry, valType);
45
+ if (!value) {
46
+ return [ValClass, new Set(), 0];
47
+ }
48
+ else if (isU8a(value) || isHex(value)) {
49
+ return decodeSetFromU8a(registry, ValClass, u8aToU8a(value));
50
+ }
51
+ else if (Array.isArray(value) || value instanceof Set) {
52
+ return decodeSetFromSet(registry, ValClass, value);
53
+ }
54
+ throw new Error('BTreeSet: cannot decode type');
55
+ }
56
+ export class BTreeSet extends Set {
57
+ registry;
58
+ createdAtHash;
59
+ initialU8aLength;
60
+ isStorageFallback;
61
+ #ValClass;
62
+ constructor(registry, valType, rawValue) {
63
+ const [ValClass, values, decodedLength] = decodeSet(registry, valType, rawValue);
64
+ super(sortSet(values));
65
+ this.registry = registry;
66
+ this.initialU8aLength = decodedLength;
67
+ this.#ValClass = ValClass;
68
+ }
69
+ static with(valType) {
70
+ return class extends BTreeSet {
71
+ constructor(registry, value) {
72
+ super(registry, valType, value);
73
+ }
74
+ };
75
+ }
76
+ /**
77
+ * @description The length of the value when encoded as a Uint8Array
78
+ */
79
+ get encodedLength() {
80
+ let len = compactToU8a(this.size).length;
81
+ for (const v of this.values()) {
82
+ len += v.encodedLength;
83
+ }
84
+ return len;
85
+ }
86
+ /**
87
+ * @description Returns a hash of the value
88
+ */
89
+ get hash() {
90
+ return this.registry.hash(this.toU8a());
91
+ }
92
+ /**
93
+ * @description Checks if the value is an empty value
94
+ */
95
+ get isEmpty() {
96
+ return this.size === 0;
97
+ }
98
+ /**
99
+ * @description The actual set values as a string[]
100
+ */
101
+ get strings() {
102
+ return [...super.values()].map((v) => v.toString());
103
+ }
104
+ /**
105
+ * @description Compares the value of the input to see if there is a match
106
+ */
107
+ eq(other) {
108
+ return compareSet(this, other);
109
+ }
110
+ /**
111
+ * @description Returns a breakdown of the hex encoding for this Codec
112
+ */
113
+ inspect() {
114
+ const inner = [];
115
+ for (const v of this.values()) {
116
+ inner.push(v.inspect());
117
+ }
118
+ return {
119
+ inner,
120
+ outer: [compactToU8a(this.size)]
121
+ };
122
+ }
123
+ /**
124
+ * @description Returns a hex string representation of the value. isLe returns a LE (number-only) representation
125
+ */
126
+ toHex() {
127
+ return u8aToHex(this.toU8a());
128
+ }
129
+ /**
130
+ * @description Converts the Object to to a human-friendly JSON, with additional fields, expansion and formatting of information
131
+ */
132
+ toHuman(isExtended, disableAscii) {
133
+ const json = [];
134
+ for (const v of this.values()) {
135
+ json.push(v.toHuman(isExtended, disableAscii));
136
+ }
137
+ return json;
138
+ }
139
+ /**
140
+ * @description Converts the Object to JSON, typically used for RPC transfers
141
+ */
142
+ toJSON() {
143
+ const json = [];
144
+ for (const v of this.values()) {
145
+ json.push(v.toJSON());
146
+ }
147
+ return json;
148
+ }
149
+ /**
150
+ * @description Returns the base runtime type name for this instance
151
+ */
152
+ toRawType() {
153
+ return `BTreeSet<${this.registry.getClassName(this.#ValClass) || new this.#ValClass(this.registry).toRawType()}>`;
154
+ }
155
+ /**
156
+ * @description Converts the value in a best-fit primitive form
157
+ */
158
+ toPrimitive(disableAscii) {
159
+ const json = [];
160
+ for (const v of this.values()) {
161
+ json.push(v.toPrimitive(disableAscii));
162
+ }
163
+ return json;
164
+ }
165
+ /**
166
+ * @description Returns the string representation of the value
167
+ */
168
+ toString() {
169
+ return stringify(this.toJSON());
170
+ }
171
+ /**
172
+ * @description Encodes the value as a Uint8Array as per the SCALE specifications
173
+ * @param isBare true when the value has none of the type-specific prefixes (internal)
174
+ */
175
+ toU8a(isBare) {
176
+ const encoded = [];
177
+ if (!isBare) {
178
+ encoded.push(compactToU8a(this.size));
179
+ }
180
+ for (const v of this.values()) {
181
+ encoded.push(v.toU8a(isBare));
182
+ }
183
+ return u8aConcatStrict(encoded);
184
+ }
185
+ }
@@ -0,0 +1,37 @@
1
+ import type { AnyU8a, Inspect, Registry } from '../types/index.js';
2
+ import { Raw } from '../native/Raw.js';
3
+ /**
4
+ * @name BitVec
5
+ * @description
6
+ * A BitVec that represents an array of bits. The bits are however stored encoded. The difference between this
7
+ * and a normal Bytes would be that the length prefix indicates the number of bits encoded, not the bytes
8
+ */
9
+ export declare class BitVec extends Raw {
10
+ #private;
11
+ constructor(registry: Registry, value?: AnyU8a, isMsb?: boolean);
12
+ /**
13
+ * @description The length of the value when encoded as a Uint8Array
14
+ */
15
+ get encodedLength(): number;
16
+ /**
17
+ * @description Returns a breakdown of the hex encoding for this Codec
18
+ */
19
+ inspect(): Inspect;
20
+ /**
21
+ * @description Creates a boolean array of the bit values
22
+ */
23
+ toBoolArray(): boolean[];
24
+ /**
25
+ * @description Converts the Object to to a human-friendly JSON, with additional fields, expansion and formatting of information
26
+ */
27
+ toHuman(): string;
28
+ /**
29
+ * @description Returns the base runtime type name for this instance
30
+ */
31
+ toRawType(): string;
32
+ /**
33
+ * @description Encodes the value as a Uint8Array as per the SCALE specifications
34
+ * @param isBare true when the value has none of the type-specific prefixes (internal)
35
+ */
36
+ toU8a(isBare?: boolean): Uint8Array;
37
+ }
@@ -0,0 +1,108 @@
1
+ import { compactFromU8aLim, compactToU8a, isString, u8aConcatStrict, u8aToU8a } from '@pezkuwi/util';
2
+ import { Raw } from '../native/Raw.js';
3
+ /** @internal */
4
+ function decodeBitVecU8a(value) {
5
+ if (!value?.length) {
6
+ return [0, new Uint8Array()];
7
+ }
8
+ // handle all other Uint8Array inputs, these do have a length prefix which is the number of bits encoded
9
+ const [offset, length] = compactFromU8aLim(value);
10
+ const total = offset + Math.ceil(length / 8);
11
+ if (total > value.length) {
12
+ throw new Error(`BitVec: required length less than remainder, expected at least ${total}, found ${value.length}`);
13
+ }
14
+ return [length, value.subarray(offset, total)];
15
+ }
16
+ /** @internal */
17
+ function decodeBitVec(value) {
18
+ if (Array.isArray(value) || isString(value)) {
19
+ const u8a = u8aToU8a(value);
20
+ return [u8a.length * 8, u8a];
21
+ }
22
+ return decodeBitVecU8a(value);
23
+ }
24
+ /**
25
+ * @name BitVec
26
+ * @description
27
+ * A BitVec that represents an array of bits. The bits are however stored encoded. The difference between this
28
+ * and a normal Bytes would be that the length prefix indicates the number of bits encoded, not the bytes
29
+ */
30
+ export class BitVec extends Raw {
31
+ #decodedLength;
32
+ #isMsb;
33
+ // In lieu of having the Msb/Lsb identifiers passed through, we default to assuming
34
+ // we are dealing with Lsb, which is the default (as of writing) BitVec format used
35
+ // in the Pezkuwi code (this only affects the toHuman displays)
36
+ constructor(registry, value, isMsb = false) {
37
+ const [decodedLength, u8a] = decodeBitVec(value);
38
+ super(registry, u8a);
39
+ this.#decodedLength = decodedLength;
40
+ this.#isMsb = isMsb;
41
+ }
42
+ /**
43
+ * @description The length of the value when encoded as a Uint8Array
44
+ */
45
+ get encodedLength() {
46
+ return this.length + compactToU8a(this.#decodedLength).length;
47
+ }
48
+ /**
49
+ * @description Returns a breakdown of the hex encoding for this Codec
50
+ */
51
+ inspect() {
52
+ return {
53
+ outer: [compactToU8a(this.#decodedLength), super.toU8a()]
54
+ };
55
+ }
56
+ /**
57
+ * @description Creates a boolean array of the bit values
58
+ */
59
+ toBoolArray() {
60
+ const map = [...this.toU8a(true)].map((v) => [
61
+ !!(v & 0b1000_0000),
62
+ !!(v & 0b0100_0000),
63
+ !!(v & 0b0010_0000),
64
+ !!(v & 0b0001_0000),
65
+ !!(v & 0b0000_1000),
66
+ !!(v & 0b0000_0100),
67
+ !!(v & 0b0000_0010),
68
+ !!(v & 0b0000_0001)
69
+ ]);
70
+ const count = map.length;
71
+ const result = new Array(8 * count);
72
+ for (let i = 0; i < count; i++) {
73
+ const off = i * 8;
74
+ const v = map[i];
75
+ for (let j = 0; j < 8; j++) {
76
+ result[off + j] = this.#isMsb
77
+ ? v[j]
78
+ : v[7 - j];
79
+ }
80
+ }
81
+ return result;
82
+ }
83
+ /**
84
+ * @description Converts the Object to to a human-friendly JSON, with additional fields, expansion and formatting of information
85
+ */
86
+ toHuman() {
87
+ return `0b${[...this.toU8a(true)]
88
+ .map((d) => `00000000${d.toString(2)}`.slice(-8))
89
+ .map((s) => this.#isMsb ? s : s.split('').reverse().join(''))
90
+ .join('_')}`;
91
+ }
92
+ /**
93
+ * @description Returns the base runtime type name for this instance
94
+ */
95
+ toRawType() {
96
+ return 'BitVec';
97
+ }
98
+ /**
99
+ * @description Encodes the value as a Uint8Array as per the SCALE specifications
100
+ * @param isBare true when the value has none of the type-specific prefixes (internal)
101
+ */
102
+ toU8a(isBare) {
103
+ const bitVec = super.toU8a(isBare);
104
+ return isBare
105
+ ? bitVec
106
+ : u8aConcatStrict([compactToU8a(this.#decodedLength), bitVec]);
107
+ }
108
+ }
@@ -0,0 +1,29 @@
1
+ import type { AnyU8a, Inspect, Registry } from '../types/index.js';
2
+ import { Raw } from '../native/Raw.js';
3
+ /**
4
+ * @name Bytes
5
+ * @description
6
+ * A Bytes wrapper for Vec<u8>. The significant difference between this and a normal Uint8Array
7
+ * is that this version allows for length-encoding. (i.e. it is a variable-item codec, the same
8
+ * as what is found in [[Text]] and [[Vec]])
9
+ */
10
+ export declare class Bytes extends Raw {
11
+ constructor(registry: Registry, value?: AnyU8a);
12
+ /**
13
+ * @description The length of the value when encoded as a Uint8Array
14
+ */
15
+ get encodedLength(): number;
16
+ /**
17
+ * @description Returns a breakdown of the hex encoding for this Codec
18
+ */
19
+ inspect(isBare?: boolean): Inspect;
20
+ /**
21
+ * @description Returns the base runtime type name for this instance
22
+ */
23
+ toRawType(): string;
24
+ /**
25
+ * @description Encodes the value as a Uint8Array as per the SCALE specifications
26
+ * @param isBare true when the value has none of the type-specific prefixes (internal)
27
+ */
28
+ toU8a(isBare?: boolean): Uint8Array;
29
+ }
@@ -0,0 +1,70 @@
1
+ import { compactAddLength, compactFromU8aLim, compactToU8a, isString, isU8a, u8aToU8a } from '@pezkuwi/util';
2
+ import { Raw } from '../native/Raw.js';
3
+ const MAX_LENGTH = 10 * 1024 * 1024;
4
+ /** @internal */
5
+ function decodeBytesU8a(value) {
6
+ if (!value.length) {
7
+ return [new Uint8Array(), 0];
8
+ }
9
+ // handle all other Uint8Array inputs, these do have a length prefix
10
+ const [offset, length] = compactFromU8aLim(value);
11
+ const total = offset + length;
12
+ if (length > MAX_LENGTH) {
13
+ throw new Error(`Bytes length ${length.toString()} exceeds ${MAX_LENGTH}`);
14
+ }
15
+ else if (total > value.length) {
16
+ throw new Error(`Bytes: required length less than remainder, expected at least ${total}, found ${value.length}`);
17
+ }
18
+ return [value.subarray(offset, total), total];
19
+ }
20
+ /**
21
+ * @name Bytes
22
+ * @description
23
+ * A Bytes wrapper for Vec<u8>. The significant difference between this and a normal Uint8Array
24
+ * is that this version allows for length-encoding. (i.e. it is a variable-item codec, the same
25
+ * as what is found in [[Text]] and [[Vec]])
26
+ */
27
+ export class Bytes extends Raw {
28
+ constructor(registry, value) {
29
+ const [u8a, decodedLength] = isU8a(value) && !(value instanceof Raw)
30
+ ? decodeBytesU8a(value)
31
+ : Array.isArray(value) || isString(value)
32
+ ? [u8aToU8a(value), 0]
33
+ : [value, 0];
34
+ super(registry, u8a, decodedLength);
35
+ }
36
+ /**
37
+ * @description The length of the value when encoded as a Uint8Array
38
+ */
39
+ get encodedLength() {
40
+ return this.length + compactToU8a(this.length).length;
41
+ }
42
+ /**
43
+ * @description Returns a breakdown of the hex encoding for this Codec
44
+ */
45
+ inspect(isBare) {
46
+ const clength = compactToU8a(this.length);
47
+ return {
48
+ outer: isBare
49
+ ? [super.toU8a()]
50
+ : this.length
51
+ ? [clength, super.toU8a()]
52
+ : [clength]
53
+ };
54
+ }
55
+ /**
56
+ * @description Returns the base runtime type name for this instance
57
+ */
58
+ toRawType() {
59
+ return 'Bytes';
60
+ }
61
+ /**
62
+ * @description Encodes the value as a Uint8Array as per the SCALE specifications
63
+ * @param isBare true when the value has none of the type-specific prefixes (internal)
64
+ */
65
+ toU8a(isBare) {
66
+ return isBare
67
+ ? super.toU8a(isBare)
68
+ : compactAddLength(this);
69
+ }
70
+ }
@@ -0,0 +1,5 @@
1
+ import type { Codec, CodecClass } from '../types/index.js';
2
+ import { CodecMap } from './Map.js';
3
+ export declare class HashMap<K extends Codec = Codec, V extends Codec = Codec> extends CodecMap<K, V> {
4
+ static with<K extends Codec, V extends Codec>(keyType: CodecClass<K> | string, valType: CodecClass<V> | string): CodecClass<CodecMap<K, V>>;
5
+ }
@@ -0,0 +1,10 @@
1
+ import { CodecMap } from './Map.js';
2
+ export class HashMap extends CodecMap {
3
+ static with(keyType, valType) {
4
+ return class extends HashMap {
5
+ constructor(registry, value) {
6
+ super(registry, keyType, valType, value);
7
+ }
8
+ };
9
+ }
10
+ }
@@ -0,0 +1,37 @@
1
+ import type { Codec, CodecClass, Registry } from '../types/index.js';
2
+ import { Option } from '../base/Option.js';
3
+ import { Tuple } from '../base/Tuple.js';
4
+ import { Struct } from '../native/Struct.js';
5
+ type TypeWithValues = [CodecClass, any[]];
6
+ /**
7
+ * @name Linkage
8
+ * @description The wrapper for the result from a LinkedMap
9
+ */
10
+ export declare class Linkage<T extends Codec> extends Struct {
11
+ constructor(registry: Registry, Type: CodecClass | string, value?: unknown);
12
+ static withKey<O extends Codec>(Type: CodecClass | string): CodecClass<Linkage<O>>;
13
+ /**
14
+ * @description Returns the next item the Linkage is pointing to
15
+ */
16
+ get previous(): Option<T>;
17
+ /**
18
+ * @description Returns the previous item the Linkage is pointing to
19
+ */
20
+ get next(): Option<T>;
21
+ /**
22
+ * @description Returns the base runtime type name for this instance
23
+ */
24
+ toRawType(): string;
25
+ /**
26
+ * @description Custom toU8a which with bare mode does not return the linkage if empty
27
+ */
28
+ toU8a(isBare?: boolean): Uint8Array;
29
+ }
30
+ /**
31
+ * @name LinkageResult
32
+ * @description A Linkage keys/Values tuple
33
+ */
34
+ export declare class LinkageResult extends Tuple {
35
+ constructor(registry: Registry, [TypeKey, keys]: TypeWithValues, [TypeValue, values]: TypeWithValues);
36
+ }
37
+ export {};