@aztec/bb.js 0.0.1-alpha.7 → 0.0.1-commit.5476d83

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 (777) hide show
  1. package/README.md +55 -84
  2. package/build/amd64-linux/bb +0 -0
  3. package/build/amd64-linux/nodejs_module.node +0 -0
  4. package/build/amd64-macos/bb +0 -0
  5. package/build/amd64-macos/nodejs_module.node +0 -0
  6. package/build/arm64-linux/bb +0 -0
  7. package/build/arm64-linux/nodejs_module.node +0 -0
  8. package/build/arm64-macos/bb +0 -0
  9. package/build/arm64-macos/nodejs_module.node +0 -0
  10. package/dest/{async_map → browser/async_map}/index.d.ts +1 -1
  11. package/dest/browser/async_map/index.d.ts.map +1 -0
  12. package/dest/{async_map → browser/async_map}/index.js +1 -1
  13. package/dest/browser/barretenberg/backend.d.ts +61 -0
  14. package/dest/browser/barretenberg/backend.d.ts.map +1 -0
  15. package/dest/browser/barretenberg/backend.js +250 -0
  16. package/dest/browser/barretenberg/index.d.ts +65 -0
  17. package/dest/browser/barretenberg/index.d.ts.map +1 -0
  18. package/dest/browser/barretenberg/index.js +182 -0
  19. package/dest/browser/barretenberg/testing/bigint-buffer.d.ts +17 -0
  20. package/dest/browser/barretenberg/testing/bigint-buffer.d.ts.map +1 -0
  21. package/dest/browser/barretenberg/testing/bigint-buffer.js +37 -0
  22. package/dest/browser/barretenberg/testing/fields.d.ts +16 -0
  23. package/dest/browser/barretenberg/testing/fields.d.ts.map +1 -0
  24. package/dest/browser/barretenberg/testing/fields.js +47 -0
  25. package/dest/browser/barretenberg_wasm/barretenberg_wasm_base/index.d.ts +45 -0
  26. package/dest/browser/barretenberg_wasm/barretenberg_wasm_base/index.d.ts.map +1 -0
  27. package/dest/browser/barretenberg_wasm/barretenberg_wasm_base/index.js +124 -0
  28. package/dest/browser/barretenberg_wasm/barretenberg_wasm_main/factory/browser/index.d.ts +2 -0
  29. package/dest/browser/barretenberg_wasm/barretenberg_wasm_main/factory/browser/index.d.ts.map +1 -0
  30. package/dest/browser/barretenberg_wasm/barretenberg_wasm_main/factory/browser/index.js +9 -0
  31. package/dest/browser/barretenberg_wasm/barretenberg_wasm_main/factory/browser/main.worker.d.ts +2 -0
  32. package/dest/browser/barretenberg_wasm/barretenberg_wasm_main/factory/browser/main.worker.d.ts.map +1 -0
  33. package/dest/browser/barretenberg_wasm/barretenberg_wasm_main/factory/browser/main.worker.js +6 -0
  34. package/dest/browser/barretenberg_wasm/barretenberg_wasm_main/heap_allocator.d.ts +21 -0
  35. package/dest/browser/barretenberg_wasm/barretenberg_wasm_main/heap_allocator.d.ts.map +1 -0
  36. package/dest/browser/barretenberg_wasm/barretenberg_wasm_main/heap_allocator.js +71 -0
  37. package/dest/browser/barretenberg_wasm/barretenberg_wasm_main/index.d.ts +59 -0
  38. package/dest/browser/barretenberg_wasm/barretenberg_wasm_main/index.d.ts.map +1 -0
  39. package/dest/browser/barretenberg_wasm/barretenberg_wasm_main/index.js +197 -0
  40. package/dest/browser/barretenberg_wasm/barretenberg_wasm_thread/factory/browser/index.d.ts +2 -0
  41. package/dest/browser/barretenberg_wasm/barretenberg_wasm_thread/factory/browser/index.d.ts.map +1 -0
  42. package/dest/browser/barretenberg_wasm/barretenberg_wasm_thread/factory/browser/index.js +9 -0
  43. package/dest/browser/barretenberg_wasm/barretenberg_wasm_thread/factory/browser/thread.worker.d.ts +2 -0
  44. package/dest/browser/barretenberg_wasm/barretenberg_wasm_thread/factory/browser/thread.worker.d.ts.map +1 -0
  45. package/dest/browser/barretenberg_wasm/barretenberg_wasm_thread/factory/browser/thread.worker.js +6 -0
  46. package/dest/browser/barretenberg_wasm/barretenberg_wasm_thread/index.d.ts +30 -0
  47. package/dest/browser/barretenberg_wasm/barretenberg_wasm_thread/index.d.ts.map +1 -0
  48. package/dest/browser/barretenberg_wasm/barretenberg_wasm_thread/index.js +41 -0
  49. package/dest/browser/barretenberg_wasm/fetch_code/browser/barretenberg-threads.d.ts +3 -0
  50. package/dest/browser/barretenberg_wasm/fetch_code/browser/barretenberg-threads.d.ts.map +1 -0
  51. package/dest/browser/barretenberg_wasm/fetch_code/browser/barretenberg-threads.js +2 -0
  52. package/dest/browser/barretenberg_wasm/fetch_code/browser/barretenberg.d.ts +3 -0
  53. package/dest/browser/barretenberg_wasm/fetch_code/browser/barretenberg.d.ts.map +1 -0
  54. package/dest/browser/barretenberg_wasm/fetch_code/browser/barretenberg.js +2 -0
  55. package/dest/browser/barretenberg_wasm/fetch_code/browser/index.d.ts +2 -0
  56. package/dest/browser/barretenberg_wasm/fetch_code/browser/index.d.ts.map +1 -0
  57. package/dest/browser/barretenberg_wasm/fetch_code/browser/index.js +36 -0
  58. package/dest/browser/barretenberg_wasm/fetch_code/index.d.ts +2 -0
  59. package/dest/browser/barretenberg_wasm/fetch_code/index.d.ts.map +1 -0
  60. package/dest/browser/barretenberg_wasm/fetch_code/index.js +2 -0
  61. package/dest/browser/barretenberg_wasm/helpers/browser/index.d.ts +13 -0
  62. package/dest/browser/barretenberg_wasm/helpers/browser/index.d.ts.map +1 -0
  63. package/dest/browser/barretenberg_wasm/helpers/browser/index.js +47 -0
  64. package/dest/browser/barretenberg_wasm/helpers/index.d.ts +2 -0
  65. package/dest/browser/barretenberg_wasm/helpers/index.d.ts.map +1 -0
  66. package/dest/browser/barretenberg_wasm/helpers/index.js +2 -0
  67. package/dest/browser/barretenberg_wasm/index.d.ts +5 -0
  68. package/dest/browser/barretenberg_wasm/index.d.ts.map +1 -0
  69. package/dest/browser/barretenberg_wasm/index.js +15 -0
  70. package/dest/browser/bb_backends/browser/index.d.ts +11 -0
  71. package/dest/browser/bb_backends/browser/index.d.ts.map +1 -0
  72. package/dest/browser/bb_backends/browser/index.js +39 -0
  73. package/dest/browser/bb_backends/browser/platform.d.ts +4 -0
  74. package/dest/browser/bb_backends/browser/platform.d.ts.map +1 -0
  75. package/dest/browser/bb_backends/browser/platform.js +10 -0
  76. package/dest/browser/bb_backends/index.d.ts +48 -0
  77. package/dest/browser/bb_backends/index.d.ts.map +1 -0
  78. package/dest/browser/bb_backends/index.js +16 -0
  79. package/dest/browser/bb_backends/interface.d.ts +33 -0
  80. package/dest/browser/bb_backends/interface.d.ts.map +1 -0
  81. package/dest/browser/bb_backends/interface.js +2 -0
  82. package/dest/browser/bb_backends/wasm.d.ts +49 -0
  83. package/dest/browser/bb_backends/wasm.d.ts.map +1 -0
  84. package/dest/browser/bb_backends/wasm.js +85 -0
  85. package/dest/browser/bbapi_exception.d.ts +7 -0
  86. package/dest/browser/bbapi_exception.d.ts.map +1 -0
  87. package/dest/browser/bbapi_exception.js +14 -0
  88. package/dest/browser/bin/index.d.ts +3 -0
  89. package/dest/{bindgen → browser/bin}/index.d.ts.map +1 -1
  90. package/dest/browser/bin/index.js +11 -0
  91. package/dest/browser/cbind/generate.d.ts +5 -0
  92. package/dest/browser/cbind/generate.d.ts.map +1 -0
  93. package/dest/browser/cbind/generate.js +151 -0
  94. package/dest/browser/cbind/generated/api_types.d.ts +2051 -0
  95. package/dest/browser/cbind/generated/api_types.d.ts.map +1 -0
  96. package/dest/browser/cbind/generated/api_types.js +2747 -0
  97. package/dest/browser/cbind/generated/async.d.ts +62 -0
  98. package/dest/browser/cbind/generated/async.d.ts.map +1 -0
  99. package/dest/browser/cbind/generated/async.js +663 -0
  100. package/dest/browser/cbind/generated/curve_constants.d.ts +45 -0
  101. package/dest/browser/cbind/generated/curve_constants.d.ts.map +1 -0
  102. package/dest/browser/cbind/generated/curve_constants.js +45 -0
  103. package/dest/browser/cbind/generated/sync.d.ts +62 -0
  104. package/dest/browser/cbind/generated/sync.d.ts.map +1 -0
  105. package/dest/browser/cbind/generated/sync.js +610 -0
  106. package/dest/browser/cbind/schema_compiler.d.ts +68 -0
  107. package/dest/browser/cbind/schema_compiler.d.ts.map +1 -0
  108. package/dest/browser/cbind/schema_compiler.js +600 -0
  109. package/dest/browser/crs/browser/cached_net_crs.d.ts +43 -0
  110. package/dest/browser/crs/browser/cached_net_crs.d.ts.map +1 -0
  111. package/dest/browser/crs/browser/cached_net_crs.js +95 -0
  112. package/dest/browser/crs/browser/index.d.ts +2 -0
  113. package/dest/browser/crs/browser/index.d.ts.map +1 -0
  114. package/dest/browser/crs/browser/index.js +2 -0
  115. package/dest/browser/crs/index.d.ts +2 -0
  116. package/dest/browser/crs/index.d.ts.map +1 -0
  117. package/dest/browser/crs/index.js +2 -0
  118. package/dest/browser/crs/net_crs.d.ts +70 -0
  119. package/dest/browser/crs/net_crs.d.ts.map +1 -0
  120. package/dest/browser/crs/net_crs.js +141 -0
  121. package/dest/browser/index.d.ts +9 -0
  122. package/dest/browser/index.d.ts.map +1 -0
  123. package/dest/browser/index.js +9 -0
  124. package/dest/browser/proof/index.d.ts +21 -0
  125. package/dest/browser/proof/index.d.ts.map +1 -0
  126. package/dest/browser/proof/index.js +63 -0
  127. package/dest/browser/random/browser/index.d.ts +2 -0
  128. package/dest/browser/random/browser/index.d.ts.map +1 -0
  129. package/dest/browser/random/browser/index.js +31 -0
  130. package/dest/browser/random/index.d.ts +2 -0
  131. package/dest/browser/random/index.d.ts.map +1 -0
  132. package/dest/browser/random/index.js +2 -0
  133. package/dest/browser/retry/index.d.ts +26 -0
  134. package/dest/browser/retry/index.d.ts.map +1 -0
  135. package/dest/browser/retry/index.js +50 -0
  136. package/dest/node/async_map/index.d.ts +10 -0
  137. package/dest/node/async_map/index.d.ts.map +1 -0
  138. package/dest/node/async_map/index.js +16 -0
  139. package/dest/node/barretenberg/__snapshots__/pedersen.test.js.snap +156 -0
  140. package/dest/node/barretenberg/__snapshots__/poseidon.test.js.snap +40 -0
  141. package/dest/node/barretenberg/backend.d.ts +61 -0
  142. package/dest/node/barretenberg/backend.d.ts.map +1 -0
  143. package/dest/node/barretenberg/backend.js +250 -0
  144. package/dest/node/barretenberg/blake2s.test.d.ts +2 -0
  145. package/dest/node/barretenberg/blake2s.test.d.ts.map +1 -0
  146. package/dest/node/barretenberg/blake2s.test.js +57 -0
  147. package/dest/node/barretenberg/index.d.ts +65 -0
  148. package/dest/node/barretenberg/index.d.ts.map +1 -0
  149. package/dest/node/barretenberg/index.js +182 -0
  150. package/dest/node/barretenberg/pedersen.test.d.ts +2 -0
  151. package/dest/node/barretenberg/pedersen.test.d.ts.map +1 -0
  152. package/dest/node/barretenberg/pedersen.test.js +62 -0
  153. package/dest/node/barretenberg/poseidon.bench.test.d.ts +2 -0
  154. package/dest/node/barretenberg/poseidon.bench.test.d.ts.map +1 -0
  155. package/dest/node/barretenberg/poseidon.bench.test.js +218 -0
  156. package/dest/node/barretenberg/poseidon.test.d.ts +2 -0
  157. package/dest/node/barretenberg/poseidon.test.d.ts.map +1 -0
  158. package/dest/node/barretenberg/poseidon.test.js +35 -0
  159. package/dest/node/barretenberg/testing/bigint-buffer.d.ts +17 -0
  160. package/dest/node/barretenberg/testing/bigint-buffer.d.ts.map +1 -0
  161. package/dest/node/barretenberg/testing/bigint-buffer.js +37 -0
  162. package/dest/node/barretenberg/testing/fields.d.ts +16 -0
  163. package/dest/node/barretenberg/testing/fields.d.ts.map +1 -0
  164. package/dest/node/barretenberg/testing/fields.js +47 -0
  165. package/dest/node/barretenberg_wasm/barretenberg-threads.wasm.gz +0 -0
  166. package/dest/node/barretenberg_wasm/barretenberg_wasm_base/index.d.ts +45 -0
  167. package/dest/node/barretenberg_wasm/barretenberg_wasm_base/index.d.ts.map +1 -0
  168. package/dest/node/barretenberg_wasm/barretenberg_wasm_base/index.js +124 -0
  169. package/dest/node/barretenberg_wasm/barretenberg_wasm_main/factory/browser/index.d.ts +2 -0
  170. package/dest/node/barretenberg_wasm/barretenberg_wasm_main/factory/browser/index.d.ts.map +1 -0
  171. package/dest/node/barretenberg_wasm/barretenberg_wasm_main/factory/browser/index.js +9 -0
  172. package/dest/node/barretenberg_wasm/barretenberg_wasm_main/factory/browser/main.worker.d.ts +2 -0
  173. package/dest/node/barretenberg_wasm/barretenberg_wasm_main/factory/browser/main.worker.d.ts.map +1 -0
  174. package/dest/node/barretenberg_wasm/barretenberg_wasm_main/factory/browser/main.worker.js +6 -0
  175. package/dest/node/barretenberg_wasm/barretenberg_wasm_main/factory/node/index.d.ts +3 -0
  176. package/dest/node/barretenberg_wasm/barretenberg_wasm_main/factory/node/index.d.ts.map +1 -0
  177. package/dest/node/barretenberg_wasm/barretenberg_wasm_main/factory/node/index.js +19 -0
  178. package/dest/node/barretenberg_wasm/barretenberg_wasm_main/factory/node/main.worker.d.ts +2 -0
  179. package/dest/node/barretenberg_wasm/barretenberg_wasm_main/factory/node/main.worker.d.ts.map +1 -0
  180. package/dest/node/barretenberg_wasm/barretenberg_wasm_main/factory/node/main.worker.js +9 -0
  181. package/dest/node/barretenberg_wasm/barretenberg_wasm_main/heap_allocator.d.ts +21 -0
  182. package/dest/node/barretenberg_wasm/barretenberg_wasm_main/heap_allocator.d.ts.map +1 -0
  183. package/dest/node/barretenberg_wasm/barretenberg_wasm_main/heap_allocator.js +71 -0
  184. package/dest/node/barretenberg_wasm/barretenberg_wasm_main/index.d.ts +59 -0
  185. package/dest/node/barretenberg_wasm/barretenberg_wasm_main/index.d.ts.map +1 -0
  186. package/dest/node/barretenberg_wasm/barretenberg_wasm_main/index.js +197 -0
  187. package/dest/node/barretenberg_wasm/barretenberg_wasm_thread/factory/browser/index.d.ts +2 -0
  188. package/dest/node/barretenberg_wasm/barretenberg_wasm_thread/factory/browser/index.d.ts.map +1 -0
  189. package/dest/node/barretenberg_wasm/barretenberg_wasm_thread/factory/browser/index.js +9 -0
  190. package/dest/node/barretenberg_wasm/barretenberg_wasm_thread/factory/browser/thread.worker.d.ts +2 -0
  191. package/dest/node/barretenberg_wasm/barretenberg_wasm_thread/factory/browser/thread.worker.d.ts.map +1 -0
  192. package/dest/node/barretenberg_wasm/barretenberg_wasm_thread/factory/browser/thread.worker.js +6 -0
  193. package/dest/node/barretenberg_wasm/barretenberg_wasm_thread/factory/node/index.d.ts +3 -0
  194. package/dest/node/barretenberg_wasm/barretenberg_wasm_thread/factory/node/index.d.ts.map +1 -0
  195. package/dest/node/barretenberg_wasm/barretenberg_wasm_thread/factory/node/index.js +19 -0
  196. package/dest/node/barretenberg_wasm/barretenberg_wasm_thread/factory/node/thread.worker.d.ts +2 -0
  197. package/dest/node/barretenberg_wasm/barretenberg_wasm_thread/factory/node/thread.worker.d.ts.map +1 -0
  198. package/dest/node/barretenberg_wasm/barretenberg_wasm_thread/factory/node/thread.worker.js +10 -0
  199. package/dest/node/barretenberg_wasm/barretenberg_wasm_thread/index.d.ts +30 -0
  200. package/dest/node/barretenberg_wasm/barretenberg_wasm_thread/index.d.ts.map +1 -0
  201. package/dest/node/barretenberg_wasm/barretenberg_wasm_thread/index.js +41 -0
  202. package/dest/node/barretenberg_wasm/fetch_code/browser/barretenberg-threads.d.ts +3 -0
  203. package/dest/node/barretenberg_wasm/fetch_code/browser/barretenberg-threads.d.ts.map +1 -0
  204. package/dest/node/barretenberg_wasm/fetch_code/browser/barretenberg-threads.js +3 -0
  205. package/dest/node/barretenberg_wasm/fetch_code/browser/barretenberg.d.ts +3 -0
  206. package/dest/node/barretenberg_wasm/fetch_code/browser/barretenberg.d.ts.map +1 -0
  207. package/dest/node/barretenberg_wasm/fetch_code/browser/barretenberg.js +3 -0
  208. package/dest/node/barretenberg_wasm/fetch_code/browser/index.d.ts +2 -0
  209. package/dest/node/barretenberg_wasm/fetch_code/browser/index.d.ts.map +1 -0
  210. package/dest/node/barretenberg_wasm/fetch_code/browser/index.js +36 -0
  211. package/dest/node/barretenberg_wasm/fetch_code/index.d.ts +2 -0
  212. package/dest/node/barretenberg_wasm/fetch_code/index.d.ts.map +1 -0
  213. package/dest/node/barretenberg_wasm/fetch_code/index.js +2 -0
  214. package/dest/node/barretenberg_wasm/fetch_code/node/index.d.ts +2 -0
  215. package/dest/node/barretenberg_wasm/fetch_code/node/index.d.ts.map +1 -0
  216. package/dest/node/barretenberg_wasm/fetch_code/node/index.js +35 -0
  217. package/dest/node/barretenberg_wasm/helpers/browser/index.d.ts +13 -0
  218. package/dest/node/barretenberg_wasm/helpers/browser/index.d.ts.map +1 -0
  219. package/dest/node/barretenberg_wasm/helpers/browser/index.js +47 -0
  220. package/dest/node/barretenberg_wasm/helpers/index.d.ts +2 -0
  221. package/dest/node/barretenberg_wasm/helpers/index.d.ts.map +1 -0
  222. package/dest/node/barretenberg_wasm/helpers/index.js +2 -0
  223. package/dest/node/barretenberg_wasm/helpers/node/index.d.ts +21 -0
  224. package/dest/node/barretenberg_wasm/helpers/node/index.d.ts.map +1 -0
  225. package/dest/node/barretenberg_wasm/helpers/node/index.js +56 -0
  226. package/dest/node/barretenberg_wasm/helpers/node/node_endpoint.d.ts +8 -0
  227. package/dest/node/barretenberg_wasm/helpers/node/node_endpoint.d.ts.map +1 -0
  228. package/dest/node/barretenberg_wasm/helpers/node/node_endpoint.js +28 -0
  229. package/dest/node/barretenberg_wasm/index.d.ts +5 -0
  230. package/dest/node/barretenberg_wasm/index.d.ts.map +1 -0
  231. package/dest/node/barretenberg_wasm/index.js +15 -0
  232. package/dest/node/barretenberg_wasm/index.test.d.ts +2 -0
  233. package/dest/node/barretenberg_wasm/index.test.d.ts.map +1 -0
  234. package/dest/node/barretenberg_wasm/index.test.js +39 -0
  235. package/dest/node/bb_backends/browser/index.d.ts +11 -0
  236. package/dest/node/bb_backends/browser/index.d.ts.map +1 -0
  237. package/dest/node/bb_backends/browser/index.js +39 -0
  238. package/dest/node/bb_backends/browser/platform.d.ts +4 -0
  239. package/dest/node/bb_backends/browser/platform.d.ts.map +1 -0
  240. package/dest/node/bb_backends/browser/platform.js +10 -0
  241. package/dest/node/bb_backends/index.d.ts +48 -0
  242. package/dest/node/bb_backends/index.d.ts.map +1 -0
  243. package/dest/node/bb_backends/index.js +16 -0
  244. package/dest/node/bb_backends/interface.d.ts +33 -0
  245. package/dest/node/bb_backends/interface.d.ts.map +1 -0
  246. package/dest/node/bb_backends/interface.js +2 -0
  247. package/dest/node/bb_backends/node/index.d.ts +11 -0
  248. package/dest/node/bb_backends/node/index.d.ts.map +1 -0
  249. package/dest/node/bb_backends/node/index.js +86 -0
  250. package/dest/node/bb_backends/node/native_pipe.d.ts +25 -0
  251. package/dest/node/bb_backends/node/native_pipe.d.ts.map +1 -0
  252. package/dest/node/bb_backends/node/native_pipe.js +114 -0
  253. package/dest/node/bb_backends/node/native_shm.d.ts +28 -0
  254. package/dest/node/bb_backends/node/native_shm.d.ts.map +1 -0
  255. package/dest/node/bb_backends/node/native_shm.js +177 -0
  256. package/dest/node/bb_backends/node/native_shm_async.d.ts +51 -0
  257. package/dest/node/bb_backends/node/native_shm_async.d.ts.map +1 -0
  258. package/dest/node/bb_backends/node/native_shm_async.js +237 -0
  259. package/dest/node/bb_backends/node/native_socket.d.ts +34 -0
  260. package/dest/node/bb_backends/node/native_socket.d.ts.map +1 -0
  261. package/dest/node/bb_backends/node/native_socket.js +281 -0
  262. package/dest/node/bb_backends/node/platform.d.ts +27 -0
  263. package/dest/node/bb_backends/node/platform.d.ts.map +1 -0
  264. package/dest/node/bb_backends/node/platform.js +124 -0
  265. package/dest/node/bb_backends/wasm.d.ts +49 -0
  266. package/dest/node/bb_backends/wasm.d.ts.map +1 -0
  267. package/dest/node/bb_backends/wasm.js +85 -0
  268. package/dest/node/bbapi/exception_handling.test.d.ts +2 -0
  269. package/dest/node/bbapi/exception_handling.test.d.ts.map +1 -0
  270. package/dest/node/bbapi/exception_handling.test.js +48 -0
  271. package/dest/node/bbapi_exception.d.ts +7 -0
  272. package/dest/node/bbapi_exception.d.ts.map +1 -0
  273. package/dest/node/bbapi_exception.js +14 -0
  274. package/dest/node/benchmark/index.d.ts +3 -0
  275. package/dest/node/benchmark/index.d.ts.map +1 -0
  276. package/dest/node/benchmark/index.js +25 -0
  277. package/dest/node/benchmark/timer.d.ts +34 -0
  278. package/dest/node/benchmark/timer.d.ts.map +1 -0
  279. package/dest/node/benchmark/timer.js +42 -0
  280. package/dest/node/bin/index.d.ts +3 -0
  281. package/dest/node/bin/index.d.ts.map +1 -0
  282. package/dest/node/bin/index.js +11 -0
  283. package/dest/node/cbind/generate.d.ts +5 -0
  284. package/dest/node/cbind/generate.d.ts.map +1 -0
  285. package/dest/node/cbind/generate.js +151 -0
  286. package/dest/node/cbind/generated/api_types.d.ts +2051 -0
  287. package/dest/node/cbind/generated/api_types.d.ts.map +1 -0
  288. package/dest/node/cbind/generated/api_types.js +2747 -0
  289. package/dest/node/cbind/generated/async.d.ts +62 -0
  290. package/dest/node/cbind/generated/async.d.ts.map +1 -0
  291. package/dest/node/cbind/generated/async.js +663 -0
  292. package/dest/node/cbind/generated/curve_constants.d.ts +45 -0
  293. package/dest/node/cbind/generated/curve_constants.d.ts.map +1 -0
  294. package/dest/node/cbind/generated/curve_constants.js +45 -0
  295. package/dest/node/cbind/generated/sync.d.ts +62 -0
  296. package/dest/node/cbind/generated/sync.d.ts.map +1 -0
  297. package/dest/node/cbind/generated/sync.js +610 -0
  298. package/dest/node/cbind/schema_compiler.d.ts +68 -0
  299. package/dest/node/cbind/schema_compiler.d.ts.map +1 -0
  300. package/dest/node/cbind/schema_compiler.js +600 -0
  301. package/dest/node/crs/browser/cached_net_crs.d.ts +43 -0
  302. package/dest/node/crs/browser/cached_net_crs.d.ts.map +1 -0
  303. package/dest/node/crs/browser/cached_net_crs.js +95 -0
  304. package/dest/node/crs/browser/index.d.ts +2 -0
  305. package/dest/node/crs/browser/index.d.ts.map +1 -0
  306. package/dest/node/crs/browser/index.js +2 -0
  307. package/dest/node/crs/index.d.ts +2 -0
  308. package/dest/node/crs/index.d.ts.map +1 -0
  309. package/dest/node/crs/index.js +2 -0
  310. package/dest/node/crs/net_crs.d.ts +70 -0
  311. package/dest/node/crs/net_crs.d.ts.map +1 -0
  312. package/dest/node/crs/net_crs.js +141 -0
  313. package/dest/node/crs/node/index.d.ts +38 -0
  314. package/dest/node/crs/node/index.d.ts.map +1 -0
  315. package/dest/node/crs/node/index.js +107 -0
  316. package/dest/node/index.d.ts +9 -0
  317. package/dest/node/index.d.ts.map +1 -0
  318. package/dest/node/index.js +9 -0
  319. package/dest/node/proof/index.d.ts +21 -0
  320. package/dest/node/proof/index.d.ts.map +1 -0
  321. package/dest/node/proof/index.js +63 -0
  322. package/dest/node/random/browser/index.d.ts +2 -0
  323. package/dest/node/random/browser/index.d.ts.map +1 -0
  324. package/dest/node/random/browser/index.js +31 -0
  325. package/dest/node/random/index.d.ts +2 -0
  326. package/dest/node/random/index.d.ts.map +1 -0
  327. package/dest/{random → node/random}/index.js +1 -1
  328. package/dest/node/random/node/index.d.ts +2 -0
  329. package/dest/node/random/node/index.d.ts.map +1 -0
  330. package/dest/node/random/node/index.js +5 -0
  331. package/dest/node/retry/index.d.ts +26 -0
  332. package/dest/node/retry/index.d.ts.map +1 -0
  333. package/dest/node/retry/index.js +50 -0
  334. package/dest/node-cjs/async_map/index.d.ts +10 -0
  335. package/dest/node-cjs/async_map/index.d.ts.map +1 -0
  336. package/dest/node-cjs/async_map/index.js +19 -0
  337. package/dest/node-cjs/barretenberg/backend.d.ts +61 -0
  338. package/dest/node-cjs/barretenberg/backend.d.ts.map +1 -0
  339. package/dest/node-cjs/barretenberg/backend.js +257 -0
  340. package/dest/node-cjs/barretenberg/blake2s.test.d.ts +2 -0
  341. package/dest/node-cjs/barretenberg/blake2s.test.d.ts.map +1 -0
  342. package/dest/node-cjs/barretenberg/blake2s.test.js +59 -0
  343. package/dest/node-cjs/barretenberg/index.d.ts +65 -0
  344. package/dest/node-cjs/barretenberg/index.d.ts.map +1 -0
  345. package/dest/node-cjs/barretenberg/index.js +191 -0
  346. package/dest/node-cjs/barretenberg/pedersen.test.d.ts +2 -0
  347. package/dest/node-cjs/barretenberg/pedersen.test.d.ts.map +1 -0
  348. package/dest/node-cjs/barretenberg/pedersen.test.js +64 -0
  349. package/dest/node-cjs/barretenberg/poseidon.bench.test.d.ts +2 -0
  350. package/dest/node-cjs/barretenberg/poseidon.bench.test.d.ts.map +1 -0
  351. package/dest/node-cjs/barretenberg/poseidon.bench.test.js +220 -0
  352. package/dest/node-cjs/barretenberg/poseidon.test.d.ts +2 -0
  353. package/dest/node-cjs/barretenberg/poseidon.test.d.ts.map +1 -0
  354. package/dest/node-cjs/barretenberg/poseidon.test.js +37 -0
  355. package/dest/node-cjs/barretenberg/testing/bigint-buffer.d.ts +17 -0
  356. package/dest/node-cjs/barretenberg/testing/bigint-buffer.d.ts.map +1 -0
  357. package/dest/node-cjs/barretenberg/testing/bigint-buffer.js +43 -0
  358. package/dest/node-cjs/barretenberg/testing/fields.d.ts +16 -0
  359. package/dest/node-cjs/barretenberg/testing/fields.d.ts.map +1 -0
  360. package/dest/node-cjs/barretenberg/testing/fields.js +51 -0
  361. package/dest/node-cjs/barretenberg_wasm/barretenberg-threads.wasm.gz +0 -0
  362. package/dest/node-cjs/barretenberg_wasm/barretenberg_wasm_base/index.d.ts +45 -0
  363. package/dest/node-cjs/barretenberg_wasm/barretenberg_wasm_base/index.d.ts.map +1 -0
  364. package/dest/node-cjs/barretenberg_wasm/barretenberg_wasm_base/index.js +128 -0
  365. package/dest/node-cjs/barretenberg_wasm/barretenberg_wasm_main/factory/browser/index.d.ts +2 -0
  366. package/dest/node-cjs/barretenberg_wasm/barretenberg_wasm_main/factory/browser/index.d.ts.map +1 -0
  367. package/dest/node-cjs/barretenberg_wasm/barretenberg_wasm_main/factory/browser/index.js +12 -0
  368. package/dest/node-cjs/barretenberg_wasm/barretenberg_wasm_main/factory/browser/main.worker.d.ts +2 -0
  369. package/dest/node-cjs/barretenberg_wasm/barretenberg_wasm_main/factory/browser/main.worker.d.ts.map +1 -0
  370. package/dest/node-cjs/barretenberg_wasm/barretenberg_wasm_main/factory/browser/main.worker.js +8 -0
  371. package/dest/node-cjs/barretenberg_wasm/barretenberg_wasm_main/factory/node/index.d.ts +3 -0
  372. package/dest/node-cjs/barretenberg_wasm/barretenberg_wasm_main/factory/node/index.d.ts.map +1 -0
  373. package/dest/node-cjs/barretenberg_wasm/barretenberg_wasm_main/factory/node/index.js +22 -0
  374. package/dest/node-cjs/barretenberg_wasm/barretenberg_wasm_main/factory/node/main.worker.d.ts +2 -0
  375. package/dest/node-cjs/barretenberg_wasm/barretenberg_wasm_main/factory/node/main.worker.d.ts.map +1 -0
  376. package/dest/node-cjs/barretenberg_wasm/barretenberg_wasm_main/factory/node/main.worker.js +11 -0
  377. package/dest/node-cjs/barretenberg_wasm/barretenberg_wasm_main/heap_allocator.d.ts +21 -0
  378. package/dest/node-cjs/barretenberg_wasm/barretenberg_wasm_main/heap_allocator.d.ts.map +1 -0
  379. package/dest/node-cjs/barretenberg_wasm/barretenberg_wasm_main/heap_allocator.js +75 -0
  380. package/dest/node-cjs/barretenberg_wasm/barretenberg_wasm_main/index.d.ts +59 -0
  381. package/dest/node-cjs/barretenberg_wasm/barretenberg_wasm_main/index.d.ts.map +1 -0
  382. package/dest/node-cjs/barretenberg_wasm/barretenberg_wasm_main/index.js +201 -0
  383. package/dest/node-cjs/barretenberg_wasm/barretenberg_wasm_thread/factory/browser/index.d.ts +2 -0
  384. package/dest/node-cjs/barretenberg_wasm/barretenberg_wasm_thread/factory/browser/index.d.ts.map +1 -0
  385. package/dest/node-cjs/barretenberg_wasm/barretenberg_wasm_thread/factory/browser/index.js +12 -0
  386. package/dest/node-cjs/barretenberg_wasm/barretenberg_wasm_thread/factory/browser/thread.worker.d.ts +2 -0
  387. package/dest/node-cjs/barretenberg_wasm/barretenberg_wasm_thread/factory/browser/thread.worker.d.ts.map +1 -0
  388. package/dest/node-cjs/barretenberg_wasm/barretenberg_wasm_thread/factory/browser/thread.worker.js +8 -0
  389. package/dest/node-cjs/barretenberg_wasm/barretenberg_wasm_thread/factory/node/index.d.ts +3 -0
  390. package/dest/node-cjs/barretenberg_wasm/barretenberg_wasm_thread/factory/node/index.d.ts.map +1 -0
  391. package/dest/node-cjs/barretenberg_wasm/barretenberg_wasm_thread/factory/node/index.js +22 -0
  392. package/dest/node-cjs/barretenberg_wasm/barretenberg_wasm_thread/factory/node/thread.worker.d.ts +2 -0
  393. package/dest/node-cjs/barretenberg_wasm/barretenberg_wasm_thread/factory/node/thread.worker.d.ts.map +1 -0
  394. package/dest/node-cjs/barretenberg_wasm/barretenberg_wasm_thread/factory/node/thread.worker.js +12 -0
  395. package/dest/node-cjs/barretenberg_wasm/barretenberg_wasm_thread/index.d.ts +30 -0
  396. package/dest/node-cjs/barretenberg_wasm/barretenberg_wasm_thread/index.d.ts.map +1 -0
  397. package/dest/node-cjs/barretenberg_wasm/barretenberg_wasm_thread/index.js +45 -0
  398. package/dest/node-cjs/barretenberg_wasm/fetch_code/browser/barretenberg-threads.d.ts +3 -0
  399. package/dest/node-cjs/barretenberg_wasm/fetch_code/browser/barretenberg-threads.d.ts.map +1 -0
  400. package/dest/node-cjs/barretenberg_wasm/fetch_code/browser/barretenberg-threads.js +6 -0
  401. package/dest/node-cjs/barretenberg_wasm/fetch_code/browser/barretenberg.d.ts +3 -0
  402. package/dest/node-cjs/barretenberg_wasm/fetch_code/browser/barretenberg.d.ts.map +1 -0
  403. package/dest/node-cjs/barretenberg_wasm/fetch_code/browser/barretenberg.js +6 -0
  404. package/dest/node-cjs/barretenberg_wasm/fetch_code/browser/index.d.ts +2 -0
  405. package/dest/node-cjs/barretenberg_wasm/fetch_code/browser/index.d.ts.map +1 -0
  406. package/dest/node-cjs/barretenberg_wasm/fetch_code/browser/index.js +40 -0
  407. package/dest/node-cjs/barretenberg_wasm/fetch_code/index.d.ts +2 -0
  408. package/dest/node-cjs/barretenberg_wasm/fetch_code/index.d.ts.map +1 -0
  409. package/dest/node-cjs/barretenberg_wasm/fetch_code/index.js +5 -0
  410. package/dest/node-cjs/barretenberg_wasm/fetch_code/node/index.d.ts +2 -0
  411. package/dest/node-cjs/barretenberg_wasm/fetch_code/node/index.d.ts.map +1 -0
  412. package/dest/node-cjs/barretenberg_wasm/fetch_code/node/index.js +39 -0
  413. package/dest/node-cjs/barretenberg_wasm/helpers/browser/index.d.ts +13 -0
  414. package/dest/node-cjs/barretenberg_wasm/helpers/browser/index.d.ts.map +1 -0
  415. package/dest/node-cjs/barretenberg_wasm/helpers/browser/index.js +57 -0
  416. package/dest/node-cjs/barretenberg_wasm/helpers/index.d.ts +2 -0
  417. package/dest/node-cjs/barretenberg_wasm/helpers/index.d.ts.map +1 -0
  418. package/dest/node-cjs/barretenberg_wasm/helpers/index.js +5 -0
  419. package/dest/node-cjs/barretenberg_wasm/helpers/node/index.d.ts +21 -0
  420. package/dest/node-cjs/barretenberg_wasm/helpers/node/index.d.ts.map +1 -0
  421. package/dest/node-cjs/barretenberg_wasm/helpers/node/index.js +65 -0
  422. package/dest/node-cjs/barretenberg_wasm/helpers/node/node_endpoint.d.ts +8 -0
  423. package/dest/node-cjs/barretenberg_wasm/helpers/node/node_endpoint.d.ts.map +1 -0
  424. package/dest/node-cjs/barretenberg_wasm/helpers/node/node_endpoint.js +31 -0
  425. package/dest/node-cjs/barretenberg_wasm/index.d.ts +5 -0
  426. package/dest/node-cjs/barretenberg_wasm/index.d.ts.map +1 -0
  427. package/dest/node-cjs/barretenberg_wasm/index.js +18 -0
  428. package/dest/node-cjs/barretenberg_wasm/index.test.d.ts +2 -0
  429. package/dest/node-cjs/barretenberg_wasm/index.test.d.ts.map +1 -0
  430. package/dest/node-cjs/barretenberg_wasm/index.test.js +41 -0
  431. package/dest/node-cjs/bb_backends/browser/index.d.ts +11 -0
  432. package/dest/node-cjs/bb_backends/browser/index.d.ts.map +1 -0
  433. package/dest/node-cjs/bb_backends/browser/index.js +43 -0
  434. package/dest/node-cjs/bb_backends/browser/platform.d.ts +4 -0
  435. package/dest/node-cjs/bb_backends/browser/platform.d.ts.map +1 -0
  436. package/dest/node-cjs/bb_backends/browser/platform.js +15 -0
  437. package/dest/node-cjs/bb_backends/index.d.ts +48 -0
  438. package/dest/node-cjs/bb_backends/index.d.ts.map +1 -0
  439. package/dest/node-cjs/bb_backends/index.js +18 -0
  440. package/dest/node-cjs/bb_backends/interface.d.ts +33 -0
  441. package/dest/node-cjs/bb_backends/interface.d.ts.map +1 -0
  442. package/dest/node-cjs/bb_backends/interface.js +3 -0
  443. package/dest/node-cjs/bb_backends/node/index.d.ts +11 -0
  444. package/dest/node-cjs/bb_backends/node/index.d.ts.map +1 -0
  445. package/dest/node-cjs/bb_backends/node/index.js +90 -0
  446. package/dest/node-cjs/bb_backends/node/native_pipe.d.ts +25 -0
  447. package/dest/node-cjs/bb_backends/node/native_pipe.d.ts.map +1 -0
  448. package/dest/node-cjs/bb_backends/node/native_pipe.js +118 -0
  449. package/dest/node-cjs/bb_backends/node/native_shm.d.ts +28 -0
  450. package/dest/node-cjs/bb_backends/node/native_shm.d.ts.map +1 -0
  451. package/dest/node-cjs/bb_backends/node/native_shm.js +181 -0
  452. package/dest/node-cjs/bb_backends/node/native_shm_async.d.ts +51 -0
  453. package/dest/node-cjs/bb_backends/node/native_shm_async.d.ts.map +1 -0
  454. package/dest/node-cjs/bb_backends/node/native_shm_async.js +241 -0
  455. package/dest/node-cjs/bb_backends/node/native_socket.d.ts +34 -0
  456. package/dest/node-cjs/bb_backends/node/native_socket.d.ts.map +1 -0
  457. package/dest/node-cjs/bb_backends/node/native_socket.js +286 -0
  458. package/dest/node-cjs/bb_backends/node/platform.d.ts +27 -0
  459. package/dest/node-cjs/bb_backends/node/platform.d.ts.map +1 -0
  460. package/dest/node-cjs/bb_backends/node/platform.js +131 -0
  461. package/dest/node-cjs/bb_backends/wasm.d.ts +49 -0
  462. package/dest/node-cjs/bb_backends/wasm.d.ts.map +1 -0
  463. package/dest/node-cjs/bb_backends/wasm.js +90 -0
  464. package/dest/node-cjs/bbapi/exception_handling.test.d.ts +2 -0
  465. package/dest/node-cjs/bbapi/exception_handling.test.d.ts.map +1 -0
  466. package/dest/node-cjs/bbapi/exception_handling.test.js +50 -0
  467. package/dest/node-cjs/bbapi_exception.d.ts +7 -0
  468. package/dest/node-cjs/bbapi_exception.d.ts.map +1 -0
  469. package/dest/node-cjs/bbapi_exception.js +18 -0
  470. package/dest/node-cjs/benchmark/index.d.ts +3 -0
  471. package/dest/node-cjs/benchmark/index.d.ts.map +1 -0
  472. package/dest/node-cjs/benchmark/index.js +29 -0
  473. package/dest/node-cjs/benchmark/timer.d.ts +34 -0
  474. package/dest/node-cjs/benchmark/timer.d.ts.map +1 -0
  475. package/dest/node-cjs/benchmark/timer.js +46 -0
  476. package/dest/node-cjs/bin/index.d.ts +3 -0
  477. package/dest/node-cjs/bin/index.d.ts.map +1 -0
  478. package/dest/node-cjs/bin/index.js +13 -0
  479. package/dest/node-cjs/cbind/generate.d.ts +5 -0
  480. package/dest/node-cjs/cbind/generate.d.ts.map +1 -0
  481. package/dest/node-cjs/cbind/generate.js +153 -0
  482. package/dest/node-cjs/cbind/generated/api_types.d.ts +2051 -0
  483. package/dest/node-cjs/cbind/generated/api_types.d.ts.map +1 -0
  484. package/dest/node-cjs/cbind/generated/api_types.js +2989 -0
  485. package/dest/node-cjs/cbind/generated/async.d.ts +62 -0
  486. package/dest/node-cjs/cbind/generated/async.d.ts.map +1 -0
  487. package/dest/node-cjs/cbind/generated/async.js +667 -0
  488. package/dest/node-cjs/cbind/generated/curve_constants.d.ts +45 -0
  489. package/dest/node-cjs/cbind/generated/curve_constants.d.ts.map +1 -0
  490. package/dest/node-cjs/cbind/generated/curve_constants.js +48 -0
  491. package/dest/node-cjs/cbind/generated/sync.d.ts +62 -0
  492. package/dest/node-cjs/cbind/generated/sync.d.ts.map +1 -0
  493. package/dest/node-cjs/cbind/generated/sync.js +614 -0
  494. package/dest/node-cjs/cbind/schema_compiler.d.ts +68 -0
  495. package/dest/node-cjs/cbind/schema_compiler.d.ts.map +1 -0
  496. package/dest/node-cjs/cbind/schema_compiler.js +607 -0
  497. package/dest/node-cjs/crs/browser/cached_net_crs.d.ts +43 -0
  498. package/dest/node-cjs/crs/browser/cached_net_crs.d.ts.map +1 -0
  499. package/dest/node-cjs/crs/browser/cached_net_crs.js +100 -0
  500. package/dest/node-cjs/crs/browser/index.d.ts +2 -0
  501. package/dest/node-cjs/crs/browser/index.d.ts.map +1 -0
  502. package/dest/node-cjs/crs/browser/index.js +7 -0
  503. package/dest/node-cjs/crs/index.d.ts +2 -0
  504. package/dest/node-cjs/crs/index.d.ts.map +1 -0
  505. package/dest/node-cjs/crs/index.js +7 -0
  506. package/dest/node-cjs/crs/net_crs.d.ts +70 -0
  507. package/dest/node-cjs/crs/net_crs.d.ts.map +1 -0
  508. package/dest/node-cjs/crs/net_crs.js +146 -0
  509. package/dest/node-cjs/crs/node/index.d.ts +38 -0
  510. package/dest/node-cjs/crs/node/index.d.ts.map +1 -0
  511. package/dest/node-cjs/crs/node/index.js +112 -0
  512. package/dest/node-cjs/index.d.ts +9 -0
  513. package/dest/node-cjs/index.d.ts.map +1 -0
  514. package/dest/node-cjs/index.js +39 -0
  515. package/dest/node-cjs/package.json +3 -0
  516. package/dest/node-cjs/proof/index.d.ts +21 -0
  517. package/dest/node-cjs/proof/index.d.ts.map +1 -0
  518. package/dest/node-cjs/proof/index.js +72 -0
  519. package/dest/node-cjs/random/browser/index.d.ts +2 -0
  520. package/dest/node-cjs/random/browser/index.d.ts.map +1 -0
  521. package/dest/node-cjs/random/browser/index.js +35 -0
  522. package/dest/node-cjs/random/index.d.ts +2 -0
  523. package/dest/node-cjs/random/index.d.ts.map +1 -0
  524. package/dest/node-cjs/random/index.js +5 -0
  525. package/dest/node-cjs/random/node/index.d.ts +2 -0
  526. package/dest/node-cjs/random/node/index.d.ts.map +1 -0
  527. package/dest/node-cjs/random/node/index.js +8 -0
  528. package/dest/node-cjs/retry/index.d.ts +26 -0
  529. package/dest/node-cjs/retry/index.d.ts.map +1 -0
  530. package/dest/node-cjs/retry/index.js +55 -0
  531. package/package.json +59 -46
  532. package/src/barretenberg/__snapshots__/pedersen.test.ts.snap +156 -0
  533. package/src/barretenberg/__snapshots__/poseidon.test.ts.snap +40 -0
  534. package/src/barretenberg/backend.ts +312 -0
  535. package/src/barretenberg/blake2s.test.ts +69 -0
  536. package/src/barretenberg/index.ts +212 -0
  537. package/src/barretenberg/pedersen.test.ts +69 -0
  538. package/src/barretenberg/poseidon.bench.test.ts +271 -0
  539. package/src/barretenberg/poseidon.test.ts +39 -0
  540. package/src/barretenberg/testing/bigint-buffer.ts +43 -0
  541. package/src/barretenberg/testing/fields.ts +63 -0
  542. package/src/barretenberg_wasm/barretenberg_wasm_base/index.ts +137 -0
  543. package/src/barretenberg_wasm/barretenberg_wasm_main/factory/browser/index.ts +9 -0
  544. package/src/barretenberg_wasm/barretenberg_wasm_main/factory/browser/main.worker.ts +6 -0
  545. package/src/barretenberg_wasm/barretenberg_wasm_main/factory/node/index.ts +19 -0
  546. package/src/barretenberg_wasm/barretenberg_wasm_main/factory/node/main.worker.ts +10 -0
  547. package/src/barretenberg_wasm/barretenberg_wasm_main/heap_allocator.ts +72 -0
  548. package/src/barretenberg_wasm/barretenberg_wasm_main/index.ts +251 -0
  549. package/src/barretenberg_wasm/barretenberg_wasm_thread/factory/browser/index.ts +9 -0
  550. package/src/barretenberg_wasm/barretenberg_wasm_thread/factory/browser/thread.worker.ts +6 -0
  551. package/src/barretenberg_wasm/barretenberg_wasm_thread/factory/node/index.ts +19 -0
  552. package/src/barretenberg_wasm/barretenberg_wasm_thread/factory/node/thread.worker.ts +12 -0
  553. package/src/barretenberg_wasm/barretenberg_wasm_thread/index.ts +48 -0
  554. package/src/barretenberg_wasm/fetch_code/browser/barretenberg-threads.ts +3 -0
  555. package/src/barretenberg_wasm/fetch_code/browser/barretenberg.ts +3 -0
  556. package/src/barretenberg_wasm/fetch_code/browser/index.ts +34 -0
  557. package/src/barretenberg_wasm/fetch_code/index.ts +1 -0
  558. package/src/barretenberg_wasm/fetch_code/node/index.ts +34 -0
  559. package/src/barretenberg_wasm/fetch_code/wasm-module.d.ts +4 -0
  560. package/src/barretenberg_wasm/helpers/browser/index.ts +54 -0
  561. package/src/barretenberg_wasm/helpers/index.ts +1 -0
  562. package/src/barretenberg_wasm/helpers/node/index.ts +62 -0
  563. package/src/barretenberg_wasm/index.test.ts +46 -0
  564. package/src/barretenberg_wasm/index.ts +21 -1
  565. package/src/bb_backends/browser/index.ts +50 -0
  566. package/src/bb_backends/browser/platform.ts +11 -0
  567. package/src/bb_backends/index.ts +52 -0
  568. package/src/bb_backends/interface.ts +35 -0
  569. package/src/bb_backends/node/index.ts +102 -0
  570. package/src/bb_backends/node/native_pipe.ts +127 -0
  571. package/src/bb_backends/node/native_shm.ts +195 -0
  572. package/src/bb_backends/node/native_shm_async.ts +266 -0
  573. package/src/bb_backends/node/native_socket.ts +326 -0
  574. package/src/bb_backends/node/platform.ts +151 -0
  575. package/src/bb_backends/wasm.ts +102 -0
  576. package/src/bbapi/exception_handling.test.ts +54 -0
  577. package/src/bbapi_exception.ts +13 -0
  578. package/src/benchmark/index.ts +26 -0
  579. package/src/benchmark/timer.ts +45 -0
  580. package/src/bin/index.ts +14 -0
  581. package/src/cbind/README.md +1 -0
  582. package/src/cbind/generate.ts +182 -0
  583. package/src/cbind/schema_compiler.ts +745 -0
  584. package/src/crs/browser/cached_net_crs.ts +41 -1
  585. package/src/crs/browser/index.ts +1 -1
  586. package/src/crs/index.ts +1 -1
  587. package/src/crs/net_crs.ts +114 -19
  588. package/src/crs/node/index.ts +95 -26
  589. package/src/index.html +1 -1
  590. package/src/index.ts +43 -5
  591. package/src/proof/index.ts +94 -0
  592. package/src/random/browser/index.ts +1 -1
  593. package/src/retry/index.ts +50 -0
  594. package/dest/async_map/index.d.ts.map +0 -1
  595. package/dest/barretenberg-threads.wasm +0 -0
  596. package/dest/barretenberg.wasm +0 -0
  597. package/dest/barretenberg_api/blake2s.test.d.ts +0 -2
  598. package/dest/barretenberg_api/blake2s.test.d.ts.map +0 -1
  599. package/dest/barretenberg_api/blake2s.test.js +0 -30
  600. package/dest/barretenberg_api/common.test.d.ts +0 -2
  601. package/dest/barretenberg_api/common.test.d.ts.map +0 -1
  602. package/dest/barretenberg_api/common.test.js +0 -18
  603. package/dest/barretenberg_api/index.d.ts +0 -103
  604. package/dest/barretenberg_api/index.d.ts.map +0 -1
  605. package/dest/barretenberg_api/index.js +0 -379
  606. package/dest/barretenberg_api/pedersen.test.d.ts +0 -2
  607. package/dest/barretenberg_api/pedersen.test.d.ts.map +0 -1
  608. package/dest/barretenberg_api/pedersen.test.js +0 -69
  609. package/dest/barretenberg_api/schnorr.test.d.ts +0 -2
  610. package/dest/barretenberg_api/schnorr.test.d.ts.map +0 -1
  611. package/dest/barretenberg_api/schnorr.test.js +0 -113
  612. package/dest/barretenberg_binder/heap_allocator.d.ts +0 -22
  613. package/dest/barretenberg_binder/heap_allocator.d.ts.map +0 -1
  614. package/dest/barretenberg_binder/heap_allocator.js +0 -59
  615. package/dest/barretenberg_binder/heap_allocator_sync.d.ts +0 -22
  616. package/dest/barretenberg_binder/heap_allocator_sync.d.ts.map +0 -1
  617. package/dest/barretenberg_binder/heap_allocator_sync.js +0 -58
  618. package/dest/barretenberg_binder/index.d.ts +0 -32
  619. package/dest/barretenberg_binder/index.d.ts.map +0 -1
  620. package/dest/barretenberg_binder/index.js +0 -73
  621. package/dest/barretenberg_wasm/barretenberg_wasm.d.ts +0 -50
  622. package/dest/barretenberg_wasm/barretenberg_wasm.d.ts.map +0 -1
  623. package/dest/barretenberg_wasm/barretenberg_wasm.js +0 -212
  624. package/dest/barretenberg_wasm/barretenberg_wasm.test.d.ts +0 -2
  625. package/dest/barretenberg_wasm/barretenberg_wasm.test.d.ts.map +0 -1
  626. package/dest/barretenberg_wasm/barretenberg_wasm.test.js +0 -43
  627. package/dest/barretenberg_wasm/browser/index.d.ts +0 -8
  628. package/dest/barretenberg_wasm/browser/index.d.ts.map +0 -1
  629. package/dest/barretenberg_wasm/browser/index.js +0 -26
  630. package/dest/barretenberg_wasm/browser/worker.d.ts +0 -2
  631. package/dest/barretenberg_wasm/browser/worker.d.ts.map +0 -1
  632. package/dest/barretenberg_wasm/browser/worker.js +0 -11
  633. package/dest/barretenberg_wasm/index.d.ts +0 -2
  634. package/dest/barretenberg_wasm/index.d.ts.map +0 -1
  635. package/dest/barretenberg_wasm/index.js +0 -2
  636. package/dest/barretenberg_wasm/node/index.d.ts +0 -17
  637. package/dest/barretenberg_wasm/node/index.d.ts.map +0 -1
  638. package/dest/barretenberg_wasm/node/index.js +0 -40
  639. package/dest/barretenberg_wasm/node/node_endpoint.d.ts +0 -8
  640. package/dest/barretenberg_wasm/node/node_endpoint.d.ts.map +0 -1
  641. package/dest/barretenberg_wasm/node/node_endpoint.js +0 -28
  642. package/dest/barretenberg_wasm/node/worker.d.ts +0 -2
  643. package/dest/barretenberg_wasm/node/worker.d.ts.map +0 -1
  644. package/dest/barretenberg_wasm/node/worker.js +0 -9
  645. package/dest/barretenberg_wasm.js +0 -2
  646. package/dest/barretenberg_wasm.js.LICENSE.txt +0 -5
  647. package/dest/bigint-array/index.d.ts +0 -3
  648. package/dest/bigint-array/index.d.ts.map +0 -1
  649. package/dest/bigint-array/index.js +0 -21
  650. package/dest/bindgen/function_declaration.d.ts +0 -11
  651. package/dest/bindgen/function_declaration.d.ts.map +0 -1
  652. package/dest/bindgen/function_declaration.js +0 -2
  653. package/dest/bindgen/index.d.ts +0 -2
  654. package/dest/bindgen/index.js +0 -15
  655. package/dest/bindgen/mappings.d.ts +0 -4
  656. package/dest/bindgen/mappings.d.ts.map +0 -1
  657. package/dest/bindgen/mappings.js +0 -63
  658. package/dest/bindgen/rust.d.ts +0 -2
  659. package/dest/bindgen/rust.d.ts.map +0 -1
  660. package/dest/bindgen/rust.js +0 -43
  661. package/dest/bindgen/to_camel_case.d.ts +0 -2
  662. package/dest/bindgen/to_camel_case.d.ts.map +0 -1
  663. package/dest/bindgen/to_camel_case.js +0 -11
  664. package/dest/bindgen/typescript.d.ts +0 -2
  665. package/dest/bindgen/typescript.d.ts.map +0 -1
  666. package/dest/bindgen/typescript.js +0 -80
  667. package/dest/crs/browser/cached_net_crs.d.ts +0 -25
  668. package/dest/crs/browser/cached_net_crs.d.ts.map +0 -1
  669. package/dest/crs/browser/cached_net_crs.js +0 -54
  670. package/dest/crs/browser/index.d.ts +0 -2
  671. package/dest/crs/browser/index.d.ts.map +0 -1
  672. package/dest/crs/browser/index.js +0 -2
  673. package/dest/crs/index.d.ts +0 -2
  674. package/dest/crs/index.d.ts.map +0 -1
  675. package/dest/crs/index.js +0 -2
  676. package/dest/crs/net_crs.d.ts +0 -36
  677. package/dest/crs/net_crs.d.ts.map +0 -1
  678. package/dest/crs/net_crs.js +0 -59
  679. package/dest/crs/node/ignition_files_crs.d.ts +0 -37
  680. package/dest/crs/node/ignition_files_crs.d.ts.map +0 -1
  681. package/dest/crs/node/ignition_files_crs.js +0 -51
  682. package/dest/crs/node/index.d.ts +0 -21
  683. package/dest/crs/node/index.d.ts.map +0 -1
  684. package/dest/crs/node/index.js +0 -54
  685. package/dest/examples/simple.rawtest.d.ts +0 -2
  686. package/dest/examples/simple.rawtest.d.ts.map +0 -1
  687. package/dest/examples/simple.rawtest.js +0 -29
  688. package/dest/examples/simple.test.d.ts +0 -2
  689. package/dest/examples/simple.test.d.ts.map +0 -1
  690. package/dest/examples/simple.test.js +0 -22
  691. package/dest/factory/index.d.ts +0 -21
  692. package/dest/factory/index.d.ts.map +0 -1
  693. package/dest/factory/index.js +0 -34
  694. package/dest/index.d.ts +0 -6
  695. package/dest/index.d.ts.map +0 -1
  696. package/dest/index.html +0 -1
  697. package/dest/index.js +0 -6
  698. package/dest/main.d.ts +0 -10
  699. package/dest/main.d.ts.map +0 -1
  700. package/dest/main.js +0 -275
  701. package/dest/random/browser/index.d.ts +0 -2
  702. package/dest/random/browser/index.d.ts.map +0 -1
  703. package/dest/random/browser/index.js +0 -31
  704. package/dest/random/index.d.ts +0 -2
  705. package/dest/random/index.d.ts.map +0 -1
  706. package/dest/random/node/index.d.ts +0 -2
  707. package/dest/random/node/index.d.ts.map +0 -1
  708. package/dest/random/node/index.js +0 -5
  709. package/dest/serialize/buffer_reader.d.ts +0 -28
  710. package/dest/serialize/buffer_reader.d.ts.map +0 -1
  711. package/dest/serialize/buffer_reader.js +0 -66
  712. package/dest/serialize/index.d.ts +0 -4
  713. package/dest/serialize/index.d.ts.map +0 -1
  714. package/dest/serialize/index.js +0 -4
  715. package/dest/serialize/output_type.d.ts +0 -11
  716. package/dest/serialize/output_type.d.ts.map +0 -1
  717. package/dest/serialize/output_type.js +0 -44
  718. package/dest/serialize/serialize.d.ts +0 -53
  719. package/dest/serialize/serialize.d.ts.map +0 -1
  720. package/dest/serialize/serialize.js +0 -139
  721. package/dest/simple_test.js +0 -2
  722. package/dest/simple_test.js.LICENSE.txt +0 -14
  723. package/dest/types/fields.d.ts +0 -33
  724. package/dest/types/fields.d.ts.map +0 -1
  725. package/dest/types/fields.js +0 -86
  726. package/dest/types/fixed_size_buffer.d.ts +0 -26
  727. package/dest/types/fixed_size_buffer.d.ts.map +0 -1
  728. package/dest/types/fixed_size_buffer.js +0 -54
  729. package/dest/types/index.d.ts +0 -6
  730. package/dest/types/index.d.ts.map +0 -1
  731. package/dest/types/index.js +0 -6
  732. package/dest/types/point.d.ts +0 -17
  733. package/dest/types/point.d.ts.map +0 -1
  734. package/dest/types/point.js +0 -32
  735. package/dest/types/ptr.d.ts +0 -13
  736. package/dest/types/ptr.d.ts.map +0 -1
  737. package/dest/types/ptr.js +0 -20
  738. package/dest/types/raw_buffer.d.ts +0 -3
  739. package/dest/types/raw_buffer.d.ts.map +0 -1
  740. package/dest/types/raw_buffer.js +0 -5
  741. package/src/barretenberg_api/blake2s.test.ts +0 -39
  742. package/src/barretenberg_api/common.test.ts +0 -21
  743. package/src/barretenberg_api/index.ts +0 -649
  744. package/src/barretenberg_api/pedersen.test.ts +0 -84
  745. package/src/barretenberg_api/schnorr.test.ts +0 -169
  746. package/src/barretenberg_binder/heap_allocator.ts +0 -62
  747. package/src/barretenberg_binder/heap_allocator_sync.ts +0 -61
  748. package/src/barretenberg_binder/index.ts +0 -76
  749. package/src/barretenberg_wasm/barretenberg_wasm.test.ts +0 -52
  750. package/src/barretenberg_wasm/barretenberg_wasm.ts +0 -246
  751. package/src/barretenberg_wasm/browser/index.ts +0 -32
  752. package/src/barretenberg_wasm/browser/worker.ts +0 -13
  753. package/src/barretenberg_wasm/node/index.ts +0 -46
  754. package/src/barretenberg_wasm/node/worker.ts +0 -10
  755. package/src/bigint-array/index.ts +0 -21
  756. package/src/bindgen/function_declaration.ts +0 -11
  757. package/src/bindgen/index.ts +0 -17
  758. package/src/bindgen/mappings.ts +0 -66
  759. package/src/bindgen/rust.ts +0 -52
  760. package/src/bindgen/to_camel_case.ts +0 -10
  761. package/src/bindgen/typescript.ts +0 -91
  762. package/src/crs/node/ignition_files_crs.ts +0 -60
  763. package/src/examples/simple.rawtest.ts +0 -37
  764. package/src/examples/simple.test.ts +0 -27
  765. package/src/factory/index.ts +0 -36
  766. package/src/main.ts +0 -311
  767. package/src/serialize/buffer_reader.ts +0 -82
  768. package/src/serialize/index.ts +0 -3
  769. package/src/serialize/output_type.ts +0 -53
  770. package/src/serialize/serialize.ts +0 -157
  771. package/src/types/fields.ts +0 -98
  772. package/src/types/fixed_size_buffer.ts +0 -59
  773. package/src/types/index.ts +0 -5
  774. package/src/types/point.ts +0 -35
  775. package/src/types/ptr.ts +0 -20
  776. package/src/types/raw_buffer.ts +0 -3
  777. /package/src/barretenberg_wasm/{node → helpers/node}/node_endpoint.ts +0 -0
