@kontor/kontor-sdk 1.0.0-alpha.39 → 1.0.0-alpha.40

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 (270) hide show
  1. package/README.md +1 -1
  2. package/dist/cjs/sdk/actions/kontor/public/call-view.js.map +1 -1
  3. package/dist/cjs/sdk/chains/definitions/signet.js +2 -2
  4. package/dist/cjs/sdk/test/e2e.test-deprecated.js +2 -0
  5. package/dist/cjs/sdk/test/e2e.test-deprecated.js.map +1 -0
  6. package/dist/cjs/sdk/utils/wit/codecs/bool.js +9 -21
  7. package/dist/cjs/sdk/utils/wit/codecs/bool.js.map +1 -1
  8. package/dist/cjs/sdk/utils/wit/codecs/contract-address.js +92 -0
  9. package/dist/cjs/sdk/utils/wit/codecs/contract-address.js.map +1 -0
  10. package/dist/cjs/sdk/utils/wit/codecs/index.js +29 -0
  11. package/dist/cjs/sdk/utils/wit/codecs/index.js.map +1 -0
  12. package/dist/cjs/sdk/utils/wit/codecs/list.js +21 -95
  13. package/dist/cjs/sdk/utils/wit/codecs/list.js.map +1 -1
  14. package/dist/cjs/sdk/utils/wit/codecs/numerics.js +228 -0
  15. package/dist/cjs/sdk/utils/wit/codecs/numerics.js.map +1 -0
  16. package/dist/cjs/sdk/utils/wit/codecs/option.js +21 -72
  17. package/dist/cjs/sdk/utils/wit/codecs/option.js.map +1 -1
  18. package/dist/cjs/sdk/utils/wit/codecs/result.js +32 -0
  19. package/dist/cjs/sdk/utils/wit/codecs/result.js.map +1 -0
  20. package/dist/cjs/sdk/utils/wit/codecs/string.js +16 -21
  21. package/dist/cjs/sdk/utils/wit/codecs/string.js.map +1 -1
  22. package/dist/cjs/sdk/utils/wit/codecs/unit.js +11 -19
  23. package/dist/cjs/sdk/utils/wit/codecs/unit.js.map +1 -1
  24. package/dist/cjs/sdk/utils/wit/codecs/util.js +185 -0
  25. package/dist/cjs/sdk/utils/wit/codecs/util.js.map +1 -0
  26. package/dist/cjs/sdk/utils/wit/decode-wit-parameter.js +297 -163
  27. package/dist/cjs/sdk/utils/wit/decode-wit-parameter.js.map +1 -1
  28. package/dist/cjs/sdk/utils/wit/encode-wit-parameters.js +214 -221
  29. package/dist/cjs/sdk/utils/wit/encode-wit-parameters.js.map +1 -1
  30. package/dist/cjs/tsconfig.build.tsbuildinfo +1 -1
  31. package/dist/cjs/wit/built-ins.js +19 -0
  32. package/dist/cjs/wit/built-ins.js.map +1 -0
  33. package/dist/cjs/wit/regex.js +1 -1
  34. package/dist/cjs/wit/regex.js.map +1 -1
  35. package/dist/cjs/wit/wit-parser/core/errors/signature.js +17 -2
  36. package/dist/cjs/wit/wit-parser/core/errors/signature.js.map +1 -1
  37. package/dist/cjs/wit/wit-parser/core/signatures.js +18 -0
  38. package/dist/cjs/wit/wit-parser/core/signatures.js.map +1 -1
  39. package/dist/cjs/wit/wit-parser/core/types/{records.js → user-defined.js} +1 -1
  40. package/dist/cjs/wit/wit-parser/core/types/user-defined.js.map +1 -0
  41. package/dist/cjs/wit/wit-parser/core/user-defined.js +271 -0
  42. package/dist/cjs/wit/wit-parser/core/user-defined.js.map +1 -0
  43. package/dist/cjs/wit/wit-parser/core/utils.js +29 -7
  44. package/dist/cjs/wit/wit-parser/core/utils.js.map +1 -1
  45. package/dist/cjs/wit/wit-parser/parse-wit-parameter.js +9 -3
  46. package/dist/cjs/wit/wit-parser/parse-wit-parameter.js.map +1 -1
  47. package/dist/cjs/wit/wit-parser/parse-wit.js +7 -3
  48. package/dist/cjs/wit/wit-parser/parse-wit.js.map +1 -1
  49. package/dist/esm/sdk/actions/kontor/public/call-view.js.map +1 -1
  50. package/dist/esm/sdk/chains/definitions/signet.js +2 -2
  51. package/dist/esm/sdk/test/e2e.test-deprecated.js +197 -0
  52. package/dist/esm/sdk/test/e2e.test-deprecated.js.map +1 -0
  53. package/dist/esm/sdk/utils/wit/codecs/bool.js +9 -21
  54. package/dist/esm/sdk/utils/wit/codecs/bool.js.map +1 -1
  55. package/dist/esm/sdk/utils/wit/codecs/contract-address.js +92 -0
  56. package/dist/esm/sdk/utils/wit/codecs/contract-address.js.map +1 -0
  57. package/dist/esm/sdk/utils/wit/codecs/index.js +9 -0
  58. package/dist/esm/sdk/utils/wit/codecs/index.js.map +1 -0
  59. package/dist/esm/sdk/utils/wit/codecs/list.js +20 -114
  60. package/dist/esm/sdk/utils/wit/codecs/list.js.map +1 -1
  61. package/dist/esm/sdk/utils/wit/codecs/numerics.js +234 -0
  62. package/dist/esm/sdk/utils/wit/codecs/numerics.js.map +1 -0
  63. package/dist/esm/sdk/utils/wit/codecs/option.js +21 -88
  64. package/dist/esm/sdk/utils/wit/codecs/option.js.map +1 -1
  65. package/dist/esm/sdk/utils/wit/codecs/result.js +29 -0
  66. package/dist/esm/sdk/utils/wit/codecs/result.js.map +1 -0
  67. package/dist/esm/sdk/utils/wit/codecs/string.js +22 -22
  68. package/dist/esm/sdk/utils/wit/codecs/string.js.map +1 -1
  69. package/dist/esm/sdk/utils/wit/codecs/unit.js +12 -21
  70. package/dist/esm/sdk/utils/wit/codecs/unit.js.map +1 -1
  71. package/dist/esm/sdk/utils/wit/codecs/util.js +181 -0
  72. package/dist/esm/sdk/utils/wit/codecs/util.js.map +1 -0
  73. package/dist/esm/sdk/utils/wit/decode-wit-parameter.js +322 -188
  74. package/dist/esm/sdk/utils/wit/decode-wit-parameter.js.map +1 -1
  75. package/dist/esm/sdk/utils/wit/encode-wit-parameters.js +230 -233
  76. package/dist/esm/sdk/utils/wit/encode-wit-parameters.js.map +1 -1
  77. package/dist/esm/tsconfig.build.tsbuildinfo +1 -1
  78. package/dist/esm/wit/built-ins.js +16 -0
  79. package/dist/esm/wit/built-ins.js.map +1 -0
  80. package/dist/esm/wit/regex.js +1 -1
  81. package/dist/esm/wit/regex.js.map +1 -1
  82. package/dist/esm/wit/wit-parser/core/errors/signature.js +15 -1
  83. package/dist/esm/wit/wit-parser/core/errors/signature.js.map +1 -1
  84. package/dist/esm/wit/wit-parser/core/signatures.js +14 -0
  85. package/dist/esm/wit/wit-parser/core/signatures.js.map +1 -1
  86. package/dist/esm/wit/wit-parser/core/types/signatures.js.map +1 -1
  87. package/dist/esm/wit/wit-parser/core/types/user-defined.js +2 -0
  88. package/dist/esm/wit/wit-parser/core/types/user-defined.js.map +1 -0
  89. package/dist/esm/wit/wit-parser/core/types/utils.js +25 -0
  90. package/dist/esm/wit/wit-parser/core/types/utils.js.map +1 -1
  91. package/dist/esm/wit/wit-parser/core/user-defined.js +280 -0
  92. package/dist/esm/wit/wit-parser/core/user-defined.js.map +1 -0
  93. package/dist/esm/wit/wit-parser/core/utils.js +33 -36
  94. package/dist/esm/wit/wit-parser/core/utils.js.map +1 -1
  95. package/dist/esm/wit/wit-parser/parse-wit-parameter.js +10 -4
  96. package/dist/esm/wit/wit-parser/parse-wit-parameter.js.map +1 -1
  97. package/dist/esm/wit/wit-parser/parse-wit.js +8 -4
  98. package/dist/esm/wit/wit-parser/parse-wit.js.map +1 -1
  99. package/dist/types/sdk/actions/kontor/public/call-view.d.ts +2 -1
  100. package/dist/types/sdk/actions/kontor/public/call-view.d.ts.map +1 -1
  101. package/dist/types/sdk/chains/definitions/signet.d.ts +2 -2
  102. package/dist/types/sdk/test/e2e.test-deprecated.d.ts +2 -0
  103. package/dist/types/sdk/test/e2e.test-deprecated.d.ts.map +1 -0
  104. package/dist/types/sdk/types/contract.d.ts +5 -5
  105. package/dist/types/sdk/types/contract.d.ts.map +1 -1
  106. package/dist/types/sdk/utils/wit/codecs/bool.d.ts +2 -2
  107. package/dist/types/sdk/utils/wit/codecs/bool.d.ts.map +1 -1
  108. package/dist/types/sdk/utils/wit/codecs/contract-address.d.ts +5 -0
  109. package/dist/types/sdk/utils/wit/codecs/contract-address.d.ts.map +1 -0
  110. package/dist/types/sdk/utils/wit/codecs/index.d.ts +9 -0
  111. package/dist/types/sdk/utils/wit/codecs/index.d.ts.map +1 -0
  112. package/dist/types/sdk/utils/wit/codecs/list.d.ts +2 -16
  113. package/dist/types/sdk/utils/wit/codecs/list.d.ts.map +1 -1
  114. package/dist/types/sdk/utils/wit/codecs/numerics.d.ts +14 -0
  115. package/dist/types/sdk/utils/wit/codecs/numerics.d.ts.map +1 -0
  116. package/dist/types/sdk/utils/wit/codecs/option.d.ts +3 -23
  117. package/dist/types/sdk/utils/wit/codecs/option.d.ts.map +1 -1
  118. package/dist/types/sdk/utils/wit/codecs/result.d.ts +4 -0
  119. package/dist/types/sdk/utils/wit/codecs/result.d.ts.map +1 -0
  120. package/dist/types/sdk/utils/wit/codecs/string.d.ts +6 -2
  121. package/dist/types/sdk/utils/wit/codecs/string.d.ts.map +1 -1
  122. package/dist/types/sdk/utils/wit/codecs/types.d.ts +4 -0
  123. package/dist/types/sdk/utils/wit/codecs/types.d.ts.map +1 -1
  124. package/dist/types/sdk/utils/wit/codecs/unit.d.ts +2 -11
  125. package/dist/types/sdk/utils/wit/codecs/unit.d.ts.map +1 -1
  126. package/dist/types/sdk/utils/wit/codecs/util.d.ts +12 -0
  127. package/dist/types/sdk/utils/wit/codecs/util.d.ts.map +1 -0
  128. package/dist/types/sdk/utils/wit/decode-wit-parameter.d.ts +9 -31
  129. package/dist/types/sdk/utils/wit/decode-wit-parameter.d.ts.map +1 -1
  130. package/dist/types/sdk/utils/wit/encode-wit-parameters.d.ts +9 -1
  131. package/dist/types/sdk/utils/wit/encode-wit-parameters.d.ts.map +1 -1
  132. package/dist/types/wit/built-ins.d.ts +6 -0
  133. package/dist/types/wit/built-ins.d.ts.map +1 -0
  134. package/dist/types/wit/regex.d.ts.map +1 -1
  135. package/dist/types/wit/utils.d.ts +53 -33
  136. package/dist/types/wit/utils.d.ts.map +1 -1
  137. package/dist/types/wit/wit-parser/core/errors/signature.d.ts +7 -1
  138. package/dist/types/wit/wit-parser/core/errors/signature.d.ts.map +1 -1
  139. package/dist/types/wit/wit-parser/core/signatures.d.ts +10 -0
  140. package/dist/types/wit/wit-parser/core/signatures.d.ts.map +1 -1
  141. package/dist/types/wit/wit-parser/core/types/signatures.d.ts +6 -2
  142. package/dist/types/wit/wit-parser/core/types/signatures.d.ts.map +1 -1
  143. package/dist/types/wit/wit-parser/core/types/user-defined.d.ts +134 -0
  144. package/dist/types/wit/wit-parser/core/types/user-defined.d.ts.map +1 -0
  145. package/dist/types/wit/wit-parser/core/types/utils.d.ts +86 -11
  146. package/dist/types/wit/wit-parser/core/types/utils.d.ts.map +1 -1
  147. package/dist/types/wit/wit-parser/core/user-defined.d.ts +19 -0
  148. package/dist/types/wit/wit-parser/core/user-defined.d.ts.map +1 -0
  149. package/dist/types/wit/wit-parser/core/utils.d.ts +8 -4
  150. package/dist/types/wit/wit-parser/core/utils.d.ts.map +1 -1
  151. package/dist/types/wit/wit-parser/parse-wit-parameter.d.ts +11 -5
  152. package/dist/types/wit/wit-parser/parse-wit-parameter.d.ts.map +1 -1
  153. package/dist/types/wit/wit-parser/parse-wit.d.ts +7 -3
  154. package/dist/types/wit/wit-parser/parse-wit.d.ts.map +1 -1
  155. package/dist/types/wit/wit.d.ts +20 -12
  156. package/dist/types/wit/wit.d.ts.map +1 -1
  157. package/package.json +1 -1
  158. package/src/sdk/actions/get-contract.test-d.ts +430 -50
  159. package/src/sdk/actions/get-contract.test.ts +324 -24
  160. package/src/sdk/actions/kontor/public/call-view.ts +2 -1
  161. package/src/sdk/actions/kontor/public/proc-contract.test-d.ts +107 -0
  162. package/src/sdk/actions/kontor/public/proc-contract.test.ts +234 -21
  163. package/src/sdk/actions/kontor/public/view-contract.test-d.ts +240 -0
  164. package/src/sdk/actions/kontor/public/view-contract.test.ts +613 -18
  165. package/src/sdk/chains/definitions/signet.ts +2 -2
  166. package/src/sdk/clients/base/create-rpc-client.test.ts +2 -2
  167. package/src/sdk/clients/create-public-client.test.ts +2 -2
  168. package/src/sdk/clients/kontor/create-public-client.test.ts +2 -2
  169. package/src/sdk/clients/transports/http-rpc.test.ts +0 -24
  170. package/src/sdk/test/e2e.test-deprecated.ts +195 -0
  171. package/src/sdk/types/contract.test-d.ts +489 -55
  172. package/src/sdk/types/contract.ts +6 -7
  173. package/src/sdk/utils/wit/codecs/bool.test.ts +29 -0
  174. package/src/sdk/utils/wit/codecs/bool.ts +10 -25
  175. package/src/sdk/utils/wit/codecs/contract-address.test.ts +37 -0
  176. package/src/sdk/utils/wit/codecs/contract-address.ts +114 -0
  177. package/src/sdk/utils/wit/codecs/index.ts +20 -0
  178. package/src/sdk/utils/wit/codecs/list.test-d.ts +13 -0
  179. package/src/sdk/utils/wit/codecs/list.test.ts +55 -0
  180. package/src/sdk/utils/wit/codecs/list.ts +21 -150
  181. package/src/sdk/utils/wit/codecs/numerics.test.ts +399 -0
  182. package/src/sdk/utils/wit/codecs/numerics.ts +304 -0
  183. package/src/sdk/utils/wit/codecs/option.test.ts +71 -0
  184. package/src/sdk/utils/wit/codecs/option.ts +21 -120
  185. package/src/sdk/utils/wit/codecs/result.test.ts +82 -0
  186. package/src/sdk/utils/wit/codecs/result.ts +37 -0
  187. package/src/sdk/utils/wit/codecs/string.test.ts +62 -0
  188. package/src/sdk/utils/wit/codecs/string.ts +23 -25
  189. package/src/sdk/utils/wit/codecs/types.ts +5 -0
  190. package/src/sdk/utils/wit/codecs/unit.test.ts +27 -0
  191. package/src/sdk/utils/wit/codecs/unit.ts +14 -38
  192. package/src/sdk/utils/wit/codecs/util.test.ts +221 -0
  193. package/src/sdk/utils/wit/codecs/util.ts +193 -0
  194. package/src/sdk/utils/wit/decode-wit-parameter.test.ts +1264 -32
  195. package/src/sdk/utils/wit/decode-wit-parameter.ts +508 -211
  196. package/src/sdk/utils/wit/encode-wit-parameters.test.ts +955 -91
  197. package/src/sdk/utils/wit/encode-wit-parameters.ts +277 -274
  198. package/src/sdk/utils/wit/get-wit-item.test.ts +1 -1
  199. package/src/wit/built-ins.ts +23 -0
  200. package/src/wit/regex.ts +1 -1
  201. package/src/wit/utils.ts +120 -74
  202. package/src/wit/wit-parser/core/errors/signature.ts +13 -2
  203. package/src/wit/wit-parser/core/signatures.ts +28 -0
  204. package/src/wit/wit-parser/core/types/signatures.test-d.ts +21 -0
  205. package/src/wit/wit-parser/core/types/signatures.ts +19 -2
  206. package/src/wit/wit-parser/core/types/user-defined.test-d.ts +1308 -0
  207. package/src/wit/wit-parser/core/types/user-defined.ts +412 -0
  208. package/src/wit/wit-parser/core/types/utils.test-d.ts +43 -2
  209. package/src/wit/wit-parser/core/types/utils.ts +143 -14
  210. package/src/wit/wit-parser/core/user-defined.test.ts +609 -0
  211. package/src/wit/wit-parser/core/user-defined.ts +392 -0
  212. package/src/wit/wit-parser/core/utils.test.ts +334 -115
  213. package/src/wit/wit-parser/core/utils.ts +54 -38
  214. package/src/wit/wit-parser/parse-wit-parameter.test.ts +282 -4
  215. package/src/wit/wit-parser/parse-wit-parameter.ts +37 -11
  216. package/src/wit/wit-parser/parse-wit.test.ts +738 -12
  217. package/src/wit/wit-parser/parse-wit.ts +25 -10
  218. package/src/wit/wit.ts +37 -16
  219. package/vitest.config.ts +5 -0
  220. package/dist/cjs/sdk/utils/wit/codecs/decimal.js +0 -148
  221. package/dist/cjs/sdk/utils/wit/codecs/decimal.js.map +0 -1
  222. package/dist/cjs/sdk/utils/wit/codecs/enum.js +0 -94
  223. package/dist/cjs/sdk/utils/wit/codecs/enum.js.map +0 -1
  224. package/dist/cjs/sdk/utils/wit/codecs/integer.js +0 -125
  225. package/dist/cjs/sdk/utils/wit/codecs/integer.js.map +0 -1
  226. package/dist/cjs/sdk/utils/wit/codecs/s64.js +0 -57
  227. package/dist/cjs/sdk/utils/wit/codecs/s64.js.map +0 -1
  228. package/dist/cjs/sdk/utils/wit/codecs/u64.js +0 -56
  229. package/dist/cjs/sdk/utils/wit/codecs/u64.js.map +0 -1
  230. package/dist/cjs/wit/wit-parser/core/records.js +0 -70
  231. package/dist/cjs/wit/wit-parser/core/records.js.map +0 -1
  232. package/dist/cjs/wit/wit-parser/core/types/records.js.map +0 -1
  233. package/dist/esm/sdk/utils/wit/codecs/decimal.js +0 -165
  234. package/dist/esm/sdk/utils/wit/codecs/decimal.js.map +0 -1
  235. package/dist/esm/sdk/utils/wit/codecs/enum.js +0 -104
  236. package/dist/esm/sdk/utils/wit/codecs/enum.js.map +0 -1
  237. package/dist/esm/sdk/utils/wit/codecs/integer.js +0 -167
  238. package/dist/esm/sdk/utils/wit/codecs/integer.js.map +0 -1
  239. package/dist/esm/sdk/utils/wit/codecs/s64.js +0 -65
  240. package/dist/esm/sdk/utils/wit/codecs/s64.js.map +0 -1
  241. package/dist/esm/sdk/utils/wit/codecs/u64.js +0 -63
  242. package/dist/esm/sdk/utils/wit/codecs/u64.js.map +0 -1
  243. package/dist/esm/wit/wit-parser/core/records.js +0 -73
  244. package/dist/esm/wit/wit-parser/core/records.js.map +0 -1
  245. package/dist/esm/wit/wit-parser/core/types/records.js +0 -2
  246. package/dist/esm/wit/wit-parser/core/types/records.js.map +0 -1
  247. package/dist/types/sdk/utils/wit/codecs/decimal.d.ts +0 -42
  248. package/dist/types/sdk/utils/wit/codecs/decimal.d.ts.map +0 -1
  249. package/dist/types/sdk/utils/wit/codecs/enum.d.ts +0 -49
  250. package/dist/types/sdk/utils/wit/codecs/enum.d.ts.map +0 -1
  251. package/dist/types/sdk/utils/wit/codecs/integer.d.ts +0 -36
  252. package/dist/types/sdk/utils/wit/codecs/integer.d.ts.map +0 -1
  253. package/dist/types/sdk/utils/wit/codecs/s64.d.ts +0 -23
  254. package/dist/types/sdk/utils/wit/codecs/s64.d.ts.map +0 -1
  255. package/dist/types/sdk/utils/wit/codecs/u64.d.ts +0 -23
  256. package/dist/types/sdk/utils/wit/codecs/u64.d.ts.map +0 -1
  257. package/dist/types/wit/wit-parser/core/records.d.ts +0 -4
  258. package/dist/types/wit/wit-parser/core/records.d.ts.map +0 -1
  259. package/dist/types/wit/wit-parser/core/types/records.d.ts +0 -51
  260. package/dist/types/wit/wit-parser/core/types/records.d.ts.map +0 -1
  261. package/src/sdk/test/e2e.test.ts +0 -194
  262. package/src/sdk/utils/wit/codecs/decimal.ts +0 -215
  263. package/src/sdk/utils/wit/codecs/enum.ts +0 -114
  264. package/src/sdk/utils/wit/codecs/integer.ts +0 -193
  265. package/src/sdk/utils/wit/codecs/s64.ts +0 -76
  266. package/src/sdk/utils/wit/codecs/u64.ts +0 -73
  267. package/src/wit/wit-parser/core/records.test.ts +0 -69
  268. package/src/wit/wit-parser/core/records.ts +0 -101
  269. package/src/wit/wit-parser/core/types/records.test-d.ts +0 -331
  270. package/src/wit/wit-parser/core/types/records.ts +0 -91
