@aztec/bb.js 0.0.1-alpha.7 → 0.0.1-commit.0208eb9

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 (821) 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 +93 -0
  14. package/dest/browser/barretenberg/backend.d.ts.map +1 -0
  15. package/dest/browser/barretenberg/backend.js +350 -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 +50 -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 +8 -0
  92. package/dest/browser/cbind/generate.d.ts.map +1 -0
  93. package/dest/browser/cbind/generate.js +173 -0
  94. package/dest/browser/cbind/generated/api_types.d.ts +1130 -0
  95. package/dest/browser/cbind/generated/api_types.d.ts.map +1 -0
  96. package/dest/browser/cbind/generated/api_types.js +2657 -0
  97. package/dest/browser/cbind/generated/async.d.ts +60 -0
  98. package/dest/browser/cbind/generated/async.d.ts.map +1 -0
  99. package/dest/browser/cbind/generated/async.js +643 -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 +60 -0
  104. package/dest/browser/cbind/generated/sync.d.ts.map +1 -0
  105. package/dest/browser/cbind/generated/sync.js +592 -0
  106. package/dest/browser/cbind/naming.d.ts +16 -0
  107. package/dest/browser/cbind/naming.d.ts.map +1 -0
  108. package/dest/browser/cbind/naming.js +24 -0
  109. package/dest/browser/cbind/rust_codegen.d.ts +26 -0
  110. package/dest/browser/cbind/rust_codegen.d.ts.map +1 -0
  111. package/dest/browser/cbind/rust_codegen.js +461 -0
  112. package/dest/browser/cbind/schema_visitor.d.ts +47 -0
  113. package/dest/browser/cbind/schema_visitor.d.ts.map +1 -0
  114. package/dest/browser/cbind/schema_visitor.js +158 -0
  115. package/dest/browser/cbind/typescript_codegen.d.ts +30 -0
  116. package/dest/browser/cbind/typescript_codegen.d.ts.map +1 -0
  117. package/dest/browser/cbind/typescript_codegen.js +365 -0
  118. package/dest/browser/crs/browser/cached_net_crs.d.ts +43 -0
  119. package/dest/browser/crs/browser/cached_net_crs.d.ts.map +1 -0
  120. package/dest/browser/crs/browser/cached_net_crs.js +95 -0
  121. package/dest/browser/crs/browser/index.d.ts +2 -0
  122. package/dest/browser/crs/browser/index.d.ts.map +1 -0
  123. package/dest/browser/crs/browser/index.js +2 -0
  124. package/dest/browser/crs/index.d.ts +2 -0
  125. package/dest/browser/crs/index.d.ts.map +1 -0
  126. package/dest/browser/crs/index.js +2 -0
  127. package/dest/browser/crs/net_crs.d.ts +75 -0
  128. package/dest/browser/crs/net_crs.d.ts.map +1 -0
  129. package/dest/browser/crs/net_crs.js +164 -0
  130. package/dest/browser/index.d.ts +9 -0
  131. package/dest/browser/index.d.ts.map +1 -0
  132. package/dest/browser/index.js +9 -0
  133. package/dest/browser/proof/index.d.ts +21 -0
  134. package/dest/browser/proof/index.d.ts.map +1 -0
  135. package/dest/browser/proof/index.js +63 -0
  136. package/dest/browser/random/browser/index.d.ts +2 -0
  137. package/dest/browser/random/browser/index.d.ts.map +1 -0
  138. package/dest/browser/random/browser/index.js +31 -0
  139. package/dest/browser/random/index.d.ts +2 -0
  140. package/dest/browser/random/index.d.ts.map +1 -0
  141. package/dest/browser/random/index.js +2 -0
  142. package/dest/browser/retry/index.d.ts +26 -0
  143. package/dest/browser/retry/index.d.ts.map +1 -0
  144. package/dest/browser/retry/index.js +50 -0
  145. package/dest/node/async_map/index.d.ts +10 -0
  146. package/dest/node/async_map/index.d.ts.map +1 -0
  147. package/dest/node/async_map/index.js +16 -0
  148. package/dest/node/barretenberg/__snapshots__/pedersen.test.js.snap +156 -0
  149. package/dest/node/barretenberg/__snapshots__/poseidon.test.js.snap +40 -0
  150. package/dest/node/barretenberg/backend.d.ts +93 -0
  151. package/dest/node/barretenberg/backend.d.ts.map +1 -0
  152. package/dest/node/barretenberg/backend.js +350 -0
  153. package/dest/node/barretenberg/backend.test.d.ts +2 -0
  154. package/dest/node/barretenberg/backend.test.d.ts.map +1 -0
  155. package/dest/node/barretenberg/backend.test.js +103 -0
  156. package/dest/node/barretenberg/blake2s.test.d.ts +2 -0
  157. package/dest/node/barretenberg/blake2s.test.d.ts.map +1 -0
  158. package/dest/node/barretenberg/blake2s.test.js +57 -0
  159. package/dest/node/barretenberg/index.d.ts +65 -0
  160. package/dest/node/barretenberg/index.d.ts.map +1 -0
  161. package/dest/node/barretenberg/index.js +182 -0
  162. package/dest/node/barretenberg/pedersen.test.d.ts +2 -0
  163. package/dest/node/barretenberg/pedersen.test.d.ts.map +1 -0
  164. package/dest/node/barretenberg/pedersen.test.js +62 -0
  165. package/dest/node/barretenberg/poseidon.bench.test.d.ts +2 -0
  166. package/dest/node/barretenberg/poseidon.bench.test.d.ts.map +1 -0
  167. package/dest/node/barretenberg/poseidon.bench.test.js +218 -0
  168. package/dest/node/barretenberg/poseidon.test.d.ts +2 -0
  169. package/dest/node/barretenberg/poseidon.test.d.ts.map +1 -0
  170. package/dest/node/barretenberg/poseidon.test.js +35 -0
  171. package/dest/node/barretenberg/testing/bigint-buffer.d.ts +17 -0
  172. package/dest/node/barretenberg/testing/bigint-buffer.d.ts.map +1 -0
  173. package/dest/node/barretenberg/testing/bigint-buffer.js +37 -0
  174. package/dest/node/barretenberg/testing/fields.d.ts +16 -0
  175. package/dest/node/barretenberg/testing/fields.d.ts.map +1 -0
  176. package/dest/node/barretenberg/testing/fields.js +47 -0
  177. package/dest/node/barretenberg_wasm/barretenberg-threads.wasm.gz +0 -0
  178. package/dest/node/barretenberg_wasm/barretenberg_wasm_base/index.d.ts +45 -0
  179. package/dest/node/barretenberg_wasm/barretenberg_wasm_base/index.d.ts.map +1 -0
  180. package/dest/node/barretenberg_wasm/barretenberg_wasm_base/index.js +124 -0
  181. package/dest/node/barretenberg_wasm/barretenberg_wasm_main/factory/browser/index.d.ts +2 -0
  182. package/dest/node/barretenberg_wasm/barretenberg_wasm_main/factory/browser/index.d.ts.map +1 -0
  183. package/dest/node/barretenberg_wasm/barretenberg_wasm_main/factory/browser/index.js +9 -0
  184. package/dest/node/barretenberg_wasm/barretenberg_wasm_main/factory/browser/main.worker.d.ts +2 -0
  185. package/dest/node/barretenberg_wasm/barretenberg_wasm_main/factory/browser/main.worker.d.ts.map +1 -0
  186. package/dest/node/barretenberg_wasm/barretenberg_wasm_main/factory/browser/main.worker.js +6 -0
  187. package/dest/node/barretenberg_wasm/barretenberg_wasm_main/factory/node/index.d.ts +3 -0
  188. package/dest/node/barretenberg_wasm/barretenberg_wasm_main/factory/node/index.d.ts.map +1 -0
  189. package/dest/node/barretenberg_wasm/barretenberg_wasm_main/factory/node/index.js +19 -0
  190. package/dest/node/barretenberg_wasm/barretenberg_wasm_main/factory/node/main.worker.d.ts +2 -0
  191. package/dest/node/barretenberg_wasm/barretenberg_wasm_main/factory/node/main.worker.d.ts.map +1 -0
  192. package/dest/node/barretenberg_wasm/barretenberg_wasm_main/factory/node/main.worker.js +9 -0
  193. package/dest/node/barretenberg_wasm/barretenberg_wasm_main/heap_allocator.d.ts +21 -0
  194. package/dest/node/barretenberg_wasm/barretenberg_wasm_main/heap_allocator.d.ts.map +1 -0
  195. package/dest/node/barretenberg_wasm/barretenberg_wasm_main/heap_allocator.js +71 -0
  196. package/dest/node/barretenberg_wasm/barretenberg_wasm_main/index.d.ts +59 -0
  197. package/dest/node/barretenberg_wasm/barretenberg_wasm_main/index.d.ts.map +1 -0
  198. package/dest/node/barretenberg_wasm/barretenberg_wasm_main/index.js +197 -0
  199. package/dest/node/barretenberg_wasm/barretenberg_wasm_thread/factory/browser/index.d.ts +2 -0
  200. package/dest/node/barretenberg_wasm/barretenberg_wasm_thread/factory/browser/index.d.ts.map +1 -0
  201. package/dest/node/barretenberg_wasm/barretenberg_wasm_thread/factory/browser/index.js +9 -0
  202. package/dest/node/barretenberg_wasm/barretenberg_wasm_thread/factory/browser/thread.worker.d.ts +2 -0
  203. package/dest/node/barretenberg_wasm/barretenberg_wasm_thread/factory/browser/thread.worker.d.ts.map +1 -0
  204. package/dest/node/barretenberg_wasm/barretenberg_wasm_thread/factory/browser/thread.worker.js +6 -0
  205. package/dest/node/barretenberg_wasm/barretenberg_wasm_thread/factory/node/index.d.ts +3 -0
  206. package/dest/node/barretenberg_wasm/barretenberg_wasm_thread/factory/node/index.d.ts.map +1 -0
  207. package/dest/node/barretenberg_wasm/barretenberg_wasm_thread/factory/node/index.js +19 -0
  208. package/dest/node/barretenberg_wasm/barretenberg_wasm_thread/factory/node/thread.worker.d.ts +2 -0
  209. package/dest/node/barretenberg_wasm/barretenberg_wasm_thread/factory/node/thread.worker.d.ts.map +1 -0
  210. package/dest/node/barretenberg_wasm/barretenberg_wasm_thread/factory/node/thread.worker.js +10 -0
  211. package/dest/node/barretenberg_wasm/barretenberg_wasm_thread/index.d.ts +30 -0
  212. package/dest/node/barretenberg_wasm/barretenberg_wasm_thread/index.d.ts.map +1 -0
  213. package/dest/node/barretenberg_wasm/barretenberg_wasm_thread/index.js +41 -0
  214. package/dest/node/barretenberg_wasm/fetch_code/browser/barretenberg-threads.d.ts +3 -0
  215. package/dest/node/barretenberg_wasm/fetch_code/browser/barretenberg-threads.d.ts.map +1 -0
  216. package/dest/node/barretenberg_wasm/fetch_code/browser/barretenberg-threads.js +3 -0
  217. package/dest/node/barretenberg_wasm/fetch_code/browser/barretenberg.d.ts +3 -0
  218. package/dest/node/barretenberg_wasm/fetch_code/browser/barretenberg.d.ts.map +1 -0
  219. package/dest/node/barretenberg_wasm/fetch_code/browser/barretenberg.js +3 -0
  220. package/dest/node/barretenberg_wasm/fetch_code/browser/index.d.ts +2 -0
  221. package/dest/node/barretenberg_wasm/fetch_code/browser/index.d.ts.map +1 -0
  222. package/dest/node/barretenberg_wasm/fetch_code/browser/index.js +36 -0
  223. package/dest/node/barretenberg_wasm/fetch_code/index.d.ts +2 -0
  224. package/dest/node/barretenberg_wasm/fetch_code/index.d.ts.map +1 -0
  225. package/dest/node/barretenberg_wasm/fetch_code/index.js +2 -0
  226. package/dest/node/barretenberg_wasm/fetch_code/node/index.d.ts +2 -0
  227. package/dest/node/barretenberg_wasm/fetch_code/node/index.d.ts.map +1 -0
  228. package/dest/node/barretenberg_wasm/fetch_code/node/index.js +35 -0
  229. package/dest/node/barretenberg_wasm/helpers/browser/index.d.ts +13 -0
  230. package/dest/node/barretenberg_wasm/helpers/browser/index.d.ts.map +1 -0
  231. package/dest/node/barretenberg_wasm/helpers/browser/index.js +47 -0
  232. package/dest/node/barretenberg_wasm/helpers/index.d.ts +2 -0
  233. package/dest/node/barretenberg_wasm/helpers/index.d.ts.map +1 -0
  234. package/dest/node/barretenberg_wasm/helpers/index.js +2 -0
  235. package/dest/node/barretenberg_wasm/helpers/node/index.d.ts +21 -0
  236. package/dest/node/barretenberg_wasm/helpers/node/index.d.ts.map +1 -0
  237. package/dest/node/barretenberg_wasm/helpers/node/index.js +56 -0
  238. package/dest/node/barretenberg_wasm/helpers/node/node_endpoint.d.ts +8 -0
  239. package/dest/node/barretenberg_wasm/helpers/node/node_endpoint.d.ts.map +1 -0
  240. package/dest/node/barretenberg_wasm/helpers/node/node_endpoint.js +28 -0
  241. package/dest/node/barretenberg_wasm/index.d.ts +5 -0
  242. package/dest/node/barretenberg_wasm/index.d.ts.map +1 -0
  243. package/dest/node/barretenberg_wasm/index.js +15 -0
  244. package/dest/node/barretenberg_wasm/index.test.d.ts +2 -0
  245. package/dest/node/barretenberg_wasm/index.test.d.ts.map +1 -0
  246. package/dest/node/barretenberg_wasm/index.test.js +39 -0
  247. package/dest/node/bb_backends/browser/index.d.ts +11 -0
  248. package/dest/node/bb_backends/browser/index.d.ts.map +1 -0
  249. package/dest/node/bb_backends/browser/index.js +39 -0
  250. package/dest/node/bb_backends/browser/platform.d.ts +4 -0
  251. package/dest/node/bb_backends/browser/platform.d.ts.map +1 -0
  252. package/dest/node/bb_backends/browser/platform.js +10 -0
  253. package/dest/node/bb_backends/index.d.ts +50 -0
  254. package/dest/node/bb_backends/index.d.ts.map +1 -0
  255. package/dest/node/bb_backends/index.js +16 -0
  256. package/dest/node/bb_backends/interface.d.ts +33 -0
  257. package/dest/node/bb_backends/interface.d.ts.map +1 -0
  258. package/dest/node/bb_backends/interface.js +2 -0
  259. package/dest/node/bb_backends/node/index.d.ts +11 -0
  260. package/dest/node/bb_backends/node/index.d.ts.map +1 -0
  261. package/dest/node/bb_backends/node/index.js +86 -0
  262. package/dest/node/bb_backends/node/native_pipe.d.ts +25 -0
  263. package/dest/node/bb_backends/node/native_pipe.d.ts.map +1 -0
  264. package/dest/node/bb_backends/node/native_pipe.js +114 -0
  265. package/dest/node/bb_backends/node/native_shm.d.ts +29 -0
  266. package/dest/node/bb_backends/node/native_shm.d.ts.map +1 -0
  267. package/dest/node/bb_backends/node/native_shm.js +196 -0
  268. package/dest/node/bb_backends/node/native_shm_async.d.ts +51 -0
  269. package/dest/node/bb_backends/node/native_shm_async.d.ts.map +1 -0
  270. package/dest/node/bb_backends/node/native_shm_async.js +233 -0
  271. package/dest/node/bb_backends/node/native_socket.d.ts +34 -0
  272. package/dest/node/bb_backends/node/native_socket.d.ts.map +1 -0
  273. package/dest/node/bb_backends/node/native_socket.js +283 -0
  274. package/dest/node/bb_backends/node/platform.d.ts +27 -0
  275. package/dest/node/bb_backends/node/platform.d.ts.map +1 -0
  276. package/dest/node/bb_backends/node/platform.js +129 -0
  277. package/dest/node/bb_backends/wasm.d.ts +49 -0
  278. package/dest/node/bb_backends/wasm.d.ts.map +1 -0
  279. package/dest/node/bb_backends/wasm.js +85 -0
  280. package/dest/node/bbapi/exception_handling.test.d.ts +2 -0
  281. package/dest/node/bbapi/exception_handling.test.d.ts.map +1 -0
  282. package/dest/node/bbapi/exception_handling.test.js +48 -0
  283. package/dest/node/bbapi_exception.d.ts +7 -0
  284. package/dest/node/bbapi_exception.d.ts.map +1 -0
  285. package/dest/node/bbapi_exception.js +14 -0
  286. package/dest/node/benchmark/index.d.ts +3 -0
  287. package/dest/node/benchmark/index.d.ts.map +1 -0
  288. package/dest/node/benchmark/index.js +25 -0
  289. package/dest/node/benchmark/timer.d.ts +34 -0
  290. package/dest/node/benchmark/timer.d.ts.map +1 -0
  291. package/dest/node/benchmark/timer.js +42 -0
  292. package/dest/node/bin/index.d.ts +3 -0
  293. package/dest/node/bin/index.d.ts.map +1 -0
  294. package/dest/node/bin/index.js +11 -0
  295. package/dest/node/cbind/generate.d.ts +8 -0
  296. package/dest/node/cbind/generate.d.ts.map +1 -0
  297. package/dest/node/cbind/generate.js +173 -0
  298. package/dest/node/cbind/generated/api_types.d.ts +1130 -0
  299. package/dest/node/cbind/generated/api_types.d.ts.map +1 -0
  300. package/dest/node/cbind/generated/api_types.js +2657 -0
  301. package/dest/node/cbind/generated/async.d.ts +60 -0
  302. package/dest/node/cbind/generated/async.d.ts.map +1 -0
  303. package/dest/node/cbind/generated/async.js +643 -0
  304. package/dest/node/cbind/generated/curve_constants.d.ts +45 -0
  305. package/dest/node/cbind/generated/curve_constants.d.ts.map +1 -0
  306. package/dest/node/cbind/generated/curve_constants.js +45 -0
  307. package/dest/node/cbind/generated/sync.d.ts +60 -0
  308. package/dest/node/cbind/generated/sync.d.ts.map +1 -0
  309. package/dest/node/cbind/generated/sync.js +592 -0
  310. package/dest/node/cbind/naming.d.ts +16 -0
  311. package/dest/node/cbind/naming.d.ts.map +1 -0
  312. package/dest/node/cbind/naming.js +24 -0
  313. package/dest/node/cbind/rust_codegen.d.ts +26 -0
  314. package/dest/node/cbind/rust_codegen.d.ts.map +1 -0
  315. package/dest/node/cbind/rust_codegen.js +461 -0
  316. package/dest/node/cbind/schema_visitor.d.ts +47 -0
  317. package/dest/node/cbind/schema_visitor.d.ts.map +1 -0
  318. package/dest/node/cbind/schema_visitor.js +158 -0
  319. package/dest/node/cbind/typescript_codegen.d.ts +30 -0
  320. package/dest/node/cbind/typescript_codegen.d.ts.map +1 -0
  321. package/dest/node/cbind/typescript_codegen.js +365 -0
  322. package/dest/node/crs/browser/cached_net_crs.d.ts +43 -0
  323. package/dest/node/crs/browser/cached_net_crs.d.ts.map +1 -0
  324. package/dest/node/crs/browser/cached_net_crs.js +95 -0
  325. package/dest/node/crs/browser/index.d.ts +2 -0
  326. package/dest/node/crs/browser/index.d.ts.map +1 -0
  327. package/dest/node/crs/browser/index.js +2 -0
  328. package/dest/node/crs/index.d.ts +2 -0
  329. package/dest/node/crs/index.d.ts.map +1 -0
  330. package/dest/node/crs/index.js +2 -0
  331. package/dest/node/crs/net_crs.d.ts +75 -0
  332. package/dest/node/crs/net_crs.d.ts.map +1 -0
  333. package/dest/node/crs/net_crs.js +164 -0
  334. package/dest/node/crs/net_crs.test.d.ts +2 -0
  335. package/dest/node/crs/net_crs.test.d.ts.map +1 -0
  336. package/dest/node/crs/net_crs.test.js +39 -0
  337. package/dest/node/crs/node/index.d.ts +38 -0
  338. package/dest/node/crs/node/index.d.ts.map +1 -0
  339. package/dest/node/crs/node/index.js +107 -0
  340. package/dest/node/index.d.ts +9 -0
  341. package/dest/node/index.d.ts.map +1 -0
  342. package/dest/node/index.js +9 -0
  343. package/dest/node/proof/index.d.ts +21 -0
  344. package/dest/node/proof/index.d.ts.map +1 -0
  345. package/dest/node/proof/index.js +63 -0
  346. package/dest/node/random/browser/index.d.ts +2 -0
  347. package/dest/node/random/browser/index.d.ts.map +1 -0
  348. package/dest/node/random/browser/index.js +31 -0
  349. package/dest/node/random/index.d.ts +2 -0
  350. package/dest/node/random/index.d.ts.map +1 -0
  351. package/dest/{random → node/random}/index.js +1 -1
  352. package/dest/node/random/node/index.d.ts +2 -0
  353. package/dest/node/random/node/index.d.ts.map +1 -0
  354. package/dest/node/random/node/index.js +5 -0
  355. package/dest/node/retry/index.d.ts +26 -0
  356. package/dest/node/retry/index.d.ts.map +1 -0
  357. package/dest/node/retry/index.js +50 -0
  358. package/dest/node-cjs/async_map/index.d.ts +10 -0
  359. package/dest/node-cjs/async_map/index.d.ts.map +1 -0
  360. package/dest/node-cjs/async_map/index.js +19 -0
  361. package/dest/node-cjs/barretenberg/backend.d.ts +93 -0
  362. package/dest/node-cjs/barretenberg/backend.d.ts.map +1 -0
  363. package/dest/node-cjs/barretenberg/backend.js +359 -0
  364. package/dest/node-cjs/barretenberg/backend.test.d.ts +2 -0
  365. package/dest/node-cjs/barretenberg/backend.test.d.ts.map +1 -0
  366. package/dest/node-cjs/barretenberg/backend.test.js +105 -0
  367. package/dest/node-cjs/barretenberg/blake2s.test.d.ts +2 -0
  368. package/dest/node-cjs/barretenberg/blake2s.test.d.ts.map +1 -0
  369. package/dest/node-cjs/barretenberg/blake2s.test.js +59 -0
  370. package/dest/node-cjs/barretenberg/index.d.ts +65 -0
  371. package/dest/node-cjs/barretenberg/index.d.ts.map +1 -0
  372. package/dest/node-cjs/barretenberg/index.js +193 -0
  373. package/dest/node-cjs/barretenberg/pedersen.test.d.ts +2 -0
  374. package/dest/node-cjs/barretenberg/pedersen.test.d.ts.map +1 -0
  375. package/dest/node-cjs/barretenberg/pedersen.test.js +64 -0
  376. package/dest/node-cjs/barretenberg/poseidon.bench.test.d.ts +2 -0
  377. package/dest/node-cjs/barretenberg/poseidon.bench.test.d.ts.map +1 -0
  378. package/dest/node-cjs/barretenberg/poseidon.bench.test.js +220 -0
  379. package/dest/node-cjs/barretenberg/poseidon.test.d.ts +2 -0
  380. package/dest/node-cjs/barretenberg/poseidon.test.d.ts.map +1 -0
  381. package/dest/node-cjs/barretenberg/poseidon.test.js +37 -0
  382. package/dest/node-cjs/barretenberg/testing/bigint-buffer.d.ts +17 -0
  383. package/dest/node-cjs/barretenberg/testing/bigint-buffer.d.ts.map +1 -0
  384. package/dest/node-cjs/barretenberg/testing/bigint-buffer.js +43 -0
  385. package/dest/node-cjs/barretenberg/testing/fields.d.ts +16 -0
  386. package/dest/node-cjs/barretenberg/testing/fields.d.ts.map +1 -0
  387. package/dest/node-cjs/barretenberg/testing/fields.js +51 -0
  388. package/dest/node-cjs/barretenberg_wasm/barretenberg-threads.wasm.gz +0 -0
  389. package/dest/node-cjs/barretenberg_wasm/barretenberg_wasm_base/index.d.ts +45 -0
  390. package/dest/node-cjs/barretenberg_wasm/barretenberg_wasm_base/index.d.ts.map +1 -0
  391. package/dest/node-cjs/barretenberg_wasm/barretenberg_wasm_base/index.js +128 -0
  392. package/dest/node-cjs/barretenberg_wasm/barretenberg_wasm_main/factory/browser/index.d.ts +2 -0
  393. package/dest/node-cjs/barretenberg_wasm/barretenberg_wasm_main/factory/browser/index.d.ts.map +1 -0
  394. package/dest/node-cjs/barretenberg_wasm/barretenberg_wasm_main/factory/browser/index.js +12 -0
  395. package/dest/node-cjs/barretenberg_wasm/barretenberg_wasm_main/factory/browser/main.worker.d.ts +2 -0
  396. package/dest/node-cjs/barretenberg_wasm/barretenberg_wasm_main/factory/browser/main.worker.d.ts.map +1 -0
  397. package/dest/node-cjs/barretenberg_wasm/barretenberg_wasm_main/factory/browser/main.worker.js +8 -0
  398. package/dest/node-cjs/barretenberg_wasm/barretenberg_wasm_main/factory/node/index.d.ts +3 -0
  399. package/dest/node-cjs/barretenberg_wasm/barretenberg_wasm_main/factory/node/index.d.ts.map +1 -0
  400. package/dest/node-cjs/barretenberg_wasm/barretenberg_wasm_main/factory/node/index.js +22 -0
  401. package/dest/node-cjs/barretenberg_wasm/barretenberg_wasm_main/factory/node/main.worker.d.ts +2 -0
  402. package/dest/node-cjs/barretenberg_wasm/barretenberg_wasm_main/factory/node/main.worker.d.ts.map +1 -0
  403. package/dest/node-cjs/barretenberg_wasm/barretenberg_wasm_main/factory/node/main.worker.js +11 -0
  404. package/dest/node-cjs/barretenberg_wasm/barretenberg_wasm_main/heap_allocator.d.ts +21 -0
  405. package/dest/node-cjs/barretenberg_wasm/barretenberg_wasm_main/heap_allocator.d.ts.map +1 -0
  406. package/dest/node-cjs/barretenberg_wasm/barretenberg_wasm_main/heap_allocator.js +75 -0
  407. package/dest/node-cjs/barretenberg_wasm/barretenberg_wasm_main/index.d.ts +59 -0
  408. package/dest/node-cjs/barretenberg_wasm/barretenberg_wasm_main/index.d.ts.map +1 -0
  409. package/dest/node-cjs/barretenberg_wasm/barretenberg_wasm_main/index.js +201 -0
  410. package/dest/node-cjs/barretenberg_wasm/barretenberg_wasm_thread/factory/browser/index.d.ts +2 -0
  411. package/dest/node-cjs/barretenberg_wasm/barretenberg_wasm_thread/factory/browser/index.d.ts.map +1 -0
  412. package/dest/node-cjs/barretenberg_wasm/barretenberg_wasm_thread/factory/browser/index.js +12 -0
  413. package/dest/node-cjs/barretenberg_wasm/barretenberg_wasm_thread/factory/browser/thread.worker.d.ts +2 -0
  414. package/dest/node-cjs/barretenberg_wasm/barretenberg_wasm_thread/factory/browser/thread.worker.d.ts.map +1 -0
  415. package/dest/node-cjs/barretenberg_wasm/barretenberg_wasm_thread/factory/browser/thread.worker.js +8 -0
  416. package/dest/node-cjs/barretenberg_wasm/barretenberg_wasm_thread/factory/node/index.d.ts +3 -0
  417. package/dest/node-cjs/barretenberg_wasm/barretenberg_wasm_thread/factory/node/index.d.ts.map +1 -0
  418. package/dest/node-cjs/barretenberg_wasm/barretenberg_wasm_thread/factory/node/index.js +22 -0
  419. package/dest/node-cjs/barretenberg_wasm/barretenberg_wasm_thread/factory/node/thread.worker.d.ts +2 -0
  420. package/dest/node-cjs/barretenberg_wasm/barretenberg_wasm_thread/factory/node/thread.worker.d.ts.map +1 -0
  421. package/dest/node-cjs/barretenberg_wasm/barretenberg_wasm_thread/factory/node/thread.worker.js +12 -0
  422. package/dest/node-cjs/barretenberg_wasm/barretenberg_wasm_thread/index.d.ts +30 -0
  423. package/dest/node-cjs/barretenberg_wasm/barretenberg_wasm_thread/index.d.ts.map +1 -0
  424. package/dest/node-cjs/barretenberg_wasm/barretenberg_wasm_thread/index.js +45 -0
  425. package/dest/node-cjs/barretenberg_wasm/fetch_code/browser/barretenberg-threads.d.ts +3 -0
  426. package/dest/node-cjs/barretenberg_wasm/fetch_code/browser/barretenberg-threads.d.ts.map +1 -0
  427. package/dest/node-cjs/barretenberg_wasm/fetch_code/browser/barretenberg-threads.js +6 -0
  428. package/dest/node-cjs/barretenberg_wasm/fetch_code/browser/barretenberg.d.ts +3 -0
  429. package/dest/node-cjs/barretenberg_wasm/fetch_code/browser/barretenberg.d.ts.map +1 -0
  430. package/dest/node-cjs/barretenberg_wasm/fetch_code/browser/barretenberg.js +6 -0
  431. package/dest/node-cjs/barretenberg_wasm/fetch_code/browser/index.d.ts +2 -0
  432. package/dest/node-cjs/barretenberg_wasm/fetch_code/browser/index.d.ts.map +1 -0
  433. package/dest/node-cjs/barretenberg_wasm/fetch_code/browser/index.js +40 -0
  434. package/dest/node-cjs/barretenberg_wasm/fetch_code/index.d.ts +2 -0
  435. package/dest/node-cjs/barretenberg_wasm/fetch_code/index.d.ts.map +1 -0
  436. package/dest/node-cjs/barretenberg_wasm/fetch_code/index.js +5 -0
  437. package/dest/node-cjs/barretenberg_wasm/fetch_code/node/index.d.ts +2 -0
  438. package/dest/node-cjs/barretenberg_wasm/fetch_code/node/index.d.ts.map +1 -0
  439. package/dest/node-cjs/barretenberg_wasm/fetch_code/node/index.js +39 -0
  440. package/dest/node-cjs/barretenberg_wasm/helpers/browser/index.d.ts +13 -0
  441. package/dest/node-cjs/barretenberg_wasm/helpers/browser/index.d.ts.map +1 -0
  442. package/dest/node-cjs/barretenberg_wasm/helpers/browser/index.js +57 -0
  443. package/dest/node-cjs/barretenberg_wasm/helpers/index.d.ts +2 -0
  444. package/dest/node-cjs/barretenberg_wasm/helpers/index.d.ts.map +1 -0
  445. package/dest/node-cjs/barretenberg_wasm/helpers/index.js +5 -0
  446. package/dest/node-cjs/barretenberg_wasm/helpers/node/index.d.ts +21 -0
  447. package/dest/node-cjs/barretenberg_wasm/helpers/node/index.d.ts.map +1 -0
  448. package/dest/node-cjs/barretenberg_wasm/helpers/node/index.js +65 -0
  449. package/dest/node-cjs/barretenberg_wasm/helpers/node/node_endpoint.d.ts +8 -0
  450. package/dest/node-cjs/barretenberg_wasm/helpers/node/node_endpoint.d.ts.map +1 -0
  451. package/dest/node-cjs/barretenberg_wasm/helpers/node/node_endpoint.js +31 -0
  452. package/dest/node-cjs/barretenberg_wasm/index.d.ts +5 -0
  453. package/dest/node-cjs/barretenberg_wasm/index.d.ts.map +1 -0
  454. package/dest/node-cjs/barretenberg_wasm/index.js +18 -0
  455. package/dest/node-cjs/barretenberg_wasm/index.test.d.ts +2 -0
  456. package/dest/node-cjs/barretenberg_wasm/index.test.d.ts.map +1 -0
  457. package/dest/node-cjs/barretenberg_wasm/index.test.js +41 -0
  458. package/dest/node-cjs/bb_backends/browser/index.d.ts +11 -0
  459. package/dest/node-cjs/bb_backends/browser/index.d.ts.map +1 -0
  460. package/dest/node-cjs/bb_backends/browser/index.js +43 -0
  461. package/dest/node-cjs/bb_backends/browser/platform.d.ts +4 -0
  462. package/dest/node-cjs/bb_backends/browser/platform.d.ts.map +1 -0
  463. package/dest/node-cjs/bb_backends/browser/platform.js +15 -0
  464. package/dest/node-cjs/bb_backends/index.d.ts +50 -0
  465. package/dest/node-cjs/bb_backends/index.d.ts.map +1 -0
  466. package/dest/node-cjs/bb_backends/index.js +18 -0
  467. package/dest/node-cjs/bb_backends/interface.d.ts +33 -0
  468. package/dest/node-cjs/bb_backends/interface.d.ts.map +1 -0
  469. package/dest/node-cjs/bb_backends/interface.js +3 -0
  470. package/dest/node-cjs/bb_backends/node/index.d.ts +11 -0
  471. package/dest/node-cjs/bb_backends/node/index.d.ts.map +1 -0
  472. package/dest/node-cjs/bb_backends/node/index.js +90 -0
  473. package/dest/node-cjs/bb_backends/node/native_pipe.d.ts +25 -0
  474. package/dest/node-cjs/bb_backends/node/native_pipe.d.ts.map +1 -0
  475. package/dest/node-cjs/bb_backends/node/native_pipe.js +118 -0
  476. package/dest/node-cjs/bb_backends/node/native_shm.d.ts +29 -0
  477. package/dest/node-cjs/bb_backends/node/native_shm.d.ts.map +1 -0
  478. package/dest/node-cjs/bb_backends/node/native_shm.js +200 -0
  479. package/dest/node-cjs/bb_backends/node/native_shm_async.d.ts +51 -0
  480. package/dest/node-cjs/bb_backends/node/native_shm_async.d.ts.map +1 -0
  481. package/dest/node-cjs/bb_backends/node/native_shm_async.js +237 -0
  482. package/dest/node-cjs/bb_backends/node/native_socket.d.ts +34 -0
  483. package/dest/node-cjs/bb_backends/node/native_socket.d.ts.map +1 -0
  484. package/dest/node-cjs/bb_backends/node/native_socket.js +288 -0
  485. package/dest/node-cjs/bb_backends/node/platform.d.ts +27 -0
  486. package/dest/node-cjs/bb_backends/node/platform.d.ts.map +1 -0
  487. package/dest/node-cjs/bb_backends/node/platform.js +136 -0
  488. package/dest/node-cjs/bb_backends/wasm.d.ts +49 -0
  489. package/dest/node-cjs/bb_backends/wasm.d.ts.map +1 -0
  490. package/dest/node-cjs/bb_backends/wasm.js +90 -0
  491. package/dest/node-cjs/bbapi/exception_handling.test.d.ts +2 -0
  492. package/dest/node-cjs/bbapi/exception_handling.test.d.ts.map +1 -0
  493. package/dest/node-cjs/bbapi/exception_handling.test.js +50 -0
  494. package/dest/node-cjs/bbapi_exception.d.ts +7 -0
  495. package/dest/node-cjs/bbapi_exception.d.ts.map +1 -0
  496. package/dest/node-cjs/bbapi_exception.js +18 -0
  497. package/dest/node-cjs/benchmark/index.d.ts +3 -0
  498. package/dest/node-cjs/benchmark/index.d.ts.map +1 -0
  499. package/dest/node-cjs/benchmark/index.js +29 -0
  500. package/dest/node-cjs/benchmark/timer.d.ts +34 -0
  501. package/dest/node-cjs/benchmark/timer.d.ts.map +1 -0
  502. package/dest/node-cjs/benchmark/timer.js +46 -0
  503. package/dest/node-cjs/bin/index.d.ts +3 -0
  504. package/dest/node-cjs/bin/index.d.ts.map +1 -0
  505. package/dest/node-cjs/bin/index.js +13 -0
  506. package/dest/node-cjs/cbind/generate.d.ts +8 -0
  507. package/dest/node-cjs/cbind/generate.d.ts.map +1 -0
  508. package/dest/node-cjs/cbind/generate.js +175 -0
  509. package/dest/node-cjs/cbind/generated/api_types.d.ts +1130 -0
  510. package/dest/node-cjs/cbind/generated/api_types.d.ts.map +1 -0
  511. package/dest/node-cjs/cbind/generated/api_types.js +2889 -0
  512. package/dest/node-cjs/cbind/generated/async.d.ts +60 -0
  513. package/dest/node-cjs/cbind/generated/async.d.ts.map +1 -0
  514. package/dest/node-cjs/cbind/generated/async.js +647 -0
  515. package/dest/node-cjs/cbind/generated/curve_constants.d.ts +45 -0
  516. package/dest/node-cjs/cbind/generated/curve_constants.d.ts.map +1 -0
  517. package/dest/node-cjs/cbind/generated/curve_constants.js +48 -0
  518. package/dest/node-cjs/cbind/generated/sync.d.ts +60 -0
  519. package/dest/node-cjs/cbind/generated/sync.d.ts.map +1 -0
  520. package/dest/node-cjs/cbind/generated/sync.js +596 -0
  521. package/dest/node-cjs/cbind/naming.d.ts +16 -0
  522. package/dest/node-cjs/cbind/naming.d.ts.map +1 -0
  523. package/dest/node-cjs/cbind/naming.js +28 -0
  524. package/dest/node-cjs/cbind/rust_codegen.d.ts +26 -0
  525. package/dest/node-cjs/cbind/rust_codegen.d.ts.map +1 -0
  526. package/dest/node-cjs/cbind/rust_codegen.js +465 -0
  527. package/dest/node-cjs/cbind/schema_visitor.d.ts +47 -0
  528. package/dest/node-cjs/cbind/schema_visitor.d.ts.map +1 -0
  529. package/dest/node-cjs/cbind/schema_visitor.js +162 -0
  530. package/dest/node-cjs/cbind/typescript_codegen.d.ts +30 -0
  531. package/dest/node-cjs/cbind/typescript_codegen.d.ts.map +1 -0
  532. package/dest/node-cjs/cbind/typescript_codegen.js +369 -0
  533. package/dest/node-cjs/crs/browser/cached_net_crs.d.ts +43 -0
  534. package/dest/node-cjs/crs/browser/cached_net_crs.d.ts.map +1 -0
  535. package/dest/node-cjs/crs/browser/cached_net_crs.js +100 -0
  536. package/dest/node-cjs/crs/browser/index.d.ts +2 -0
  537. package/dest/node-cjs/crs/browser/index.d.ts.map +1 -0
  538. package/dest/node-cjs/crs/browser/index.js +7 -0
  539. package/dest/node-cjs/crs/index.d.ts +2 -0
  540. package/dest/node-cjs/crs/index.d.ts.map +1 -0
  541. package/dest/node-cjs/crs/index.js +7 -0
  542. package/dest/node-cjs/crs/net_crs.d.ts +75 -0
  543. package/dest/node-cjs/crs/net_crs.d.ts.map +1 -0
  544. package/dest/node-cjs/crs/net_crs.js +170 -0
  545. package/dest/node-cjs/crs/net_crs.test.d.ts +2 -0
  546. package/dest/node-cjs/crs/net_crs.test.d.ts.map +1 -0
  547. package/dest/node-cjs/crs/net_crs.test.js +41 -0
  548. package/dest/node-cjs/crs/node/index.d.ts +38 -0
  549. package/dest/node-cjs/crs/node/index.d.ts.map +1 -0
  550. package/dest/node-cjs/crs/node/index.js +112 -0
  551. package/dest/node-cjs/index.d.ts +9 -0
  552. package/dest/node-cjs/index.d.ts.map +1 -0
  553. package/dest/node-cjs/index.js +41 -0
  554. package/dest/node-cjs/package.json +3 -0
  555. package/dest/node-cjs/proof/index.d.ts +21 -0
  556. package/dest/node-cjs/proof/index.d.ts.map +1 -0
  557. package/dest/node-cjs/proof/index.js +72 -0
  558. package/dest/node-cjs/random/browser/index.d.ts +2 -0
  559. package/dest/node-cjs/random/browser/index.d.ts.map +1 -0
  560. package/dest/node-cjs/random/browser/index.js +35 -0
  561. package/dest/node-cjs/random/index.d.ts +2 -0
  562. package/dest/node-cjs/random/index.d.ts.map +1 -0
  563. package/dest/node-cjs/random/index.js +5 -0
  564. package/dest/node-cjs/random/node/index.d.ts +2 -0
  565. package/dest/node-cjs/random/node/index.d.ts.map +1 -0
  566. package/dest/node-cjs/random/node/index.js +8 -0
  567. package/dest/node-cjs/retry/index.d.ts +26 -0
  568. package/dest/node-cjs/retry/index.d.ts.map +1 -0
  569. package/dest/node-cjs/retry/index.js +55 -0
  570. package/package.json +59 -46
  571. package/src/barretenberg/__snapshots__/pedersen.test.ts.snap +156 -0
  572. package/src/barretenberg/__snapshots__/poseidon.test.ts.snap +40 -0
  573. package/src/barretenberg/backend.test.ts +122 -0
  574. package/src/barretenberg/backend.ts +438 -0
  575. package/src/barretenberg/blake2s.test.ts +69 -0
  576. package/src/barretenberg/index.ts +220 -0
  577. package/src/barretenberg/pedersen.test.ts +69 -0
  578. package/src/barretenberg/poseidon.bench.test.ts +271 -0
  579. package/src/barretenberg/poseidon.test.ts +39 -0
  580. package/src/barretenberg/testing/bigint-buffer.ts +43 -0
  581. package/src/barretenberg/testing/fields.ts +63 -0
  582. package/src/barretenberg_wasm/barretenberg_wasm_base/index.ts +137 -0
  583. package/src/barretenberg_wasm/barretenberg_wasm_main/factory/browser/index.ts +9 -0
  584. package/src/barretenberg_wasm/barretenberg_wasm_main/factory/browser/main.worker.ts +6 -0
  585. package/src/barretenberg_wasm/barretenberg_wasm_main/factory/node/index.ts +19 -0
  586. package/src/barretenberg_wasm/barretenberg_wasm_main/factory/node/main.worker.ts +10 -0
  587. package/src/barretenberg_wasm/barretenberg_wasm_main/heap_allocator.ts +72 -0
  588. package/src/barretenberg_wasm/barretenberg_wasm_main/index.ts +251 -0
  589. package/src/barretenberg_wasm/barretenberg_wasm_thread/factory/browser/index.ts +9 -0
  590. package/src/barretenberg_wasm/barretenberg_wasm_thread/factory/browser/thread.worker.ts +6 -0
  591. package/src/barretenberg_wasm/barretenberg_wasm_thread/factory/node/index.ts +19 -0
  592. package/src/barretenberg_wasm/barretenberg_wasm_thread/factory/node/thread.worker.ts +12 -0
  593. package/src/barretenberg_wasm/barretenberg_wasm_thread/index.ts +48 -0
  594. package/src/barretenberg_wasm/fetch_code/browser/barretenberg-threads.ts +3 -0
  595. package/src/barretenberg_wasm/fetch_code/browser/barretenberg.ts +3 -0
  596. package/src/barretenberg_wasm/fetch_code/browser/index.ts +34 -0
  597. package/src/barretenberg_wasm/fetch_code/index.ts +1 -0
  598. package/src/barretenberg_wasm/fetch_code/node/index.ts +34 -0
  599. package/src/barretenberg_wasm/fetch_code/wasm-module.d.ts +4 -0
  600. package/src/barretenberg_wasm/helpers/browser/index.ts +54 -0
  601. package/src/barretenberg_wasm/helpers/index.ts +1 -0
  602. package/src/barretenberg_wasm/helpers/node/index.ts +62 -0
  603. package/src/barretenberg_wasm/index.test.ts +46 -0
  604. package/src/barretenberg_wasm/index.ts +21 -1
  605. package/src/bb_backends/browser/index.ts +50 -0
  606. package/src/bb_backends/browser/platform.ts +11 -0
  607. package/src/bb_backends/index.ts +55 -0
  608. package/src/bb_backends/interface.ts +35 -0
  609. package/src/bb_backends/node/index.ts +107 -0
  610. package/src/bb_backends/node/native_pipe.ts +127 -0
  611. package/src/bb_backends/node/native_shm.ts +214 -0
  612. package/src/bb_backends/node/native_shm_async.ts +262 -0
  613. package/src/bb_backends/node/native_socket.ts +328 -0
  614. package/src/bb_backends/node/platform.ts +156 -0
  615. package/src/bb_backends/wasm.ts +102 -0
  616. package/src/bbapi/exception_handling.test.ts +54 -0
  617. package/src/bbapi_exception.ts +13 -0
  618. package/src/benchmark/index.ts +26 -0
  619. package/src/benchmark/timer.ts +45 -0
  620. package/src/bin/index.ts +14 -0
  621. package/src/cbind/README.md +1 -0
  622. package/src/cbind/generate.ts +201 -0
  623. package/src/cbind/naming.ts +27 -0
  624. package/src/cbind/rust_codegen.ts +504 -0
  625. package/src/cbind/schema_visitor.ts +219 -0
  626. package/src/cbind/typescript_codegen.ts +419 -0
  627. package/src/crs/browser/cached_net_crs.ts +41 -1
  628. package/src/crs/browser/index.ts +1 -1
  629. package/src/crs/index.ts +1 -1
  630. package/src/crs/net_crs.test.ts +47 -0
  631. package/src/crs/net_crs.ts +145 -19
  632. package/src/crs/node/index.ts +95 -26
  633. package/src/index.html +1 -1
  634. package/src/index.ts +47 -5
  635. package/src/proof/index.ts +94 -0
  636. package/src/random/browser/index.ts +1 -1
  637. package/src/retry/index.ts +50 -0
  638. package/dest/async_map/index.d.ts.map +0 -1
  639. package/dest/barretenberg-threads.wasm +0 -0
  640. package/dest/barretenberg.wasm +0 -0
  641. package/dest/barretenberg_api/blake2s.test.d.ts +0 -2
  642. package/dest/barretenberg_api/blake2s.test.d.ts.map +0 -1
  643. package/dest/barretenberg_api/blake2s.test.js +0 -30
  644. package/dest/barretenberg_api/common.test.d.ts +0 -2
  645. package/dest/barretenberg_api/common.test.d.ts.map +0 -1
  646. package/dest/barretenberg_api/common.test.js +0 -18
  647. package/dest/barretenberg_api/index.d.ts +0 -103
  648. package/dest/barretenberg_api/index.d.ts.map +0 -1
  649. package/dest/barretenberg_api/index.js +0 -379
  650. package/dest/barretenberg_api/pedersen.test.d.ts +0 -2
  651. package/dest/barretenberg_api/pedersen.test.d.ts.map +0 -1
  652. package/dest/barretenberg_api/pedersen.test.js +0 -69
  653. package/dest/barretenberg_api/schnorr.test.d.ts +0 -2
  654. package/dest/barretenberg_api/schnorr.test.d.ts.map +0 -1
  655. package/dest/barretenberg_api/schnorr.test.js +0 -113
  656. package/dest/barretenberg_binder/heap_allocator.d.ts +0 -22
  657. package/dest/barretenberg_binder/heap_allocator.d.ts.map +0 -1
  658. package/dest/barretenberg_binder/heap_allocator.js +0 -59
  659. package/dest/barretenberg_binder/heap_allocator_sync.d.ts +0 -22
  660. package/dest/barretenberg_binder/heap_allocator_sync.d.ts.map +0 -1
  661. package/dest/barretenberg_binder/heap_allocator_sync.js +0 -58
  662. package/dest/barretenberg_binder/index.d.ts +0 -32
  663. package/dest/barretenberg_binder/index.d.ts.map +0 -1
  664. package/dest/barretenberg_binder/index.js +0 -73
  665. package/dest/barretenberg_wasm/barretenberg_wasm.d.ts +0 -50
  666. package/dest/barretenberg_wasm/barretenberg_wasm.d.ts.map +0 -1
  667. package/dest/barretenberg_wasm/barretenberg_wasm.js +0 -212
  668. package/dest/barretenberg_wasm/barretenberg_wasm.test.d.ts +0 -2
  669. package/dest/barretenberg_wasm/barretenberg_wasm.test.d.ts.map +0 -1
  670. package/dest/barretenberg_wasm/barretenberg_wasm.test.js +0 -43
  671. package/dest/barretenberg_wasm/browser/index.d.ts +0 -8
  672. package/dest/barretenberg_wasm/browser/index.d.ts.map +0 -1
  673. package/dest/barretenberg_wasm/browser/index.js +0 -26
  674. package/dest/barretenberg_wasm/browser/worker.d.ts +0 -2
  675. package/dest/barretenberg_wasm/browser/worker.d.ts.map +0 -1
  676. package/dest/barretenberg_wasm/browser/worker.js +0 -11
  677. package/dest/barretenberg_wasm/index.d.ts +0 -2
  678. package/dest/barretenberg_wasm/index.d.ts.map +0 -1
  679. package/dest/barretenberg_wasm/index.js +0 -2
  680. package/dest/barretenberg_wasm/node/index.d.ts +0 -17
  681. package/dest/barretenberg_wasm/node/index.d.ts.map +0 -1
  682. package/dest/barretenberg_wasm/node/index.js +0 -40
  683. package/dest/barretenberg_wasm/node/node_endpoint.d.ts +0 -8
  684. package/dest/barretenberg_wasm/node/node_endpoint.d.ts.map +0 -1
  685. package/dest/barretenberg_wasm/node/node_endpoint.js +0 -28
  686. package/dest/barretenberg_wasm/node/worker.d.ts +0 -2
  687. package/dest/barretenberg_wasm/node/worker.d.ts.map +0 -1
  688. package/dest/barretenberg_wasm/node/worker.js +0 -9
  689. package/dest/barretenberg_wasm.js +0 -2
  690. package/dest/barretenberg_wasm.js.LICENSE.txt +0 -5
  691. package/dest/bigint-array/index.d.ts +0 -3
  692. package/dest/bigint-array/index.d.ts.map +0 -1
  693. package/dest/bigint-array/index.js +0 -21
  694. package/dest/bindgen/function_declaration.d.ts +0 -11
  695. package/dest/bindgen/function_declaration.d.ts.map +0 -1
  696. package/dest/bindgen/function_declaration.js +0 -2
  697. package/dest/bindgen/index.d.ts +0 -2
  698. package/dest/bindgen/index.js +0 -15
  699. package/dest/bindgen/mappings.d.ts +0 -4
  700. package/dest/bindgen/mappings.d.ts.map +0 -1
  701. package/dest/bindgen/mappings.js +0 -63
  702. package/dest/bindgen/rust.d.ts +0 -2
  703. package/dest/bindgen/rust.d.ts.map +0 -1
  704. package/dest/bindgen/rust.js +0 -43
  705. package/dest/bindgen/to_camel_case.d.ts +0 -2
  706. package/dest/bindgen/to_camel_case.d.ts.map +0 -1
  707. package/dest/bindgen/to_camel_case.js +0 -11
  708. package/dest/bindgen/typescript.d.ts +0 -2
  709. package/dest/bindgen/typescript.d.ts.map +0 -1
  710. package/dest/bindgen/typescript.js +0 -80
  711. package/dest/crs/browser/cached_net_crs.d.ts +0 -25
  712. package/dest/crs/browser/cached_net_crs.d.ts.map +0 -1
  713. package/dest/crs/browser/cached_net_crs.js +0 -54
  714. package/dest/crs/browser/index.d.ts +0 -2
  715. package/dest/crs/browser/index.d.ts.map +0 -1
  716. package/dest/crs/browser/index.js +0 -2
  717. package/dest/crs/index.d.ts +0 -2
  718. package/dest/crs/index.d.ts.map +0 -1
  719. package/dest/crs/index.js +0 -2
  720. package/dest/crs/net_crs.d.ts +0 -36
  721. package/dest/crs/net_crs.d.ts.map +0 -1
  722. package/dest/crs/net_crs.js +0 -59
  723. package/dest/crs/node/ignition_files_crs.d.ts +0 -37
  724. package/dest/crs/node/ignition_files_crs.d.ts.map +0 -1
  725. package/dest/crs/node/ignition_files_crs.js +0 -51
  726. package/dest/crs/node/index.d.ts +0 -21
  727. package/dest/crs/node/index.d.ts.map +0 -1
  728. package/dest/crs/node/index.js +0 -54
  729. package/dest/examples/simple.rawtest.d.ts +0 -2
  730. package/dest/examples/simple.rawtest.d.ts.map +0 -1
  731. package/dest/examples/simple.rawtest.js +0 -29
  732. package/dest/examples/simple.test.d.ts +0 -2
  733. package/dest/examples/simple.test.d.ts.map +0 -1
  734. package/dest/examples/simple.test.js +0 -22
  735. package/dest/factory/index.d.ts +0 -21
  736. package/dest/factory/index.d.ts.map +0 -1
  737. package/dest/factory/index.js +0 -34
  738. package/dest/index.d.ts +0 -6
  739. package/dest/index.d.ts.map +0 -1
  740. package/dest/index.html +0 -1
  741. package/dest/index.js +0 -6
  742. package/dest/main.d.ts +0 -10
  743. package/dest/main.d.ts.map +0 -1
  744. package/dest/main.js +0 -275
  745. package/dest/random/browser/index.d.ts +0 -2
  746. package/dest/random/browser/index.d.ts.map +0 -1
  747. package/dest/random/browser/index.js +0 -31
  748. package/dest/random/index.d.ts +0 -2
  749. package/dest/random/index.d.ts.map +0 -1
  750. package/dest/random/node/index.d.ts +0 -2
  751. package/dest/random/node/index.d.ts.map +0 -1
  752. package/dest/random/node/index.js +0 -5
  753. package/dest/serialize/buffer_reader.d.ts +0 -28
  754. package/dest/serialize/buffer_reader.d.ts.map +0 -1
  755. package/dest/serialize/buffer_reader.js +0 -66
  756. package/dest/serialize/index.d.ts +0 -4
  757. package/dest/serialize/index.d.ts.map +0 -1
  758. package/dest/serialize/index.js +0 -4
  759. package/dest/serialize/output_type.d.ts +0 -11
  760. package/dest/serialize/output_type.d.ts.map +0 -1
  761. package/dest/serialize/output_type.js +0 -44
  762. package/dest/serialize/serialize.d.ts +0 -53
  763. package/dest/serialize/serialize.d.ts.map +0 -1
  764. package/dest/serialize/serialize.js +0 -139
  765. package/dest/simple_test.js +0 -2
  766. package/dest/simple_test.js.LICENSE.txt +0 -14
  767. package/dest/types/fields.d.ts +0 -33
  768. package/dest/types/fields.d.ts.map +0 -1
  769. package/dest/types/fields.js +0 -86
  770. package/dest/types/fixed_size_buffer.d.ts +0 -26
  771. package/dest/types/fixed_size_buffer.d.ts.map +0 -1
  772. package/dest/types/fixed_size_buffer.js +0 -54
  773. package/dest/types/index.d.ts +0 -6
  774. package/dest/types/index.d.ts.map +0 -1
  775. package/dest/types/index.js +0 -6
  776. package/dest/types/point.d.ts +0 -17
  777. package/dest/types/point.d.ts.map +0 -1
  778. package/dest/types/point.js +0 -32
  779. package/dest/types/ptr.d.ts +0 -13
  780. package/dest/types/ptr.d.ts.map +0 -1
  781. package/dest/types/ptr.js +0 -20
  782. package/dest/types/raw_buffer.d.ts +0 -3
  783. package/dest/types/raw_buffer.d.ts.map +0 -1
  784. package/dest/types/raw_buffer.js +0 -5
  785. package/src/barretenberg_api/blake2s.test.ts +0 -39
  786. package/src/barretenberg_api/common.test.ts +0 -21
  787. package/src/barretenberg_api/index.ts +0 -649
  788. package/src/barretenberg_api/pedersen.test.ts +0 -84
  789. package/src/barretenberg_api/schnorr.test.ts +0 -169
  790. package/src/barretenberg_binder/heap_allocator.ts +0 -62
  791. package/src/barretenberg_binder/heap_allocator_sync.ts +0 -61
  792. package/src/barretenberg_binder/index.ts +0 -76
  793. package/src/barretenberg_wasm/barretenberg_wasm.test.ts +0 -52
  794. package/src/barretenberg_wasm/barretenberg_wasm.ts +0 -246
  795. package/src/barretenberg_wasm/browser/index.ts +0 -32
  796. package/src/barretenberg_wasm/browser/worker.ts +0 -13
  797. package/src/barretenberg_wasm/node/index.ts +0 -46
  798. package/src/barretenberg_wasm/node/worker.ts +0 -10
  799. package/src/bigint-array/index.ts +0 -21
  800. package/src/bindgen/function_declaration.ts +0 -11
  801. package/src/bindgen/index.ts +0 -17
  802. package/src/bindgen/mappings.ts +0 -66
  803. package/src/bindgen/rust.ts +0 -52
  804. package/src/bindgen/to_camel_case.ts +0 -10
  805. package/src/bindgen/typescript.ts +0 -91
  806. package/src/crs/node/ignition_files_crs.ts +0 -60
  807. package/src/examples/simple.rawtest.ts +0 -37
  808. package/src/examples/simple.test.ts +0 -27
  809. package/src/factory/index.ts +0 -36
  810. package/src/main.ts +0 -311
  811. package/src/serialize/buffer_reader.ts +0 -82
  812. package/src/serialize/index.ts +0 -3
  813. package/src/serialize/output_type.ts +0 -53
  814. package/src/serialize/serialize.ts +0 -157
  815. package/src/types/fields.ts +0 -98
  816. package/src/types/fixed_size_buffer.ts +0 -59
  817. package/src/types/index.ts +0 -5
  818. package/src/types/point.ts +0 -35
  819. package/src/types/ptr.ts +0 -20
  820. package/src/types/raw_buffer.ts +0 -3
  821. /package/src/barretenberg_wasm/{node → helpers/node}/node_endpoint.ts +0 -0
