@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,99 @@
1
+ import { compactAddLength, compactStripLength, compactToU8a, isHex, isU8a, u8aToU8a } from '@pezkuwi/util';
2
+ import { Raw } from '../native/Raw.js';
3
+ import { typeToConstructor } from '../utils/index.js';
4
+ import { Bytes } from './Bytes.js';
5
+ function decodeRaw(registry, typeName, value) {
6
+ const Type = typeToConstructor(registry, typeName);
7
+ if (isU8a(value) || isHex(value)) {
8
+ try {
9
+ const [, u8a] = isHex(value)
10
+ ? [0, u8aToU8a(value)]
11
+ : (value instanceof Raw)
12
+ ? [0, value.subarray()]
13
+ : compactStripLength(value);
14
+ return [Type, new Type(registry, u8a), value];
15
+ }
16
+ catch {
17
+ return [Type, null, value];
18
+ }
19
+ }
20
+ const instance = new Type(registry, value);
21
+ return [Type, instance, compactAddLength(instance.toU8a())];
22
+ }
23
+ export class WrapperKeepOpaque extends Bytes {
24
+ #Type;
25
+ #decoded;
26
+ #opaqueName;
27
+ constructor(registry, typeName, value, { opaqueName = 'WrapperKeepOpaque' } = {}) {
28
+ const [Type, decoded, u8a] = decodeRaw(registry, typeName, value);
29
+ super(registry, u8a);
30
+ this.#Type = Type;
31
+ this.#decoded = decoded;
32
+ this.#opaqueName = opaqueName;
33
+ }
34
+ static with(Type) {
35
+ return class extends WrapperKeepOpaque {
36
+ constructor(registry, value) {
37
+ super(registry, Type, value);
38
+ }
39
+ };
40
+ }
41
+ /**
42
+ * @description Checks if the wrapper is decodable
43
+ */
44
+ get isDecoded() {
45
+ return !!this.#decoded;
46
+ }
47
+ /**
48
+ * @description Returns a breakdown of the hex encoding for this Codec
49
+ */
50
+ inspect() {
51
+ return this.#decoded
52
+ ? {
53
+ inner: [this.#decoded.inspect()],
54
+ outer: [compactToU8a(this.length)]
55
+ }
56
+ : {
57
+ outer: [compactToU8a(this.length), this.toU8a(true)]
58
+ };
59
+ }
60
+ /**
61
+ * @description Converts the Object to to a human-friendly JSON, with additional fields, expansion and formatting of information
62
+ */
63
+ toHuman(isExtended, disableAscii) {
64
+ return this.#decoded
65
+ ? this.#decoded.toHuman(isExtended, disableAscii)
66
+ : super.toHuman(isExtended, disableAscii);
67
+ }
68
+ /**
69
+ * @description Converts the value in a best-fit primitive form
70
+ */
71
+ toPrimitive(disableAscii) {
72
+ return this.#decoded
73
+ ? this.#decoded.toPrimitive(disableAscii)
74
+ : super.toPrimitive(disableAscii);
75
+ }
76
+ /**
77
+ * @description Returns the base runtime type name for this instance
78
+ */
79
+ toRawType() {
80
+ return `${this.#opaqueName}<${this.registry.getClassName(this.#Type) || (this.#decoded ? this.#decoded.toRawType() : new this.#Type(this.registry).toRawType())}>`;
81
+ }
82
+ /**
83
+ * @description Converts the Object to to a string (either decoded or bytes)
84
+ */
85
+ toString() {
86
+ return this.#decoded
87
+ ? this.#decoded.toString()
88
+ : super.toString();
89
+ }
90
+ /**
91
+ * @description Returns the decoded that the WrapperKeepOpaque represents (if available), throws if non-decodable
92
+ */
93
+ unwrap() {
94
+ if (!this.#decoded) {
95
+ throw new Error(`${this.#opaqueName}: unwrapping an undecodable value`);
96
+ }
97
+ return this.#decoded;
98
+ }
99
+ }
@@ -0,0 +1,10 @@
1
+ import type { Codec, CodecClass, Registry } from '../types/index.js';
2
+ import { WrapperKeepOpaque } from './WrapperKeepOpaque.js';
3
+ export declare class WrapperOpaque<T extends Codec> extends WrapperKeepOpaque<T> {
4
+ constructor(registry: Registry, typeName: CodecClass<T> | string, value?: unknown);
5
+ static with<T extends Codec>(Type: CodecClass<T> | string): CodecClass<WrapperKeepOpaque<T>>;
6
+ /**
7
+ * @description The inner value for this wrapper, in all cases it _should_ be decodable (unlike KeepOpaque)
8
+ */
9
+ get inner(): T;
10
+ }
@@ -0,0 +1,19 @@
1
+ import { WrapperKeepOpaque } from './WrapperKeepOpaque.js';
2
+ export class WrapperOpaque extends WrapperKeepOpaque {
3
+ constructor(registry, typeName, value) {
4
+ super(registry, typeName, value, { opaqueName: 'WrapperOpaque' });
5
+ }
6
+ static with(Type) {
7
+ return class extends WrapperOpaque {
8
+ constructor(registry, value) {
9
+ super(registry, Type, value);
10
+ }
11
+ };
12
+ }
13
+ /**
14
+ * @description The inner value for this wrapper, in all cases it _should_ be decodable (unlike KeepOpaque)
15
+ */
16
+ get inner() {
17
+ return this.unwrap();
18
+ }
19
+ }
@@ -1,6 +1,3 @@
1
- // Copyright 2017-2025 @polkadot/types-codec authors & contributors
2
- // SPDX-License-Identifier: Apache-2.0
3
-
4
1
  export { BitVec } from './BitVec.js';
5
2
  export { BTreeMap } from './BTreeMap.js';
6
3
  export { BTreeSet } from './BTreeSet.js';
@@ -0,0 +1,14 @@
1
+ export { BitVec } from './BitVec.js';
2
+ export { BTreeMap } from './BTreeMap.js';
3
+ export { BTreeSet } from './BTreeSet.js';
4
+ export { Bytes } from './Bytes.js';
5
+ export { HashMap } from './HashMap.js';
6
+ export { Linkage } from './Linkage.js';
7
+ export { CodecMap, CodecMap as Map } from './Map.js';
8
+ export { OptionBool } from './OptionBool.js';
9
+ export { Range } from './Range.js';
10
+ export { RangeInclusive } from './RangeInclusive.js';
11
+ export { Type } from './Type.js';
12
+ export { U8aFixed } from './U8aFixed.js';
13
+ export { WrapperKeepOpaque } from './WrapperKeepOpaque.js';
14
+ export { WrapperOpaque } from './WrapperOpaque.js';
package/index.d.ts ADDED
@@ -0,0 +1,2 @@
1
+ import './packageDetect.js';
2
+ export * from './bundle.js';
package/index.js ADDED
@@ -0,0 +1,2 @@
1
+ import './packageDetect.js';
2
+ export * from './bundle.js';
@@ -0,0 +1,71 @@
1
+ import type { HexString } from '@pezkuwi/util/types';
2
+ import type { AnyBool, Codec, Inspect, IU8a, Registry } from '../types/index.js';
3
+ /**
4
+ * @name bool
5
+ * @description
6
+ * Representation for a boolean value in the system. It extends the base JS `Boolean` class
7
+ * @noInheritDoc
8
+ */
9
+ export declare class bool extends Boolean implements Codec {
10
+ readonly registry: Registry;
11
+ createdAtHash?: IU8a;
12
+ initialU8aLength: number;
13
+ isStorageFallback?: boolean;
14
+ constructor(registry: Registry, value?: bool | AnyBool | Uint8Array | number);
15
+ /**
16
+ * @description The length of the value when encoded as a Uint8Array
17
+ */
18
+ get encodedLength(): number;
19
+ /**
20
+ * @description returns a hash of the contents
21
+ */
22
+ get hash(): IU8a;
23
+ /**
24
+ * @description Checks if the value is an empty value (true when it wraps false/default)
25
+ */
26
+ get isEmpty(): boolean;
27
+ /**
28
+ * @description Checks if the value is an empty value (always false)
29
+ */
30
+ get isFalse(): boolean;
31
+ /**
32
+ * @description Checks if the value is an empty value (always false)
33
+ */
34
+ get isTrue(): boolean;
35
+ /**
36
+ * @description Compares the value of the input to see if there is a match
37
+ */
38
+ eq(other?: unknown): boolean;
39
+ /**
40
+ * @description Returns a breakdown of the hex encoding for this Codec
41
+ */
42
+ inspect(): Inspect;
43
+ /**
44
+ * @description Returns a hex string representation of the value
45
+ */
46
+ toHex(): HexString;
47
+ /**
48
+ * @description Converts the Object to to a human-friendly JSON, with additional fields, expansion and formatting of information
49
+ */
50
+ toHuman(): boolean;
51
+ /**
52
+ * @description Converts the Object to JSON, typically used for RPC transfers
53
+ */
54
+ toJSON(): boolean;
55
+ /**
56
+ * @description Converts the value in a best-fit primitive form
57
+ */
58
+ toPrimitive(): boolean;
59
+ /**
60
+ * @description Returns the base runtime type name for this instance
61
+ */
62
+ toRawType(): string;
63
+ /**
64
+ * @description Returns the string representation of the value
65
+ */
66
+ toString(): string;
67
+ /**
68
+ * @description Encodes the value as a Uint8Array as per the SCALE specifications
69
+ */
70
+ toU8a(_isBare?: boolean): Uint8Array;
71
+ }
package/native/Bool.js ADDED
@@ -0,0 +1,109 @@
1
+ import { isU8a, u8aToHex } from '@pezkuwi/util';
2
+ /**
3
+ * @name bool
4
+ * @description
5
+ * Representation for a boolean value in the system. It extends the base JS `Boolean` class
6
+ * @noInheritDoc
7
+ */
8
+ export class bool extends Boolean {
9
+ registry;
10
+ createdAtHash;
11
+ initialU8aLength = 1;
12
+ isStorageFallback;
13
+ constructor(registry, value = false) {
14
+ super(isU8a(value)
15
+ ? value[0] === 1
16
+ : value instanceof Boolean
17
+ ? value.valueOf()
18
+ : !!value);
19
+ this.registry = registry;
20
+ }
21
+ /**
22
+ * @description The length of the value when encoded as a Uint8Array
23
+ */
24
+ get encodedLength() {
25
+ return 1 | 0;
26
+ }
27
+ /**
28
+ * @description returns a hash of the contents
29
+ */
30
+ get hash() {
31
+ return this.registry.hash(this.toU8a());
32
+ }
33
+ /**
34
+ * @description Checks if the value is an empty value (true when it wraps false/default)
35
+ */
36
+ get isEmpty() {
37
+ return this.isFalse;
38
+ }
39
+ /**
40
+ * @description Checks if the value is an empty value (always false)
41
+ */
42
+ get isFalse() {
43
+ return !this.isTrue;
44
+ }
45
+ /**
46
+ * @description Checks if the value is an empty value (always false)
47
+ */
48
+ get isTrue() {
49
+ return this.valueOf();
50
+ }
51
+ /**
52
+ * @description Compares the value of the input to see if there is a match
53
+ */
54
+ eq(other) {
55
+ return this.valueOf() === (other instanceof Boolean
56
+ ? other.valueOf()
57
+ : other);
58
+ }
59
+ /**
60
+ * @description Returns a breakdown of the hex encoding for this Codec
61
+ */
62
+ inspect() {
63
+ return {
64
+ outer: [this.toU8a()]
65
+ };
66
+ }
67
+ /**
68
+ * @description Returns a hex string representation of the value
69
+ */
70
+ toHex() {
71
+ return u8aToHex(this.toU8a());
72
+ }
73
+ /**
74
+ * @description Converts the Object to to a human-friendly JSON, with additional fields, expansion and formatting of information
75
+ */
76
+ toHuman() {
77
+ return this.toJSON();
78
+ }
79
+ /**
80
+ * @description Converts the Object to JSON, typically used for RPC transfers
81
+ */
82
+ toJSON() {
83
+ return this.valueOf();
84
+ }
85
+ /**
86
+ * @description Converts the value in a best-fit primitive form
87
+ */
88
+ toPrimitive() {
89
+ return this.toJSON();
90
+ }
91
+ /**
92
+ * @description Returns the base runtime type name for this instance
93
+ */
94
+ toRawType() {
95
+ return 'bool';
96
+ }
97
+ /**
98
+ * @description Returns the string representation of the value
99
+ */
100
+ toString() {
101
+ return this.toJSON().toString();
102
+ }
103
+ /**
104
+ * @description Encodes the value as a Uint8Array as per the SCALE specifications
105
+ */
106
+ toU8a(_isBare) {
107
+ return new Uint8Array([this.valueOf() ? 1 : 0]);
108
+ }
109
+ }
@@ -0,0 +1,84 @@
1
+ import type { HexString } from '@pezkuwi/util/types';
2
+ import type { AnyNumber, Inspect, INumber, IU8a, Registry, UIntBitLength } from '../types/index.js';
3
+ import { BN } from '@pezkuwi/util';
4
+ /**
5
+ * @name Date
6
+ * @description
7
+ * A wrapper around seconds/timestamps. Internally the representation only has
8
+ * second precicion (aligning with Rust), so any numbers passed an/out are always
9
+ * per-second. For any encoding/decoding the 1000 multiplier would be applied to
10
+ * get it in line with JavaScript formats. It extends the base JS `Date` object
11
+ * and has all the methods available that are applicable to any `Date`
12
+ * @noInheritDoc
13
+ */
14
+ export declare class CodecDate extends Date implements INumber {
15
+ readonly registry: Registry;
16
+ createdAtHash?: IU8a;
17
+ initialU8aLength: number;
18
+ isStorageFallback?: boolean;
19
+ constructor(registry: Registry, value?: CodecDate | Date | AnyNumber);
20
+ /**
21
+ * @description The length of the value when encoded as a Uint8Array
22
+ */
23
+ get encodedLength(): number;
24
+ /**
25
+ * @description returns a hash of the contents
26
+ */
27
+ get hash(): IU8a;
28
+ /**
29
+ * @description Checks if the value is an empty value
30
+ */
31
+ get isEmpty(): boolean;
32
+ /**
33
+ * @description Returns the number of bits in the value
34
+ */
35
+ bitLength(): UIntBitLength;
36
+ /**
37
+ * @description Compares the value of the input to see if there is a match
38
+ */
39
+ eq(other?: unknown): boolean;
40
+ /**
41
+ * @description Returns a breakdown of the hex encoding for this Codec
42
+ */
43
+ inspect(): Inspect;
44
+ /**
45
+ * @description Returns a BigInt representation of the number
46
+ */
47
+ toBigInt(): bigint;
48
+ /**
49
+ * @description Returns the BN representation of the timestamp
50
+ */
51
+ toBn(): BN;
52
+ /**
53
+ * @description Returns a hex string representation of the value
54
+ */
55
+ toHex(isLe?: boolean): HexString;
56
+ /**
57
+ * @description Converts the Object to to a human-friendly JSON, with additional fields, expansion and formatting of information
58
+ */
59
+ toHuman(): string;
60
+ /**
61
+ * @description Converts the Object to JSON, typically used for RPC transfers
62
+ */
63
+ toJSON(): any;
64
+ /**
65
+ * @description Returns the number representation for the timestamp
66
+ */
67
+ toNumber(): number;
68
+ /**
69
+ * @description Converts the value in a best-fit primitive form
70
+ */
71
+ toPrimitive(): number;
72
+ /**
73
+ * @description Returns the base runtime type name for this instance
74
+ */
75
+ toRawType(): string;
76
+ /**
77
+ * @description Returns the string representation of the value
78
+ */
79
+ toString(): string;
80
+ /**
81
+ * @description Encodes the value as a Uint8Array as per the SCALE specifications
82
+ */
83
+ toU8a(_isBare?: boolean): Uint8Array;
84
+ }
package/native/Date.js ADDED
@@ -0,0 +1,140 @@
1
+ import { BN, bnToBn, bnToHex, bnToU8a, isString, isU8a, u8aToBn } from '@pezkuwi/util';
2
+ const BITLENGTH = 64;
3
+ const U8A_OPTS = { bitLength: BITLENGTH, isLe: true };
4
+ function decodeDate(value) {
5
+ if (isU8a(value)) {
6
+ value = u8aToBn(value.subarray(0, BITLENGTH / 8));
7
+ }
8
+ else if (value instanceof Date) {
9
+ return value;
10
+ }
11
+ else if (isString(value)) {
12
+ value = new BN(value.toString(), 10, 'le');
13
+ }
14
+ return new Date(bnToBn(value).toNumber() * 1000);
15
+ }
16
+ /**
17
+ * @name Date
18
+ * @description
19
+ * A wrapper around seconds/timestamps. Internally the representation only has
20
+ * second precicion (aligning with Rust), so any numbers passed an/out are always
21
+ * per-second. For any encoding/decoding the 1000 multiplier would be applied to
22
+ * get it in line with JavaScript formats. It extends the base JS `Date` object
23
+ * and has all the methods available that are applicable to any `Date`
24
+ * @noInheritDoc
25
+ */
26
+ export class CodecDate extends Date {
27
+ registry;
28
+ createdAtHash;
29
+ initialU8aLength = BITLENGTH / 8;
30
+ isStorageFallback;
31
+ constructor(registry, value = 0) {
32
+ super(decodeDate(value));
33
+ this.registry = registry;
34
+ }
35
+ /**
36
+ * @description The length of the value when encoded as a Uint8Array
37
+ */
38
+ get encodedLength() {
39
+ return BITLENGTH / 8;
40
+ }
41
+ /**
42
+ * @description returns a hash of the contents
43
+ */
44
+ get hash() {
45
+ return this.registry.hash(this.toU8a());
46
+ }
47
+ /**
48
+ * @description Checks if the value is an empty value
49
+ */
50
+ get isEmpty() {
51
+ return this.getTime() === 0;
52
+ }
53
+ /**
54
+ * @description Returns the number of bits in the value
55
+ */
56
+ bitLength() {
57
+ return BITLENGTH;
58
+ }
59
+ /**
60
+ * @description Compares the value of the input to see if there is a match
61
+ */
62
+ eq(other) {
63
+ return decodeDate(other).getTime() === this.getTime();
64
+ }
65
+ /**
66
+ * @description Returns a breakdown of the hex encoding for this Codec
67
+ */
68
+ inspect() {
69
+ return {
70
+ outer: [this.toU8a()]
71
+ };
72
+ }
73
+ /**
74
+ * @description Returns a BigInt representation of the number
75
+ */
76
+ toBigInt() {
77
+ return BigInt(this.toNumber());
78
+ }
79
+ /**
80
+ * @description Returns the BN representation of the timestamp
81
+ */
82
+ toBn() {
83
+ return new BN(this.toNumber());
84
+ }
85
+ /**
86
+ * @description Returns a hex string representation of the value
87
+ */
88
+ toHex(isLe = false) {
89
+ return bnToHex(this.toBn(), {
90
+ bitLength: BITLENGTH,
91
+ isLe,
92
+ isNegative: false
93
+ });
94
+ }
95
+ /**
96
+ * @description Converts the Object to to a human-friendly JSON, with additional fields, expansion and formatting of information
97
+ */
98
+ toHuman() {
99
+ return this.toISOString();
100
+ }
101
+ /**
102
+ * @description Converts the Object to JSON, typically used for RPC transfers
103
+ */
104
+ toJSON() {
105
+ // FIXME Return type should be number, but conflicts with Date.toJSON()
106
+ // which returns string
107
+ return this.toNumber();
108
+ }
109
+ /**
110
+ * @description Returns the number representation for the timestamp
111
+ */
112
+ toNumber() {
113
+ return Math.ceil(this.getTime() / 1000);
114
+ }
115
+ /**
116
+ * @description Converts the value in a best-fit primitive form
117
+ */
118
+ toPrimitive() {
119
+ return this.toNumber();
120
+ }
121
+ /**
122
+ * @description Returns the base runtime type name for this instance
123
+ */
124
+ toRawType() {
125
+ return 'Moment';
126
+ }
127
+ /**
128
+ * @description Returns the string representation of the value
129
+ */
130
+ toString() {
131
+ // only included here since we do not inherit docs
132
+ return super.toString();
133
+ }
134
+ /**
135
+ * @description Encodes the value as a Uint8Array as per the SCALE specifications
136
+ */
137
+ toU8a(_isBare) {
138
+ return bnToU8a(this.toNumber(), U8A_OPTS);
139
+ }
140
+ }
@@ -0,0 +1,68 @@
1
+ import type { HexString } from '@pezkuwi/util/types';
2
+ import type { AnyFloat, CodecClass, IFloat, Inspect, IU8a, Registry } from '../types/index.js';
3
+ interface Options {
4
+ bitLength?: 32 | 64;
5
+ }
6
+ /**
7
+ * @name Float
8
+ * @description
9
+ * A Codec wrapper for F32 & F64 values. You generally don't want to be using
10
+ * f32/f64 in your runtime, operations on fixed points numbers are preferable. This class
11
+ * was explicitly added since scale-codec has a flag that enables this and it is available
12
+ * in some eth_* RPCs
13
+ */
14
+ export declare class Float extends Number implements IFloat {
15
+ #private;
16
+ readonly encodedLength: number;
17
+ readonly registry: Registry;
18
+ createdAtHash?: IU8a;
19
+ initialU8aLength?: number;
20
+ isStorageFallback?: boolean;
21
+ constructor(registry: Registry, value?: AnyFloat, { bitLength }?: Options);
22
+ static with(bitLength: 32 | 64): CodecClass<Float>;
23
+ /**
24
+ * @description returns a hash of the contents
25
+ */
26
+ get hash(): IU8a;
27
+ /**
28
+ * @description Returns true if the type wraps an empty/default all-0 value
29
+ */
30
+ get isEmpty(): boolean;
31
+ /**
32
+ * @description Compares the value of the input to see if there is a match
33
+ */
34
+ eq(other?: unknown): boolean;
35
+ /**
36
+ * @description Returns a breakdown of the hex encoding for this Codec
37
+ */
38
+ inspect(): Inspect;
39
+ /**
40
+ * @description Returns a hex string representation of the value
41
+ */
42
+ toHex(): HexString;
43
+ /**
44
+ * @description Converts the Object to to a human-friendly JSON, with additional fields, expansion and formatting of information
45
+ */
46
+ toHuman(): string;
47
+ /**
48
+ * @description Converts the Object to JSON, typically used for RPC transfers
49
+ */
50
+ toJSON(): string;
51
+ /**
52
+ * @description Returns the number representation (Same as valueOf)
53
+ */
54
+ toNumber(): number;
55
+ /**
56
+ * @description Converts the value in a best-fit primitive form
57
+ */
58
+ toPrimitive(): number;
59
+ /**
60
+ * @description Returns the base runtime type name for this instance
61
+ */
62
+ toRawType(): string;
63
+ /**
64
+ * @description Encodes the value as a Uint8Array as per the SCALE specifications
65
+ */
66
+ toU8a(_isBare?: boolean): Uint8Array;
67
+ }
68
+ export {};