@@ -8,6 +8,25 @@ import {
8
8
  import type { ParseOptions } from "./utils.js";
9
9
 
10
10
  const parseOptions: ParseOptions = {
11
+ variants: {
12
+ color: [
13
+ { name: "hex", type: "string", internalType: "string" },
14
+ {
15
+ name: "literal",
16
+ type: "variant",
17
+ internalType: "rainbow",
18
+ components: [
19
+ { name: "red", type: "_", internalType: "_" },
20
+ { name: "orange", type: "_", internalType: "_" },
21
+ { name: "yellow", type: "_", internalType: "_" },
22
+ { name: "green", type: "_", internalType: "_" },
23
+ { name: "blue", type: "_", internalType: "_" },
24
+ { name: "indigo", type: "_", internalType: "_" },
25
+ { name: "violet", type: "_", internalType: "_" },
26
+ ],
27
+ },
28
+ ],
29
+ },
11
30
  records: {
12
31
  "contract-address": [
13
32
  { name: "name", type: "string" },
@@ -15,6 +34,9 @@ const parseOptions: ParseOptions = {
15
34
  { name: "tx-index", type: "s64" },
16
35
  ],
17
36
  },
37
+ enums: {
38
+ status: ["pending", "active", "completed", "cancelled"],
39
+ },
18
40
  };
19
41
 
20
42
  describe("parseFunctionSignature", () => {
@@ -81,12 +103,21 @@ describe("parseWitParameter", () => {
81
103
  parameter: "arith-address: contract-address",
82
104
  expected: {
83
105
  name: "arith-address",
84
- type: "tuple",
106
+ type: "record",
85
107
  internalType: "contract-address",
86
108
  components: [
87
- { name: "name", type: "string" },
88
- { name: "height", type: "s64" },
89
- { name: "tx-index", type: "s64" },
109
+ {
110
+ name: "name",
111
+ type: "string",
112
+ },
113
+ {
114
+ name: "height",
115
+ type: "s64",
116
+ },
117
+ {
118
+ name: "tx-index",
119
+ type: "s64",
120
+ },
90
121
  ],
91
122
  },
92
123
  },
@@ -118,150 +149,108 @@ describe("parseWitParameter", () => {
118
149
  parameter: "arith-addresses: list<contract-address>",
119
150
  expected: {
120
151
  name: "arith-addresses",
121
- type: "list<tuple>",
152
+ type: "list<record>",
122
153
  internalType: "list<contract-address>",
123
154
  components: [
124
- { name: "name", type: "string" },
125
- { name: "height", type: "s64" },
126
- { name: "tx-index", type: "s64" },
155
+ {
156
+ name: "name",
157
+ type: "string",
158
+ },
159
+ {
160
+ name: "height",
161
+ type: "s64",
162
+ },
163
+ {
164
+ name: "tx-index",
165
+ type: "s64",
166
+ },
127
167
  ],
128
168
  },
129
169
  },
130
170
  {
131
171
  parameter: "list<contract-address>",
132
172
  expected: {
133
- type: "list<tuple>",
173
+ type: "list<record>",
134
174
  internalType: "list<contract-address>",
135
175
  components: [
136
- { name: "name", type: "string" },
137
- { name: "height", type: "s64" },
138
- { name: "tx-index", type: "s64" },
176
+ {
177
+ name: "name",
178
+ type: "string",
179
+ },
180
+ {
181
+ name: "height",
182
+ type: "s64",
183
+ },
184
+ {
185
+ name: "tx-index",
186
+ type: "s64",
187
+ },
139
188
  ],
140
189
  },
141
190
  },
142
191
  {
143
192
  parameter: "option<contract-address>",
144
193
  expected: {
145
- type: "option<tuple>",
194
+ type: "option<record>",
146
195
  internalType: "option<contract-address>",
147
196
  components: [
148
- { name: "name", type: "string" },
149
- { name: "height", type: "s64" },
150
- { name: "tx-index", type: "s64" },
197
+ {
198
+ name: "name",
199
+ type: "string",
200
+ },
201
+ {
202
+ name: "height",
203
+ type: "s64",
204
+ },
205
+ {
206
+ name: "tx-index",
207
+ type: "s64",
208
+ },
151
209
  ],
152
210
  },
153
211
  },
154
212
  {
155
213
  parameter: "result<contract-address, error>",
156
214
  expected: {
157
- type: "result<tuple, error>",
215
+ type: "result<record, error>",
158
216
  internalType: "result<contract-address, error>",
159
217
  components: [
160
- { name: "name", type: "string" },
161
- { name: "height", type: "s64" },
162
- { name: "tx-index", type: "s64" },
218
+ {
219
+ name: "name",
220
+ type: "string",
221
+ },
222
+ {
223
+ name: "height",
224
+ type: "s64",
225
+ },
226
+ {
227
+ name: "tx-index",
228
+ type: "s64",
229
+ },
163
230
  ],
164
231
  },
165
232
  },
166
233
  {
167
234
  parameter: "result<list<contract-address>, error>",
168
235
  expected: {
169
- type: "result<list<tuple>, error>",
236
+ type: "result<list<record>, error>",
170
237
  internalType: "result<list<contract-address>, error>",
171
238
  components: [
172
- { name: "name", type: "string" },
173
- { name: "height", type: "s64" },
174
- { name: "tx-index", type: "s64" },
239
+ {
240
+ name: "name",
241
+ type: "string",
242
+ },
243
+ {
244
+ name: "height",
245
+ type: "s64",
246
+ },
247
+ {
248
+ name: "tx-index",
249
+ type: "s64",
250
+ },
175
251
  ],
176
252
  },
177
253
  },
178
- // {
179
- // parameter: "result<string, list<option<contract-address>>>",
180
- // expected: {
181
- // type: "result<string, list<option<tuple>>>",
182
- // components: [
183
- // { name: "left", type: "string" },
184
- // {
185
- // name: "right",
186
- // type: "list<option<tuple>>",
187
- // components: [
188
- // { name: "name", type: "string" },
189
- // { name: "height", type: "s64" },
190
- // { name: "tx-index", type: "s64" },
191
- // ],
192
- // },
193
- // ],
194
- // },
195
- // },
196
- // {
197
- // parameter: "result<string, list<result<string, contract-address>>>",
198
- // expected: {
199
- // type: "result<string, list<result<string, tuple>>>",
200
- // components: [
201
- // { name: "left", type: "string" },
202
- // {
203
- // name: "right",
204
- // type: "list<result<string, tuple>>",
205
- // components: [
206
- // { name: "left", type: "string" },
207
- // {
208
- // name: "right",
209
- // type: "tuple",
210
- // components: [
211
- // { name: "name", type: "string" },
212
- // { name: "height", type: "s64" },
213
- // { name: "tx-index", type: "s64" },
214
- // ],
215
- // },
216
- // ],
217
- // },
218
- // ],
219
- // },
220
- // },
221
- // {
222
- // parameter:
223
- // "result<string, list<result<string, option<contract-address>>>>",
224
- // expected: {
225
- // type: "result<string, list<result<string, option<tuple>>>>",
226
- // components: [
227
- // { name: "left", type: "string" },
228
- // {
229
- // name: "right",
230
- // type: "list<result<string, option<tuple>>>",
231
- // components: [
232
- // { name: "left", type: "string" },
233
- // {
234
- // name: "right",
235
- // type: "option<tuple>",
236
- // components: [
237
- // { name: "name", type: "string" },
238
- // { name: "height", type: "s64" },
239
- // { name: "tx-index", type: "s64" },
240
- // ],
241
- // },
242
- // ],
243
- // },
244
- // ],
245
- // },
246
- // },
247
- // {
248
- // parameter: "option<list<result<string, contract-address>>>",
249
- // expected: {
250
- // type: "option<list<result<string, tuple>>>",
251
- // components: [
252
- // { type: "string", name: "left" },
253
- // {
254
- // name: "right",
255
- // type: "tuple",
256
- // components: [
257
- // { type: "string", name: "name" },
258
- // { name: "height", type: "s64" },
259
- // { name: "tx-index", type: "s64" },
260
- // ],
261
- // },
262
- // ],
263
- // },
264
- // },
265
254
  ])("parseWitParameter($parameter)", ({ parameter, expected }) => {
266
255
  expect(parseWitParameter(parameter, parseOptions)).toEqual(expected);
267
256
  });
@@ -281,8 +270,8 @@ describe("splitParameters (WIT generics, only < > nesting)", () => {
281
270
  });
282
271
 
283
272
  test("does not split inside < >", () => {
284
- expect(splitParameters("tuple<u64, list<string>>")).toEqual([
285
- "tuple<u64, list<string>>",
273
+ expect(splitParameters("record<u64, list<string>>")).toEqual([
274
+ "record<u64, list<string>>",
286
275
  ]);
287
276
 
288
277
  expect(splitParameters("result<integer, error>")).toEqual([
@@ -331,11 +320,241 @@ describe("splitParameters (WIT generics, only < > nesting)", () => {
331
320
 
332
321
  test("complex function-style params", () => {
333
322
  const input =
334
- "ctx: borrow<proc-context>, result: result<tuple<u64, list<string>>, error>, flag: bool";
323
+ "ctx: borrow<proc-context>, result: result<record<u64, list<string>>, error>, flag: bool";
335
324
  expect(splitParameters(input)).toEqual([
336
325
  "ctx: borrow<proc-context>",
337
- "result: result<tuple<u64, list<string>>, error>",
326
+ "result: result<record<u64, list<string>>, error>",
338
327
  "flag: bool",
339
328
  ]);
340
329
  });
341
330
  });
331
+
332
+ const parseOptionsWithVariants: ParseOptions = {
333
+ variants: {
334
+ color: [
335
+ { name: "hex", type: "string", internalType: "string" },
336
+ {
337
+ name: "literal",
338
+ type: "variant",
339
+ internalType: "rainbow",
340
+ components: [
341
+ { name: "red", type: "_", internalType: "_" },
342
+ { name: "orange", type: "_", internalType: "_" },
343
+ { name: "yellow", type: "_", internalType: "_" },
344
+ { name: "green", type: "_", internalType: "_" },
345
+ { name: "blue", type: "_", internalType: "_" },
346
+ { name: "indigo", type: "_", internalType: "_" },
347
+ { name: "violet", type: "_", internalType: "_" },
348
+ ],
349
+ },
350
+ ],
351
+ },
352
+ };
353
+
354
+ test("parseWitParameter with variant from options", () => {
355
+ const parsed = parseWitParameter("c: color", parseOptionsWithVariants);
356
+
357
+ expect(parsed).toEqual({
358
+ name: "c",
359
+ type: "variant",
360
+ internalType: "color",
361
+ components: [
362
+ { name: "hex", type: "string", internalType: "string" },
363
+ {
364
+ name: "literal",
365
+ type: "variant",
366
+ internalType: "rainbow",
367
+ components: [
368
+ { name: "red", type: "_", internalType: "_" },
369
+ { name: "orange", type: "_", internalType: "_" },
370
+ { name: "yellow", type: "_", internalType: "_" },
371
+ { name: "green", type: "_", internalType: "_" },
372
+ { name: "blue", type: "_", internalType: "_" },
373
+ { name: "indigo", type: "_", internalType: "_" },
374
+ { name: "violet", type: "_", internalType: "_" },
375
+ ],
376
+ },
377
+ ],
378
+ });
379
+
380
+ const parsed0 = parseWitParameter("c: option<color>", {
381
+ variants: {
382
+ color: [
383
+ { name: "hex", type: "string", internalType: "string" },
384
+ {
385
+ name: "literal",
386
+ type: "variant",
387
+ internalType: "rainbow",
388
+ components: [
389
+ { name: "red", type: "_", internalType: "_" },
390
+ { name: "orange", type: "_", internalType: "_" },
391
+ { name: "yellow", type: "_", internalType: "_" },
392
+ { name: "green", type: "_", internalType: "_" },
393
+ { name: "blue", type: "_", internalType: "_" },
394
+ { name: "indigo", type: "_", internalType: "_" },
395
+ { name: "violet", type: "_", internalType: "_" },
396
+ ],
397
+ },
398
+ ],
399
+ },
400
+ });
401
+
402
+ expect(parsed0).toEqual({
403
+ name: "c",
404
+ type: "option<variant>",
405
+ internalType: "option<color>",
406
+ components: [
407
+ { name: "hex", type: "string", internalType: "string" },
408
+ {
409
+ name: "literal",
410
+ type: "variant",
411
+ internalType: "rainbow",
412
+ components: [
413
+ { name: "red", type: "_", internalType: "_" },
414
+ { name: "orange", type: "_", internalType: "_" },
415
+ { name: "yellow", type: "_", internalType: "_" },
416
+ { name: "green", type: "_", internalType: "_" },
417
+ { name: "blue", type: "_", internalType: "_" },
418
+ { name: "indigo", type: "_", internalType: "_" },
419
+ { name: "violet", type: "_", internalType: "_" },
420
+ ],
421
+ },
422
+ ],
423
+ });
424
+
425
+ const parsed1 = parseWitParameter(
426
+ "c: result<color, error>",
427
+ parseOptionsWithVariants,
428
+ );
429
+
430
+ expect(parsed1).toEqual({
431
+ name: "c",
432
+ type: "result<variant, error>",
433
+ internalType: "result<color, error>",
434
+ components: [
435
+ { name: "hex", type: "string", internalType: "string" },
436
+ {
437
+ name: "literal",
438
+ type: "variant",
439
+ internalType: "rainbow",
440
+ components: [
441
+ { name: "red", type: "_", internalType: "_" },
442
+ { name: "orange", type: "_", internalType: "_" },
443
+ { name: "yellow", type: "_", internalType: "_" },
444
+ { name: "green", type: "_", internalType: "_" },
445
+ { name: "blue", type: "_", internalType: "_" },
446
+ { name: "indigo", type: "_", internalType: "_" },
447
+ { name: "violet", type: "_", internalType: "_" },
448
+ ],
449
+ },
450
+ ],
451
+ });
452
+ });
453
+
454
+ const parseOptionsWithEnums: ParseOptions = {
455
+ enums: {
456
+ status: ["pending", "active", "completed", "cancelled"],
457
+ },
458
+ };
459
+
460
+ describe("parseWitParameter with enums", () => {
461
+ test("parseWitParameter with enum from options", () => {
462
+ const parsed = parseWitParameter("s: status", parseOptionsWithEnums);
463
+
464
+ expect(parsed).toEqual({
465
+ name: "s",
466
+ type: "enum",
467
+ internalType: "status",
468
+ components: [
469
+ { name: "pending", type: "_", internalType: "_" },
470
+ { name: "active", type: "_", internalType: "_" },
471
+ { name: "completed", type: "_", internalType: "_" },
472
+ { name: "cancelled", type: "_", internalType: "_" },
473
+ ],
474
+ });
475
+ });
476
+
477
+ test("parseWitParameter with option<enum>", () => {
478
+ const parsed = parseWitParameter(
479
+ "s: option<status>",
480
+ parseOptionsWithEnums,
481
+ );
482
+
483
+ expect(parsed).toEqual({
484
+ name: "s",
485
+ type: "option<enum>",
486
+ internalType: "option<status>",
487
+ components: [
488
+ { name: "pending", type: "_", internalType: "_" },
489
+ { name: "active", type: "_", internalType: "_" },
490
+ { name: "completed", type: "_", internalType: "_" },
491
+ { name: "cancelled", type: "_", internalType: "_" },
492
+ ],
493
+ });
494
+ });
495
+
496
+ test("parseWitParameter with list<enum>", () => {
497
+ const parsed = parseWitParameter(
498
+ "statuses: list<status>",
499
+ parseOptionsWithEnums,
500
+ );
501
+
502
+ expect(parsed).toEqual({
503
+ name: "statuses",
504
+ type: "list<enum>",
505
+ internalType: "list<status>",
506
+ components: [
507
+ { name: "pending", type: "_", internalType: "_" },
508
+ { name: "active", type: "_", internalType: "_" },
509
+ { name: "completed", type: "_", internalType: "_" },
510
+ { name: "cancelled", type: "_", internalType: "_" },
511
+ ],
512
+ });
513
+ });
514
+
515
+ test("parseWitParameter with result<enum, error>", () => {
516
+ const parsed = parseWitParameter(
517
+ "s: result<status, error>",
518
+ parseOptionsWithEnums,
519
+ );
520
+
521
+ expect(parsed).toEqual({
522
+ name: "s",
523
+ type: "result<enum, error>",
524
+ internalType: "result<status, error>",
525
+ components: [
526
+ { name: "pending", type: "_", internalType: "_" },
527
+ { name: "active", type: "_", internalType: "_" },
528
+ { name: "completed", type: "_", internalType: "_" },
529
+ { name: "cancelled", type: "_", internalType: "_" },
530
+ ],
531
+ });
532
+ });
533
+ });
534
+
535
+ test("parseWitParameter with mixed types (records, variants, and enums)", () => {
536
+ const parsed = parseWitParameter("task: task-info", {
537
+ records: {
538
+ "task-info": [
539
+ { name: "id", type: "u64" },
540
+ { name: "status", type: "status" },
541
+ { name: "priority", type: "priority" },
542
+ ],
543
+ },
544
+ enums: {
545
+ status: ["pending", "active", "completed"],
546
+ priority: ["low", "medium", "high", "urgent"],
547
+ },
548
+ });
549
+
550
+ expect(parsed).toEqual({
551
+ name: "task",
552
+ type: "record",
553
+ internalType: "task-info",
554
+ components: [
555
+ { name: "id", type: "u64" },
556
+ { name: "status", type: "status" },
557
+ { name: "priority", type: "priority" },
558
+ ],
559
+ });
560
+ });