@@ -0,0 +1,745 @@
1
+ /**
2
+ * Unified schema compiler with integrated strategies
3
+ */
4
+
5
+ // Core type definitions
6
+ export type Schema =
7
+ | string
8
+ | ObjectSchema
9
+ | ['tuple', Schema[]]
10
+ | ['map', [Schema, Schema]]
11
+ | ['optional', [Schema]]
12
+ | ['vector', [Schema]]
13
+ | ['variant', Schema[]]
14
+ | ['named_union', Array<[string, Schema]>]
15
+ | ['shared_ptr', [Schema]]
16
+ | ['array', [Schema, number]]
17
+ | ['alias', [string, string]];
18
+
19
+ export type ObjectSchema = { [key: string]: Schema };
20
+
21
+ export interface TypeInfo {
22
+ typeName: string;
23
+ msgpackTypeName?: string;
24
+ declaration?: string;
25
+ toMethod?: string;
26
+ fromMethod?: string;
27
+ }
28
+
29
+ export interface FunctionMetadata {
30
+ name: string;
31
+ commandType: string;
32
+ responseType: string;
33
+ }
34
+
35
+ // Compiler configuration
36
+ export interface CompilerConfig {
37
+ mode: 'types' | 'sync' | 'async';
38
+ imports?: string[];
39
+ wasmImport?: string;
40
+ }
41
+
42
+ // Helper functions
43
+ function capitalize(s: string): string {
44
+ return s.charAt(0).toUpperCase() + s.substring(1);
45
+ }
46
+
47
+ function camelCase(s: string): string {
48
+ return s
49
+ .split('_')
50
+ .map((part, index) => (index === 0 ? part.charAt(0).toLowerCase() + part.substring(1) : capitalize(part)))
51
+ .join('');
52
+ }
53
+
54
+ function pascalCase(s: string): string {
55
+ return s.split('_').map(capitalize).join('');
56
+ }
57
+
58
+ export class SchemaCompiler {
59
+ private typeCache = new Map<string, TypeInfo>();
60
+ private functionMetadata: FunctionMetadata[] = [];
61
+ // WORKTODO(bbapi): AI slop fixup - redundant with typeCache, remove
62
+ private referencedTypes = new Set<string>();
63
+
64
+ constructor(private config: CompilerConfig) {}
65
+
66
+ /**
67
+ * Process API schema and extract function metadata
68
+ */
69
+ processApiSchema(commandsSchema: Schema, responsesSchema: Schema): void {
70
+ // Process types
71
+ this.processSchema(commandsSchema);
72
+ this.processSchema(responsesSchema);
73
+
74
+ // Extract function metadata from named unions
75
+ if (
76
+ !Array.isArray(commandsSchema) ||
77
+ commandsSchema[0] !== 'named_union' ||
78
+ !Array.isArray(responsesSchema) ||
79
+ responsesSchema[0] !== 'named_union'
80
+ ) {
81
+ throw new Error('Expected named_union schema format');
82
+ }
83
+
84
+ const commands = commandsSchema[1] as Array<[string, Schema]>;
85
+ const responses = responsesSchema[1] as Array<[string, Schema]>;
86
+
87
+ // Filter out ErrorResponse - it's a special error variant, not a command response
88
+ const normalResponses = responses.filter(([name]) => name !== 'ErrorResponse');
89
+
90
+ if (commands.length !== normalResponses.length) {
91
+ throw new Error(`Command count (${commands.length}) does not match response count (${normalResponses.length})`);
92
+ }
93
+
94
+ for (let i = 0; i < commands.length; i++) {
95
+ const [commandName] = commands[i];
96
+ const [responseName] = normalResponses[i];
97
+
98
+ this.functionMetadata.push({
99
+ name: camelCase(commandName),
100
+ commandType: pascalCase(commandName),
101
+ responseType: pascalCase(responseName),
102
+ });
103
+ }
104
+ }
105
+
106
+ /**
107
+ * Process a schema and populate type cache
108
+ */
109
+ processSchema(schema: Schema): TypeInfo {
110
+ const key = this.getSchemaKey(schema);
111
+ if (this.typeCache.has(key)) {
112
+ const ret = this.typeCache.get(key)!;
113
+ if (ret.typeName === 'unknown') {
114
+ throw new Error(`Recursive schema detected at ${key}, please check your schema for circular references.`);
115
+ }
116
+ return ret;
117
+ }
118
+
119
+ this.typeCache.set(key, { typeName: 'unknown', msgpackTypeName: '' });
120
+ const typeInfo = this.generateTypeInfo(schema);
121
+ this.typeCache.set(key, typeInfo);
122
+ return typeInfo;
123
+ }
124
+
125
+ /**
126
+ * Generate the complete output
127
+ */
128
+ compile(): string {
129
+ const parts: string[] = ['// AUTOGENERATED FILE - DO NOT EDIT', ''];
130
+
131
+ // Generate imports
132
+ parts.push(...this.generateImports());
133
+ parts.push('');
134
+
135
+ // Generate type declarations only for 'types' mode
136
+ if (this.config.mode === 'types') {
137
+ const sortedTypes = Array.from(this.typeCache.values())
138
+ .filter(t => t.declaration)
139
+ .sort((a, b) => a.typeName.localeCompare(b.typeName));
140
+
141
+ // Group declarations
142
+ const typeAliases = sortedTypes.filter(
143
+ t => t.declaration?.startsWith('export type') && !t.declaration?.includes('interface'),
144
+ );
145
+ const publicInterfaces = sortedTypes.filter(t => t.declaration?.includes('export interface'));
146
+ const privateInterfaces = sortedTypes.filter(t => t.declaration?.includes('interface Msgpack'));
147
+
148
+ // Add type aliases if needed
149
+ if (typeAliases.length > 0) {
150
+ parts.push('// Type aliases');
151
+ for (const type of typeAliases) {
152
+ parts.push(type.declaration!);
153
+ }
154
+ parts.push('');
155
+ }
156
+
157
+ // Add tuple helper if needed
158
+ if (this.needsTupleHelper()) {
159
+ parts.push(
160
+ '// Tuple type for fixed-size arrays',
161
+ 'type Tuple<T, N extends number> = N extends N ? (number extends N ? T[] : _TupleOf<T, N, []>) : never;',
162
+ "type _TupleOf<T, N extends number, R extends unknown[]> = R['length'] extends N ? R : _TupleOf<T, N, [T, ...R]>;",
163
+ '',
164
+ '// Helper functions',
165
+ 'function mapTuple<T, S, N extends number>(tuple: Tuple<T, N>, fn: (item: T) => S): Tuple<S, N> {',
166
+ ' return tuple.map(fn) as Tuple<S, N>;',
167
+ '}',
168
+ '',
169
+ );
170
+ }
171
+
172
+ // Add public interfaces
173
+ if (publicInterfaces.length > 0) {
174
+ parts.push('// Public interfaces (exported)');
175
+ for (const type of publicInterfaces) {
176
+ parts.push(type.declaration!, '');
177
+ }
178
+ }
179
+
180
+ // Add private interfaces
181
+ if (privateInterfaces.length > 0) {
182
+ parts.push('// Private Msgpack interfaces (not exported)');
183
+ for (const type of privateInterfaces) {
184
+ parts.push(type.declaration!, '');
185
+ }
186
+ }
187
+
188
+ // Add conversion functions (only for api_types.ts)
189
+ const conversions = sortedTypes.filter(t => t.toMethod || t.fromMethod);
190
+ if (conversions.length > 0) {
191
+ parts.push('// Conversion functions (exported)');
192
+ for (const type of conversions) {
193
+ if (type.toMethod) {
194
+ parts.push('export ' + type.toMethod, '');
195
+ }
196
+ if (type.fromMethod) {
197
+ parts.push('export ' + type.fromMethod, '');
198
+ }
199
+ }
200
+ }
201
+
202
+ // Add BbApiBase interface
203
+ if (this.functionMetadata.length > 0) {
204
+ parts.push('', '// Base API interface');
205
+ parts.push(this.generateBbApiBaseInterface());
206
+ }
207
+ }
208
+
209
+ // Add API class for non-types modes
210
+ if (this.config.mode !== 'types' && this.functionMetadata.length > 0) {
211
+ parts.push(this.generateApiClass());
212
+ }
213
+
214
+ return parts.join('\n') + '\n';
215
+ }
216
+
217
+ private getSchemaKey(schema: Schema): string {
218
+ if (typeof schema === 'string') return schema;
219
+ if (Array.isArray(schema)) return JSON.stringify(schema);
220
+ if (typeof schema === 'object') return (schema as any).__typename || JSON.stringify(schema);
221
+ return String(schema);
222
+ }
223
+
224
+ private needsTupleHelper(): boolean {
225
+ return Array.from(this.typeCache.values()).some(t => t.typeName.includes('Tuple<'));
226
+ }
227
+
228
+ private trackTypeUsage(typeName: string): void {
229
+ // Only track for API modes
230
+ if (this.config.mode === 'types') return;
231
+
232
+ // Extract base types from complex types
233
+ const baseTypes = this.extractBaseTypes(typeName);
234
+
235
+ for (const type of baseTypes) {
236
+ // Skip built-in types
237
+ if (['string', 'number', 'boolean', 'Uint8Array'].includes(type)) {
238
+ continue;
239
+ }
240
+
241
+ this.referencedTypes.add(type);
242
+ }
243
+ }
244
+
245
+ private extractBaseTypes(typeName: string): string[] {
246
+ const types: string[] = [];
247
+
248
+ // Handle arrays
249
+ const arrayMatch = typeName.match(/^(.+)\[\]$/);
250
+ if (arrayMatch) {
251
+ types.push(...this.extractBaseTypes(arrayMatch[1]));
252
+ return types;
253
+ }
254
+
255
+ // Handle Tuple
256
+ const tupleMatch = typeName.match(/^Tuple<(.+),\s*\d+>$/);
257
+ if (tupleMatch) {
258
+ types.push(...this.extractBaseTypes(tupleMatch[1]));
259
+ return types;
260
+ }
261
+
262
+ // Handle Record
263
+ const recordMatch = typeName.match(/^Record<(.+),\s*(.+)>$/);
264
+ if (recordMatch) {
265
+ types.push(...this.extractBaseTypes(recordMatch[1]));
266
+ types.push(...this.extractBaseTypes(recordMatch[2]));
267
+ return types;
268
+ }
269
+
270
+ // Handle union types
271
+ if (typeName.includes(' | ')) {
272
+ const parts = typeName.split(' | ');
273
+ for (const part of parts) {
274
+ types.push(...this.extractBaseTypes(part.trim()));
275
+ }
276
+ return types;
277
+ }
278
+
279
+ // Base case - simple type
280
+ types.push(typeName);
281
+ return types;
282
+ }
283
+
284
+ private generateTypeInfo(schema: Schema): TypeInfo {
285
+ if (Array.isArray(schema)) {
286
+ return this.processArraySchema(schema);
287
+ } else if (typeof schema === 'string') {
288
+ return this.processPrimitiveSchema(schema);
289
+ } else if (typeof schema === 'object') {
290
+ return this.processObjectSchema(schema);
291
+ }
292
+ throw new Error(`Unsupported schema type: ${schema}`);
293
+ }
294
+
295
+ private processArraySchema(schema: any[]): TypeInfo {
296
+ const [type, ...args] = schema;
297
+
298
+ switch (type) {
299
+ case 'array': {
300
+ const [subtype, size] = args[0];
301
+ // Special case: byte arrays should be Uint8Array
302
+ if (subtype === 'unsigned char') {
303
+ return { typeName: 'Uint8Array' };
304
+ }
305
+ // For other types, use T[] - idiomatic TypeScript for fixed-length homogeneous arrays
306
+ const subtypeInfo = this.processSchema(subtype);
307
+ return {
308
+ typeName: `${subtypeInfo.typeName}[]`,
309
+ msgpackTypeName: `${subtypeInfo.msgpackTypeName || subtypeInfo.typeName}[]`,
310
+ };
311
+ }
312
+
313
+ case 'variant': {
314
+ const variants = args[0] as Schema[];
315
+ const variantInfos = variants.map(v => this.processSchema(v));
316
+ const typeName = variantInfos.map(v => v.typeName).join(' | ');
317
+ const msgpackUnion = variantInfos.map(v => v.msgpackTypeName || v.typeName).join(' | ');
318
+ return {
319
+ typeName,
320
+ msgpackTypeName: `[number, ${msgpackUnion}]`,
321
+ };
322
+ }
323
+
324
+ case 'named_union': {
325
+ const namedTypes = args[0] as Array<[string, Schema]>;
326
+ const tupleTypes: string[] = [];
327
+
328
+ for (const [name, schemaOrName] of namedTypes) {
329
+ let typeInfo = this.processSchema(schemaOrName);
330
+ // Track usage of the type
331
+ this.trackTypeUsage(typeInfo.typeName);
332
+ tupleTypes.push(`["${name}", ${typeInfo.typeName}]`);
333
+ }
334
+
335
+ return {
336
+ typeName: tupleTypes.join(' | '),
337
+ msgpackTypeName: tupleTypes.join(' | '),
338
+ };
339
+ }
340
+
341
+ case 'vector': {
342
+ const [subtype] = args[0];
343
+ if (subtype === 'unsigned char') {
344
+ return { typeName: 'Uint8Array' };
345
+ }
346
+ const subtypeInfo = this.processSchema(subtype);
347
+ return {
348
+ typeName: `${subtypeInfo.typeName}[]`,
349
+ msgpackTypeName: `${subtypeInfo.msgpackTypeName || subtypeInfo.typeName}[]`,
350
+ };
351
+ }
352
+
353
+ case 'alias': {
354
+ const [rawTypeName, msgpackName] = args[0];
355
+ const typeName = pascalCase(rawTypeName);
356
+ let targetType: string;
357
+
358
+ if (msgpackName.startsWith('bin')) {
359
+ targetType = 'Uint8Array';
360
+ } else if (['int', 'unsigned int', 'unsigned short'].includes(msgpackName)) {
361
+ targetType = 'number';
362
+ } else {
363
+ throw new Error(`Unsupported alias type: ${msgpackName}`);
364
+ }
365
+
366
+ // Create a proper type alias declaration
367
+ return {
368
+ typeName,
369
+ msgpackTypeName: targetType,
370
+ declaration: `export type ${typeName} = ${targetType};`,
371
+ };
372
+ }
373
+
374
+ case 'shared_ptr': {
375
+ const [subtype] = args[0];
376
+ return this.processSchema(subtype);
377
+ }
378
+
379
+ case 'map': {
380
+ const [keyType, valueType] = args[0];
381
+ const keyInfo = this.processSchema(keyType);
382
+ const valueInfo = this.processSchema(valueType);
383
+ return {
384
+ typeName: `Record<${keyInfo.typeName}, ${valueInfo.typeName}>`,
385
+ msgpackTypeName: `Record<${keyInfo.msgpackTypeName || keyInfo.typeName}, ${valueInfo.msgpackTypeName || valueInfo.typeName}>`,
386
+ };
387
+ }
388
+
389
+ default:
390
+ throw new Error(`Unsupported array schema type: ${type}`);
391
+ }
392
+ }
393
+
394
+ private processPrimitiveSchema(schema: string): TypeInfo {
395
+ switch (schema) {
396
+ case 'bool':
397
+ return { typeName: 'boolean' };
398
+ case 'int':
399
+ case 'unsigned int':
400
+ case 'unsigned short':
401
+ case 'unsigned long':
402
+ case 'unsigned char':
403
+ case 'double':
404
+ return { typeName: 'number' };
405
+ case 'string':
406
+ return { typeName: 'string' };
407
+ case 'bin32':
408
+ return { typeName: 'Uint8Array' };
409
+ case 'field2':
410
+ // field2 is an extension field type (fq2) represented as a tuple of two Uint8Arrays
411
+ return {
412
+ typeName: 'Field2',
413
+ msgpackTypeName: '[Uint8Array, Uint8Array]',
414
+ declaration: 'export type Field2 = [Uint8Array, Uint8Array];',
415
+ };
416
+ default:
417
+ return { typeName: pascalCase(schema) };
418
+ }
419
+ }
420
+
421
+ private processObjectSchema(schema: ObjectSchema): TypeInfo {
422
+ const typeName = pascalCase(schema.__typename as string);
423
+ const msgpackTypeName = 'Msgpack' + typeName;
424
+
425
+ const declaration = this.generateInterfaces(typeName, schema);
426
+ const toMethod = this.generateToMethod(typeName, schema);
427
+ const fromMethod = this.generateFromMethod(typeName, schema);
428
+
429
+ return {
430
+ typeName,
431
+ msgpackTypeName,
432
+ declaration,
433
+ toMethod,
434
+ fromMethod,
435
+ };
436
+ }
437
+
438
+ private getOrCreateEmptyType(typeName: string): TypeInfo {
439
+ const key = `empty_${typeName}`;
440
+ if (this.typeCache.has(key)) {
441
+ return this.typeCache.get(key)!;
442
+ }
443
+
444
+ const typeInfo: TypeInfo = {
445
+ typeName,
446
+ msgpackTypeName: 'Msgpack' + typeName,
447
+ declaration: `export interface ${typeName} {}\n\ninterface Msgpack${typeName} {}`,
448
+ toMethod: `function to${typeName}(o: Msgpack${typeName}): ${typeName} {\n return {};\n}`,
449
+ fromMethod: `function from${typeName}(o: ${typeName}): Msgpack${typeName} {\n return {};\n}`,
450
+ };
451
+
452
+ this.typeCache.set(key, typeInfo);
453
+ return typeInfo;
454
+ }
455
+
456
+ private generateInterfaces(name: string, schema: ObjectSchema): string {
457
+ const publicInterface = this.generatePublicInterface(name, schema);
458
+ const msgpackInterface = this.generateMsgpackInterface(name, schema);
459
+ return publicInterface + '\n\n' + msgpackInterface;
460
+ }
461
+
462
+ private generatePublicInterface(name: string, schema: ObjectSchema): string {
463
+ let result = `export interface ${name} {\n`;
464
+ for (const [key, value] of Object.entries(schema)) {
465
+ if (key === '__typename') continue;
466
+ const typeInfo = this.processSchema(value);
467
+
468
+ // Track type usage
469
+ this.trackTypeUsage(typeInfo.typeName);
470
+
471
+ result += ` ${camelCase(key)}: ${typeInfo.typeName};\n`;
472
+ }
473
+ result += '}';
474
+ return result;
475
+ }
476
+
477
+ private generateMsgpackInterface(name: string, schema: ObjectSchema): string {
478
+ let result = `interface Msgpack${name} {\n`;
479
+ for (const [key, value] of Object.entries(schema)) {
480
+ if (key === '__typename') continue;
481
+ const typeInfo = this.processSchema(value);
482
+ result += ` ${key}: ${typeInfo.msgpackTypeName || typeInfo.typeName};\n`;
483
+ }
484
+ result += '}';
485
+ return result;
486
+ }
487
+
488
+ private generateToMethod(name: string, schema: ObjectSchema): string {
489
+ const fields = Object.entries(schema).filter(([key]) => key !== '__typename');
490
+
491
+ if (fields.length === 0) {
492
+ return `function to${name}(o: Msgpack${name}): ${name} {\n return {};\n}`;
493
+ }
494
+
495
+ const checks = fields
496
+ .map(
497
+ ([key]) => ` if (o.${key} === undefined) { throw new Error("Expected ${key} in ${name} deserialization"); }`,
498
+ )
499
+ .join('\n');
500
+
501
+ const conversions = fields
502
+ .map(([key, value]) => {
503
+ const typeInfo = this.processSchema(value);
504
+ const converter = this.generateConverter(typeInfo, `o.${key}`, 'to');
505
+ return ` ${camelCase(key)}: ${converter},`;
506
+ })
507
+ .join('\n');
508
+
509
+ return `function to${name}(o: Msgpack${name}): ${name} {
510
+ ${checks};
511
+ return {
512
+ ${conversions}
513
+ };
514
+ }`;
515
+ }
516
+
517
+ private generateFromMethod(name: string, schema: ObjectSchema): string {
518
+ const fields = Object.entries(schema).filter(([key]) => key !== '__typename');
519
+
520
+ if (fields.length === 0) {
521
+ return `function from${name}(o: ${name}): Msgpack${name} {\n return {};\n}`;
522
+ }
523
+
524
+ const checks = fields
525
+ .map(
526
+ ([key]) =>
527
+ ` if (o.${camelCase(key)} === undefined) { throw new Error("Expected ${camelCase(key)} in ${name} serialization"); }`,
528
+ )
529
+ .join('\n');
530
+
531
+ const conversions = fields
532
+ .map(([key, value]) => {
533
+ const typeInfo = this.processSchema(value);
534
+ const converter = this.generateConverter(typeInfo, `o.${camelCase(key)}`, 'from');
535
+ return ` ${key}: ${converter},`;
536
+ })
537
+ .join('\n');
538
+
539
+ return `function from${name}(o: ${name}): Msgpack${name} {
540
+ ${checks};
541
+ return {
542
+ ${conversions}
543
+ };
544
+ }`;
545
+ }
546
+
547
+ private generateConverter(typeInfo: TypeInfo, value: string, direction: 'to' | 'from'): string {
548
+ // Handle arrays/tuples
549
+ if (typeInfo.typeName.includes('[]') || typeInfo.typeName.includes('Tuple<')) {
550
+ const elementType = typeInfo.typeName.match(/^(.+)\[\]$/) || typeInfo.typeName.match(/^Tuple<(.+),/);
551
+ if (elementType) {
552
+ const isTuple = typeInfo.typeName.includes('Tuple<');
553
+ const mapFn = isTuple ? 'mapTuple' : 'map';
554
+ return `${value}.${mapFn}((v: any) => v)`; // Simplified for now
555
+ }
556
+ }
557
+
558
+ // Handle custom types that have conversion methods (not just type aliases)
559
+ if (typeInfo.toMethod || typeInfo.fromMethod) {
560
+ return `${direction}${typeInfo.typeName}(${value})`;
561
+ }
562
+
563
+ return value;
564
+ }
565
+
566
+ private generateImports(): string[] {
567
+ const imports: string[] = [];
568
+
569
+ // Base imports
570
+ if (this.config.imports) {
571
+ imports.push(...this.config.imports);
572
+ }
573
+
574
+ // For API modes, import from api_types
575
+ if (this.config.mode !== 'types') {
576
+ const neededImports = new Set<string>();
577
+
578
+ // Add types and conversion functions from function metadata
579
+ for (const metadata of this.functionMetadata) {
580
+ neededImports.add(metadata.commandType);
581
+ neededImports.add(metadata.responseType);
582
+ neededImports.add(`from${metadata.commandType}`);
583
+ neededImports.add(`to${metadata.responseType}`);
584
+ }
585
+
586
+ // Add referenced types
587
+ for (const type of this.referencedTypes) {
588
+ neededImports.add(type);
589
+ }
590
+
591
+ // Add BbApiBase interface
592
+ neededImports.add('BbApiBase');
593
+
594
+ if (neededImports.size > 0) {
595
+ const sortedImports = Array.from(neededImports).sort();
596
+ // Remove duplicates
597
+ const uniqueImports = sortedImports.filter((item, index) => sortedImports.indexOf(item) === index);
598
+ imports.push(`import { ${uniqueImports.join(', ')} } from './api_types.js';`);
599
+ }
600
+ }
601
+
602
+ return imports;
603
+ }
604
+
605
+ private generateBbApiBaseInterface(): string {
606
+ const methods = this.functionMetadata
607
+ .map(m => ` ${m.name}(command: ${m.commandType}): Promise<${m.responseType}>;`)
608
+ .join('\n');
609
+
610
+ return `export interface BbApiBase {
611
+ ${methods}
612
+ destroy(): Promise<void>;
613
+ }`;
614
+ }
615
+
616
+ private generateApiClass(): string {
617
+ const className = this.getApiClassName();
618
+ const methods = this.functionMetadata.map(m => this.generateApiMethod(m)).join('\n\n');
619
+
620
+ // For sync API, don't implement BbApiBase since methods are synchronous
621
+ const implementsClause = this.config.mode === 'sync' ? '' : ' implements BbApiBase';
622
+
623
+ // For tracing all calls to bb.
624
+ // const msgpackCallHelper =
625
+ // `${this.config.mode === 'async' ? 'async ' : ''}function msgpackCall(backend: ${this.getBackendType()}, input: any[]) {\n` +
626
+ // ` const commandName = input[0]?.[0] || 'unknown';\n` +
627
+ // ` process.stderr.write(\`[BB MSGPACK ${this.config.mode === 'async' ? 'ASYNC' : 'SYNC'}] \${commandName}\\n\`);\n` +
628
+ // ` const inputBuffer = new Encoder({ useRecords: false }).pack(input);\n` +
629
+ // ` const encodedResult = ${this.config.mode === 'async' ? 'await ' : ''}backend.call(inputBuffer);\n` +
630
+ // ` const result = new Decoder({ useRecords: false }).unpack(encodedResult);\n` +
631
+ // ` process.stderr.write(\`[BB MSGPACK ${this.config.mode === 'async' ? 'ASYNC' : 'SYNC'}] \${commandName} => completed\\n\`);\n` +
632
+ // ` return result;\n` +
633
+ // `}\n`;
634
+ const msgpackCallHelper =
635
+ `${this.config.mode === 'async' ? 'async ' : ''}function msgpackCall(backend: ${this.getBackendType()}, input: any[]) {` +
636
+ ` const inputBuffer = new Encoder({ useRecords: false }).pack(input);` +
637
+ ` const encodedResult = ${this.config.mode === 'async' ? 'await ' : ''}backend.call(inputBuffer);` +
638
+ ` return new Decoder({ useRecords: false }).unpack(encodedResult);` +
639
+ `}\n`;
640
+ const destroyMethod =
641
+ this.config.mode === 'sync'
642
+ ? ` destroy(): void {
643
+ if (this.backend.destroy) this.backend.destroy();
644
+ }`
645
+ : ` destroy(): Promise<void> {
646
+ return this.backend.destroy ? this.backend.destroy() : Promise.resolve();
647
+ }`;
648
+
649
+ return (
650
+ msgpackCallHelper +
651
+ `export class ${className}${implementsClause} {
652
+ constructor(protected backend: ${this.getBackendType()}) {}
653
+
654
+ ${methods}
655
+
656
+ ${destroyMethod}
657
+ }`
658
+ );
659
+ }
660
+
661
+ private getApiClassName(): string {
662
+ switch (this.config.mode) {
663
+ case 'sync':
664
+ return 'SyncApi';
665
+ case 'async':
666
+ return 'AsyncApi';
667
+ default:
668
+ throw new Error(`Invalid mode: ${this.config.mode}`);
669
+ }
670
+ }
671
+
672
+ private getBackendType(): string {
673
+ switch (this.config.mode) {
674
+ case 'sync':
675
+ return 'IMsgpackBackendSync';
676
+ case 'async':
677
+ return 'IMsgpackBackendAsync';
678
+ default:
679
+ return '';
680
+ }
681
+ }
682
+
683
+ private generateApiMethod(metadata: FunctionMetadata): string {
684
+ const { name, commandType, responseType } = metadata;
685
+
686
+ // For async mode, queue immediately and return promise
687
+ if (this.config.mode === 'async') {
688
+ return ` ${name}(command: ${commandType}): Promise<${responseType}> {
689
+ const msgpackCommand = from${commandType}(command);
690
+ return msgpackCall(this.backend, [["${capitalize(name)}", msgpackCommand]]).then(([variantName, result]: [string, any]) => {
691
+ if (variantName === 'ErrorResponse') {
692
+ throw new BBApiException(result.message || 'Unknown error from barretenberg');
693
+ }
694
+ if (variantName !== '${responseType}') {
695
+ throw new BBApiException(\`Expected variant name '${responseType}' but got '\${variantName}'\`);
696
+ }
697
+ return to${responseType}(result);
698
+ });
699
+ }`;
700
+ }
701
+
702
+ // For sync mode, keep the synchronous behavior
703
+ return ` ${name}(command: ${commandType}): ${responseType} {
704
+ const msgpackCommand = from${commandType}(command);
705
+ const [variantName, result] = msgpackCall(this.backend, [["${capitalize(name)}", msgpackCommand]]);
706
+ if (variantName === 'ErrorResponse') {
707
+ throw new BBApiException(result.message || 'Unknown error from barretenberg');
708
+ }
709
+ if (variantName !== '${responseType}') {
710
+ throw new BBApiException(\`Expected variant name '${responseType}' but got '\${variantName}'\`);
711
+ }
712
+ return to${responseType}(result);
713
+ }`;
714
+ }
715
+ }
716
+
717
+ // Factory methods for creating configured compilers
718
+ export function createSharedTypesCompiler(): SchemaCompiler {
719
+ return new SchemaCompiler({
720
+ mode: 'types',
721
+ imports: [],
722
+ });
723
+ }
724
+
725
+ export function createSyncApiCompiler(): SchemaCompiler {
726
+ return new SchemaCompiler({
727
+ mode: 'sync',
728
+ imports: [
729
+ `import { IMsgpackBackendSync } from '../../bb_backends/interface.js';`,
730
+ `import { Decoder, Encoder } from 'msgpackr';`,
731
+ `import { BBApiException } from '../../bbapi_exception.js';`,
732
+ ],
733
+ });
734
+ }
735
+
736
+ export function createAsyncApiCompiler(): SchemaCompiler {
737
+ return new SchemaCompiler({
738
+ mode: 'async',
739
+ imports: [
740
+ `import { IMsgpackBackendAsync } from '../../bb_backends/interface.js';`,
741
+ `import { Decoder, Encoder } from 'msgpackr';`,
742
+ `import { BBApiException } from '../../bbapi_exception.js';`,
743
+ ],
744
+ });
745
+ }