@@ -0,0 +1,328 @@
1
+ import { spawn, ChildProcess } from 'child_process';
2
+ import * as net from 'net';
3
+ import * as fs from 'fs';
4
+ import * as os from 'os';
5
+ import * as path from 'path';
6
+ import { IMsgpackBackendAsync } from '../interface.js';
7
+ import readline from 'readline';
8
+ import { threadId } from 'worker_threads';
9
+
10
+ let instanceCounter = 0;
11
+
12
+ /**
13
+ * Asynchronous native backend that communicates with bb binary via Unix Domain Socket.
14
+ * Uses event-based I/O with a state machine to handle partial reads.
15
+ *
16
+ * Architecture: bb acts as the SERVER, TypeScript is the CLIENT
17
+ * - bb creates the socket and listens for connections
18
+ * - TypeScript waits for socket file to exist, then connects
19
+ *
20
+ * Protocol:
21
+ * - Request: 4-byte little-endian length + msgpack buffer
22
+ * - Response: 4-byte little-endian length + msgpack buffer
23
+ */
24
+ export class BarretenbergNativeSocketAsyncBackend implements IMsgpackBackendAsync {
25
+ private process: ChildProcess;
26
+ private socket: net.Socket | null = null;
27
+ private socketPath: string;
28
+ private connectionPromise: Promise<void>;
29
+ private connectionTimeout: NodeJS.Timeout | null = null;
30
+
31
+ // Queue of pending callbacks for pipelined requests
32
+ // Responses come back in FIFO order, so we match them with queued callbacks
33
+ private pendingCallbacks: Array<{
34
+ resolve: (data: Uint8Array) => void;
35
+ reject: (error: Error) => void;
36
+ }> = [];
37
+
38
+ // State machine for reading responses
39
+ private readingLength: boolean = true;
40
+ private lengthBuffer: Buffer = Buffer.alloc(4);
41
+ private lengthBytesRead: number = 0;
42
+ private responseLength: number = 0;
43
+ private responseBuffer: Buffer | null = null;
44
+ private responseBytesRead: number = 0;
45
+
46
+ constructor(bbBinaryPath: string, threads?: number, logger?: (msg: string) => void) {
47
+ // Create a unique socket path in temp directory
48
+ this.socketPath = path.join(os.tmpdir(), `bb-${process.pid}-${threadId}-${instanceCounter++}.sock`);
49
+
50
+ // Ensure socket path doesn't already exist (cleanup from previous crashes)
51
+ if (fs.existsSync(this.socketPath)) {
52
+ fs.unlinkSync(this.socketPath);
53
+ }
54
+
55
+ let connectionResolve: (() => void) | null = null;
56
+ let connectionReject: ((error: Error) => void) | null = null;
57
+
58
+ this.connectionPromise = new Promise<void>((resolve, reject) => {
59
+ connectionResolve = resolve;
60
+ connectionReject = reject;
61
+ });
62
+
63
+ // If threads not set use num cpu cores, max 16.
64
+ const hwc = threads ? threads.toString() : Math.min(16, os.cpus().length).toString();
65
+ const env = { ...process.env, HARDWARE_CONCURRENCY: hwc };
66
+
67
+ // Spawn bb process - it will create the socket server
68
+ const args = ['msgpack', 'run', '--input', this.socketPath];
69
+ this.process = spawn(bbBinaryPath, args, {
70
+ stdio: ['ignore', logger ? 'pipe' : 'ignore', logger ? 'pipe' : 'ignore'],
71
+ env,
72
+ });
73
+
74
+ // Disconnect from event loop so process can exit without waiting for bb
75
+ // The bb process has parent death monitoring (prctl on Linux, kqueue on macOS)
76
+ // so it will automatically exit when Node.js exits
77
+ this.process.unref();
78
+
79
+ if (logger) {
80
+ logger("Logger attached to bb process. DON'T FORGET TO DESTROY THE BACKEND to allow Node.js to exit.");
81
+ readline.createInterface({ input: this.process.stdout! }).on('line', logger);
82
+ readline.createInterface({ input: this.process.stderr! }).on('line', logger);
83
+ }
84
+
85
+ this.process.on('error', err => {
86
+ if (connectionReject) {
87
+ connectionReject(new Error(`Native backend process error: ${err.message}`));
88
+ connectionReject = null;
89
+ connectionResolve = null;
90
+ }
91
+ // Reject all pending callbacks
92
+ const error = new Error(`Native backend process error: ${err.message}`);
93
+ for (const callback of this.pendingCallbacks) {
94
+ callback.reject(error);
95
+ }
96
+ this.pendingCallbacks = [];
97
+ });
98
+
99
+ this.process.on('exit', (code, signal) => {
100
+ const errorMsg =
101
+ code !== null && code !== 0
102
+ ? `Native backend process exited with code ${code}`
103
+ : signal && signal !== 'SIGTERM'
104
+ ? `Native backend process killed with signal ${signal}`
105
+ : 'Native backend process exited unexpectedly';
106
+
107
+ if (connectionReject) {
108
+ connectionReject(new Error(errorMsg));
109
+ connectionReject = null;
110
+ connectionResolve = null;
111
+ }
112
+ // Reject all pending callbacks
113
+ const error = new Error(errorMsg);
114
+ for (const callback of this.pendingCallbacks) {
115
+ callback.reject(error);
116
+ }
117
+ this.pendingCallbacks = [];
118
+ });
119
+
120
+ // Wait for bb to create socket file, then connect
121
+ this.waitForSocketAndConnect()
122
+ .then(() => {
123
+ if (connectionResolve) {
124
+ connectionResolve();
125
+ connectionResolve = null;
126
+ connectionReject = null;
127
+ }
128
+ })
129
+ .catch(err => {
130
+ if (connectionReject) {
131
+ connectionReject(err);
132
+ connectionReject = null;
133
+ connectionResolve = null;
134
+ }
135
+ });
136
+
137
+ // Set a timeout for connection
138
+ this.connectionTimeout = setTimeout(() => {
139
+ if (connectionReject) {
140
+ connectionReject(new Error('Timeout waiting for bb socket connection'));
141
+ connectionReject = null;
142
+ connectionResolve = null;
143
+ this.cleanup();
144
+ }
145
+ }, 5000);
146
+ }
147
+
148
+ private async waitForSocketAndConnect(): Promise<void> {
149
+ // Poll for socket file to exist (bb is creating it)
150
+ const startTime = Date.now();
151
+ while (!fs.existsSync(this.socketPath)) {
152
+ if (Date.now() - startTime > 5000) {
153
+ throw new Error('Timeout waiting for bb to create socket file');
154
+ }
155
+ await new Promise(resolve => setTimeout(resolve, 50));
156
+ }
157
+
158
+ // Additional check: ensure it's actually a socket
159
+ const stats = fs.statSync(this.socketPath);
160
+ if (!stats.isSocket()) {
161
+ throw new Error(`Path exists but is not a socket: ${this.socketPath}`);
162
+ }
163
+
164
+ // Connect to bb's socket server as a client
165
+ return new Promise<void>((resolve, reject) => {
166
+ this.socket = net.connect(this.socketPath);
167
+
168
+ // Disable Nagle's algorithm for lower latency
169
+ this.socket.setNoDelay(true);
170
+
171
+ // Set up event handlers
172
+ this.socket.once('connect', () => {
173
+ // Socket starts referenced - will be unreferenced when no callbacks pending
174
+
175
+ // Clear connection timeout on successful connection
176
+ if (this.connectionTimeout) {
177
+ clearTimeout(this.connectionTimeout);
178
+ this.connectionTimeout = null;
179
+ }
180
+ resolve();
181
+ });
182
+
183
+ this.socket.once('error', err => {
184
+ reject(new Error(`Failed to connect to bb socket: ${err.message}`));
185
+ });
186
+
187
+ // Set up data handler after connection is established
188
+ this.socket.on('data', (chunk: Buffer) => {
189
+ this.handleData(chunk);
190
+ });
191
+
192
+ // Handle ongoing errors after initial connection
193
+ this.socket.on('error', err => {
194
+ // Reject all pending callbacks
195
+ const error = new Error(`Socket error: ${err.message}`);
196
+ for (const callback of this.pendingCallbacks) {
197
+ callback.reject(error);
198
+ }
199
+ this.pendingCallbacks = [];
200
+ });
201
+
202
+ this.socket.on('end', () => {
203
+ // Reject all pending callbacks
204
+ const error = new Error('Socket connection ended unexpectedly');
205
+ for (const callback of this.pendingCallbacks) {
206
+ callback.reject(error);
207
+ }
208
+ this.pendingCallbacks = [];
209
+ });
210
+ });
211
+ }
212
+
213
+ private handleData(chunk: Buffer): void {
214
+ let offset = 0;
215
+
216
+ while (offset < chunk.length) {
217
+ if (this.readingLength) {
218
+ // Reading 4-byte length prefix
219
+ const bytesToCopy = Math.min(4 - this.lengthBytesRead, chunk.length - offset);
220
+ chunk.copy(this.lengthBuffer, this.lengthBytesRead, offset, offset + bytesToCopy);
221
+ this.lengthBytesRead += bytesToCopy;
222
+ offset += bytesToCopy;
223
+
224
+ if (this.lengthBytesRead === 4) {
225
+ // Length is complete, switch to reading data
226
+ this.responseLength = this.lengthBuffer.readUInt32LE(0);
227
+ this.responseBuffer = Buffer.alloc(this.responseLength);
228
+ this.responseBytesRead = 0;
229
+ this.readingLength = false;
230
+ }
231
+ } else {
232
+ // Reading response data
233
+ const bytesToCopy = Math.min(this.responseLength - this.responseBytesRead, chunk.length - offset);
234
+ chunk.copy(this.responseBuffer!, this.responseBytesRead, offset, offset + bytesToCopy);
235
+ this.responseBytesRead += bytesToCopy;
236
+ offset += bytesToCopy;
237
+
238
+ if (this.responseBytesRead === this.responseLength) {
239
+ // Response is complete - dequeue the next pending callback (FIFO)
240
+ const callback = this.pendingCallbacks.shift();
241
+ if (callback) {
242
+ callback.resolve(new Uint8Array(this.responseBuffer!));
243
+ } else {
244
+ // This shouldn't happen - response without a pending request
245
+ console.warn('Received response but no pending callback');
246
+ }
247
+
248
+ // If no more pending callbacks, unref socket to allow process to exit
249
+ if (this.pendingCallbacks.length === 0 && this.socket) {
250
+ this.socket.unref();
251
+ }
252
+
253
+ // Reset state for next message
254
+ this.readingLength = true;
255
+ this.lengthBytesRead = 0;
256
+ this.responseLength = 0;
257
+ this.responseBuffer = null;
258
+ this.responseBytesRead = 0;
259
+ }
260
+ }
261
+ }
262
+ }
263
+
264
+ async call(inputBuffer: Uint8Array): Promise<Uint8Array> {
265
+ // Wait for connection to be established
266
+ await this.connectionPromise;
267
+
268
+ if (!this.socket) {
269
+ throw new Error('Socket not connected');
270
+ }
271
+
272
+ return new Promise((resolve, reject) => {
273
+ // If this is the first pending callback, ref the socket to keep event loop alive
274
+ if (this.pendingCallbacks.length === 0) {
275
+ this.socket!.ref();
276
+ }
277
+
278
+ // Enqueue this promise's callbacks (FIFO order)
279
+ this.pendingCallbacks.push({ resolve, reject });
280
+
281
+ // Write request: 4-byte little-endian length + msgpack data
282
+ // Socket will buffer these if needed, maintaining order
283
+ const lengthBuf = Buffer.alloc(4);
284
+ lengthBuf.writeUInt32LE(inputBuffer.length, 0);
285
+ this.socket!.write(lengthBuf);
286
+ this.socket!.write(inputBuffer);
287
+ });
288
+ }
289
+
290
+ private cleanup(): void {
291
+ // Reject any remaining pending callbacks
292
+ const error = new Error('Backend connection closed');
293
+ for (const callback of this.pendingCallbacks) {
294
+ callback.reject(error);
295
+ }
296
+ this.pendingCallbacks = [];
297
+
298
+ try {
299
+ // Remove all event listeners to prevent hanging
300
+ if (this.socket) {
301
+ this.socket.removeAllListeners();
302
+ // Unref so socket doesn't keep event loop alive
303
+ // this.socket.unref();
304
+ this.socket.destroy();
305
+ }
306
+ } catch (e) {
307
+ // Ignore errors during cleanup
308
+ }
309
+
310
+ // Clear connection timeout if still pending
311
+ if (this.connectionTimeout) {
312
+ clearTimeout(this.connectionTimeout);
313
+ this.connectionTimeout = null;
314
+ }
315
+
316
+ // Remove process event listeners and unref to not block event loop
317
+ this.process.removeAllListeners();
318
+ // this.process.unref();
319
+
320
+ // Don't try to unlink socket - bb owns it and will clean it up
321
+ }
322
+
323
+ async destroy(): Promise<void> {
324
+ this.cleanup();
325
+ this.process.kill('SIGTERM');
326
+ this.process.removeAllListeners();
327
+ }
328
+ }
@@ -0,0 +1,156 @@
1
+ import * as path from 'path';
2
+ import * as fs from 'fs';
3
+ import { fileURLToPath } from 'url';
4
+
5
+ function getCurrentDir() {
6
+ if (typeof __dirname !== 'undefined') {
7
+ return __dirname;
8
+ } else {
9
+ // eslint-disable-next-line @typescript-eslint/ban-ts-comment
10
+ // @ts-ignore
11
+ return path.dirname(fileURLToPath(import.meta.url));
12
+ }
13
+ }
14
+
15
+ /**
16
+ * Find package root by climbing directory tree until package.json is found.
17
+ * @param startDir Starting directory to search from
18
+ * @returns Absolute path to package root, or null if not found
19
+ */
20
+ export function findPackageRoot(): string | null {
21
+ let currentDir = getCurrentDir();
22
+ const root = path.parse(currentDir).root;
23
+
24
+ while (currentDir !== root) {
25
+ const packageJsonPath = path.join(currentDir, 'package.json');
26
+ if (fs.existsSync(packageJsonPath)) {
27
+ // Check if this is the actual package root by verifying it has a 'build' directory
28
+ // This ensures we skip intermediate package.json files (e.g., in dest/node-cjs/)
29
+ const buildDir = path.join(currentDir, 'build');
30
+ if (fs.existsSync(buildDir)) {
31
+ return currentDir;
32
+ }
33
+ }
34
+ currentDir = path.dirname(currentDir);
35
+ }
36
+
37
+ return null;
38
+ }
39
+
40
+ /**
41
+ * Supported platform/architecture combinations.
42
+ */
43
+ export type Platform = 'x86_64-linux' | 'x86_64-darwin' | 'aarch64-linux' | 'aarch64-darwin';
44
+
45
+ /**
46
+ * Map from Platform to build directory name.
47
+ */
48
+ const PLATFORM_TO_BUILD_DIR: Record<Platform, string> = {
49
+ 'x86_64-linux': 'amd64-linux',
50
+ 'x86_64-darwin': 'amd64-macos',
51
+ 'aarch64-linux': 'arm64-linux',
52
+ 'aarch64-darwin': 'arm64-macos',
53
+ };
54
+
55
+ /**
56
+ * Detect the current platform and architecture.
57
+ * @returns Platform identifier or null if unsupported
58
+ */
59
+ export function detectPlatform(): Platform | null {
60
+ const arch = process.arch; // 'x64' | 'arm64' | ...
61
+ const platform = process.platform; // 'linux' | 'darwin' | 'win32' | ...
62
+
63
+ if (arch === 'x64' && platform === 'linux') {
64
+ return 'x86_64-linux';
65
+ }
66
+ if (arch === 'x64' && platform === 'darwin') {
67
+ return 'x86_64-darwin';
68
+ }
69
+ if (arch === 'arm64' && platform === 'linux') {
70
+ return 'aarch64-linux';
71
+ }
72
+ if (arch === 'arm64' && platform === 'darwin') {
73
+ return 'aarch64-darwin';
74
+ }
75
+
76
+ return null;
77
+ }
78
+
79
+ /**
80
+ * Find the bb binary for the native backend.
81
+ * @param customPath Optional custom path to bb binary (overrides automatic detection)
82
+ * @returns Absolute path to bb binary, or null if not found
83
+ *
84
+ * Search order:
85
+ * 1. If customPath is provided and exists, return it
86
+ * 2. Otherwise search in <package-root>/build/<platform>/bb
87
+ */
88
+ export function findBbBinary(customPath?: string): string | null {
89
+ // Check custom path first if provided
90
+ if (customPath) {
91
+ if (fs.existsSync(customPath)) {
92
+ return path.resolve(customPath);
93
+ }
94
+ // Custom path provided but doesn't exist - return null
95
+ return null;
96
+ }
97
+
98
+ // Automatic detection
99
+ const platform = detectPlatform();
100
+ if (!platform) {
101
+ return null;
102
+ }
103
+
104
+ const buildDir = PLATFORM_TO_BUILD_DIR[platform];
105
+
106
+ // Get package root by climbing directory tree to find package.json
107
+ const packageRoot = findPackageRoot();
108
+
109
+ if (!packageRoot) {
110
+ return null;
111
+ }
112
+
113
+ // Check in build/<platform>/bb
114
+ const bbPath = path.join(packageRoot, 'build', buildDir, 'bb');
115
+
116
+ if (fs.existsSync(bbPath)) {
117
+ return bbPath;
118
+ }
119
+
120
+ return null;
121
+ }
122
+
123
+ export function findNapiBinary(customPath?: string): string | null {
124
+ // Check custom path first if provided
125
+ if (customPath) {
126
+ if (fs.existsSync(customPath)) {
127
+ return path.resolve(customPath);
128
+ }
129
+ // Custom path provided but doesn't exist - return null
130
+ return null;
131
+ }
132
+
133
+ // Automatic detection
134
+ const platform = detectPlatform();
135
+ if (!platform) {
136
+ return null;
137
+ }
138
+
139
+ const buildDir = PLATFORM_TO_BUILD_DIR[platform];
140
+
141
+ // Get package root by climbing directory tree to find package.json
142
+ const packageRoot = findPackageRoot();
143
+
144
+ if (!packageRoot) {
145
+ return null;
146
+ }
147
+
148
+ // Check in build/<platform>/nodejs_module.node
149
+ const bbPath = path.join(packageRoot, 'build', buildDir, 'nodejs_module.node');
150
+
151
+ if (fs.existsSync(bbPath)) {
152
+ return bbPath;
153
+ }
154
+
155
+ return null;
156
+ }
@@ -0,0 +1,102 @@
1
+ import { BarretenbergWasmMain, BarretenbergWasmMainWorker } from '../barretenberg_wasm/barretenberg_wasm_main/index.js';
2
+ import { fetchModuleAndThreads } from '../barretenberg_wasm/index.js';
3
+ import { IMsgpackBackendSync, IMsgpackBackendAsync } from './interface.js';
4
+ import { createMainWorker } from '../barretenberg_wasm/barretenberg_wasm_main/factory/node/index.js';
5
+ import { getRemoteBarretenbergWasm } from '../barretenberg_wasm/helpers/index.js';
6
+ import { proxy } from 'comlink';
7
+
8
+ /**
9
+ * Synchronous WASM backend that wraps BarretenbergWasmMain.
10
+ * Encapsulates all WASM initialization and memory management.
11
+ */
12
+ export class BarretenbergWasmSyncBackend implements IMsgpackBackendSync {
13
+ private constructor(private wasm: BarretenbergWasmMain) {}
14
+
15
+ /**
16
+ * Create and initialize a synchronous WASM backend.
17
+ * @param wasmPath Optional path to WASM files
18
+ * @param logger Optional logging function
19
+ */
20
+ static async new(wasmPath?: string, logger?: (msg: string) => void): Promise<BarretenbergWasmSyncBackend> {
21
+ const wasm = new BarretenbergWasmMain();
22
+ const { module, threads } = await fetchModuleAndThreads(1, wasmPath, logger);
23
+ await wasm.init(module, threads, logger);
24
+ return new BarretenbergWasmSyncBackend(wasm);
25
+ }
26
+
27
+ call(inputBuffer: Uint8Array): Uint8Array {
28
+ return this.wasm.cbindCall('bbapi', inputBuffer);
29
+ }
30
+
31
+ destroy(): void {
32
+ // BarretenbergWasmMain has async destroy, but for sync API we call it without awaiting
33
+ // This is consistent with the synchronous semantics expected by the caller
34
+ void this.wasm.destroy();
35
+ }
36
+ }
37
+
38
+ /**
39
+ * Asynchronous WASM backend that supports both direct WASM and worker-based modes.
40
+ *
41
+ * Worker mode (default): Runs WASM on a worker thread to avoid blocking the main thread. Used in browsers.
42
+ * Direct mode: Runs WASM directly on the calling thread. Used by node.js for better performance.
43
+ */
44
+ export class BarretenbergWasmAsyncBackend implements IMsgpackBackendAsync {
45
+ private constructor(
46
+ private wasm: BarretenbergWasmMain | BarretenbergWasmMainWorker,
47
+ private worker?: any,
48
+ ) {}
49
+
50
+ /**
51
+ * Create and initialize an asynchronous WASM backend.
52
+ * @param options.threads Number of threads (defaults to hardware max, up to 32 for parallel proving)
53
+ * @param options.wasmPath Optional path to WASM files
54
+ * @param options.logger Optional logging function
55
+ * @param options.memory Optional initial and maximum memory configuration
56
+ * @param options.useWorker Run on worker thread (default: true for browser safety)
57
+ */
58
+ static async new(
59
+ options: {
60
+ threads?: number;
61
+ wasmPath?: string;
62
+ logger?: (msg: string) => void;
63
+ memory?: { initial?: number; maximum?: number };
64
+ useWorker?: boolean;
65
+ } = {},
66
+ ): Promise<BarretenbergWasmAsyncBackend> {
67
+ // Default to worker mode for browser safety
68
+ const useWorker = options.useWorker ?? true;
69
+
70
+ if (useWorker) {
71
+ // Worker-based mode: runs on worker thread (browser-safe)
72
+ const worker = await createMainWorker();
73
+ const wasm = getRemoteBarretenbergWasm<BarretenbergWasmMainWorker>(worker);
74
+ const { module, threads } = await fetchModuleAndThreads(options.threads, options.wasmPath, options.logger);
75
+ await wasm.init(
76
+ module,
77
+ threads,
78
+ proxy(options.logger ?? (() => {})),
79
+ options.memory?.initial,
80
+ options.memory?.maximum,
81
+ );
82
+ return new BarretenbergWasmAsyncBackend(wasm, worker);
83
+ } else {
84
+ // Direct mode: runs on calling thread (faster but blocks thread)
85
+ const wasm = new BarretenbergWasmMain();
86
+ const { module, threads } = await fetchModuleAndThreads(options.threads, options.wasmPath, options.logger);
87
+ await wasm.init(module, threads, options.logger, options.memory?.initial, options.memory?.maximum);
88
+ return new BarretenbergWasmAsyncBackend(wasm);
89
+ }
90
+ }
91
+
92
+ async call(inputBuffer: Uint8Array): Promise<Uint8Array> {
93
+ return this.wasm.cbindCall('bbapi', inputBuffer);
94
+ }
95
+
96
+ async destroy(): Promise<void> {
97
+ await this.wasm.destroy();
98
+ if (this.worker) {
99
+ await this.worker.terminate();
100
+ }
101
+ }
102
+ }
@@ -0,0 +1,54 @@
1
+ import { BarretenbergWasmSyncBackend } from '../bb_backends/wasm.js';
2
+ import { SyncApi } from '../cbind/generated/sync.js';
3
+ import { BBApiException } from '../bbapi_exception.js';
4
+
5
+ describe('BBApi Exception Handling from bb.js', () => {
6
+ let backend: BarretenbergWasmSyncBackend;
7
+ let api: SyncApi;
8
+
9
+ beforeAll(async () => {
10
+ backend = await BarretenbergWasmSyncBackend.new();
11
+ api = new SyncApi(backend);
12
+ }, 60000);
13
+
14
+ afterAll(() => {
15
+ backend.destroy();
16
+ });
17
+
18
+ it('should catch CRS initialization exceptions from WASM', () => {
19
+ // Create an SrsInitSrs command with invalid data that will cause an exception in C++
20
+ // We pass buffers that are too small, which will cause validation to fail
21
+ const invalidCommand = {
22
+ numPoints: 100, // Request 100 points (requires 6400 bytes)
23
+ pointsBuf: new Uint8Array(10), // Only 10 bytes - will cause exception
24
+ g2Point: new Uint8Array(10), // Only 10 bytes (needs 128) - will cause exception
25
+ };
26
+
27
+ // In WASM builds, throw_or_abort calls abort directly which throws a generic Error
28
+ // In native builds with exceptions, our try-catch in bbapi converts it to ErrorResponse
29
+ // This test verifies that errors are catchable from bb.js (even if as generic Error in WASM)
30
+ expect(() => {
31
+ api.srsInitSrs(invalidCommand);
32
+ }).toThrow();
33
+ });
34
+
35
+ it('should return error message from caught exception', () => {
36
+ const invalidCommand = {
37
+ numPoints: 100,
38
+ pointsBuf: new Uint8Array(10),
39
+ g2Point: new Uint8Array(10),
40
+ };
41
+
42
+ try {
43
+ api.srsInitSrs(invalidCommand);
44
+ fail('Expected exception to be thrown');
45
+ } catch (error) {
46
+ // Error is catchable and contains a useful message
47
+ expect(error).toBeInstanceOf(Error);
48
+ expect((error as Error).message).toBeTruthy();
49
+ expect((error as Error).message.length).toBeGreaterThan(0);
50
+ expect((error as Error).message).toContain('g1_identity');
51
+ console.log('Successfully caught exception from bb.js with message:', (error as Error).message);
52
+ }
53
+ });
54
+ });
@@ -0,0 +1,13 @@
1
+ /**
2
+ * Exception thrown when barretenberg API operations fail
3
+ */
4
+ export class BBApiException extends Error {
5
+ constructor(message: string) {
6
+ super(message);
7
+ this.name = 'BBApiException';
8
+ // Maintains proper stack trace for where our error was thrown (only available on V8)
9
+ if (Error.captureStackTrace) {
10
+ Error.captureStackTrace(this, BBApiException);
11
+ }
12
+ }
13
+ }
@@ -0,0 +1,26 @@
1
+ import * as fs from 'fs';
2
+ export * from './timer.js';
3
+
4
+ const bfd = (() => {
5
+ const bfdStr = process.env.BENCHMARK_FD;
6
+ const bfd = bfdStr ? parseInt(bfdStr) : -1;
7
+ if (bfd >= 0 && !fs.fstatSync(bfd)) {
8
+ throw new Error('fd is not open. Did you redirect in your shell?');
9
+ }
10
+ return bfd;
11
+ })();
12
+
13
+ export function writeBenchmark<T>(name: string, value: T, labels: Record<string, any> = {}) {
14
+ if (bfd === -1) {
15
+ return;
16
+ }
17
+ const data = {
18
+ timestamp: new Date().toISOString(),
19
+ name,
20
+ type: typeof value,
21
+ value,
22
+ ...labels,
23
+ };
24
+ const jsonl = JSON.stringify(data) + '\n';
25
+ fs.writeSync(bfd, jsonl);
26
+ }