@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,214 @@
1
+ import { createRequire } from 'module';
2
+ import { spawn, ChildProcess } from 'child_process';
3
+ import { openSync, closeSync, unlinkSync } from 'fs';
4
+ import { IMsgpackBackendSync } from '../interface.js';
5
+ import { findNapiBinary, findPackageRoot } from './platform.js';
6
+ import { threadId } from 'worker_threads';
7
+
8
+ let instanceCounter = 0;
9
+
10
+ /**
11
+ * Synchronous shared memory backend that communicates with bb binary via shared memory.
12
+ * Uses NAPI module to interface with shared memory IPC.
13
+ *
14
+ * Architecture: bb acts as the SERVER, TypeScript is the CLIENT
15
+ * - bb creates the shared memory region
16
+ * - TypeScript connects via NAPI wrapper
17
+ *
18
+ * Protocol:
19
+ * - Handled internally by IpcClient (no manual length prefixes needed)
20
+ */
21
+ export class BarretenbergNativeShmSyncBackend implements IMsgpackBackendSync {
22
+ private process: ChildProcess;
23
+ private client: any; // NAPI MsgpackClient instance
24
+ private logFd?: number; // File descriptor for logs
25
+
26
+ private constructor(process: ChildProcess, client: any, logFd?: number) {
27
+ this.process = process;
28
+ this.client = client;
29
+ this.logFd = logFd;
30
+ }
31
+
32
+ /**
33
+ * Create and initialize a shared memory backend.
34
+ * @param bbBinaryPath Path to bb binary
35
+ * @param napiPath Path to NAPI binary
36
+ * @param threads Optional number of threads
37
+ */
38
+ static async new(
39
+ bbBinaryPath: string,
40
+ napiPath: string,
41
+ threads?: number,
42
+ logger?: (msg: string) => void,
43
+ ): Promise<BarretenbergNativeShmSyncBackend> {
44
+ // Import the NAPI module
45
+ // The addon is built to the nodejs_module directory
46
+ const addonPath = findNapiBinary(napiPath);
47
+ // Try loading
48
+ let addon: any = null;
49
+ try {
50
+ const require = createRequire(findPackageRoot()!);
51
+ addon = require(addonPath!);
52
+ } catch (err) {
53
+ // Addon not built yet or not available
54
+ throw new Error('Shared memory sync NAPI not available.');
55
+ }
56
+
57
+ // Create a unique shared memory name
58
+ const shmName = `bb-sync-${process.pid}-${threadId}-${instanceCounter++}`;
59
+
60
+ // If threads not set use 1 thread. We're not expected to do long lived work on sync backends.
61
+ const hwc = threads ? threads.toString() : '1';
62
+ const env = { ...process.env, HARDWARE_CONCURRENCY: hwc };
63
+
64
+ // Set up file logging if logger is provided.
65
+ // Direct file redirection bypasses Node event loop - logs are written even if process hangs.
66
+ let logFd: number | undefined;
67
+ let logPath: string | undefined;
68
+ if (logger) {
69
+ logPath = `/tmp/${shmName}.log`;
70
+ logFd = openSync(logPath, 'w');
71
+ logger(`BB process logs redirected to: ${logPath}`);
72
+ }
73
+
74
+ // Clean up any stale shared memory files from previous runs
75
+ // This handles the case where a previous process crashed without cleanup
76
+ const shmRequestPath = `/dev/shm/${shmName}_request`;
77
+ const shmResponsePath = `/dev/shm/${shmName}_response`;
78
+ try {
79
+ unlinkSync(shmRequestPath);
80
+ } catch (err) {
81
+ const isNotFound = err && typeof err === 'object' && 'code' in err && err.code === 'ENOENT';
82
+ if (!isNotFound) {
83
+ throw new Error(`Failed to clean up stale shared memory file ${shmRequestPath}: ${err}`);
84
+ }
85
+ }
86
+
87
+ try {
88
+ unlinkSync(shmResponsePath);
89
+ } catch (err) {
90
+ const isNotFound = err && typeof err === 'object' && 'code' in err && err.code === 'ENOENT';
91
+ if (!isNotFound) {
92
+ throw new Error(`Failed to clean up stale shared memory file ${shmResponsePath}: ${err}`);
93
+ }
94
+ }
95
+
96
+ // Spawn bb process with shared memory mode (SPSC-only, no max-clients needed)
97
+ const args = ['msgpack', 'run', '--input', `${shmName}.shm`, '--request-ring-size', `${1024 * 1024 * 4}`];
98
+ const bbProcess = spawn(bbBinaryPath, args, {
99
+ stdio: ['ignore', logFd ?? 'ignore', logFd ?? 'ignore'],
100
+ env,
101
+ });
102
+
103
+ // Disconnect from event loop so process can exit without waiting for bb
104
+ // The bb process has parent death monitoring (prctl on Linux, kqueue on macOS)
105
+ // so it will automatically exit when Node.js exits
106
+ bbProcess.unref();
107
+
108
+ // Track if process has exited
109
+ let processExited = false;
110
+ let exitError: Error | null = null;
111
+
112
+ bbProcess.on('error', err => {
113
+ processExited = true;
114
+ exitError = new Error(`Native backend process error: ${err.message}`);
115
+ });
116
+
117
+ bbProcess.on('exit', (code, signal) => {
118
+ processExited = true;
119
+ if (code !== null && code !== 0) {
120
+ exitError = new Error(`Native backend process exited with code ${code}`);
121
+ } else if (signal && signal !== 'SIGTERM') {
122
+ exitError = new Error(`Native backend process killed with signal ${signal}`);
123
+ }
124
+ });
125
+
126
+ // Wait for bb to create shared memory
127
+ // Retry connection every 100ms for up to 3 seconds
128
+ const retryInterval = 100; // ms
129
+ const timeout = 3000; // ms
130
+ const maxAttempts = Math.floor(timeout / retryInterval);
131
+ let client: any = null;
132
+
133
+ try {
134
+ for (let attempt = 0; attempt < maxAttempts; attempt++) {
135
+ // Check if bb process has exited before attempting connection
136
+ if (processExited) {
137
+ throw exitError || new Error('Native backend process exited unexpectedly during startup');
138
+ }
139
+
140
+ // Wait before attempting connection (except first attempt)
141
+ if (attempt > 0) {
142
+ await new Promise(resolve => setTimeout(resolve, retryInterval));
143
+ }
144
+
145
+ try {
146
+ // Create NAPI client (SPSC-only, no max_clients needed)
147
+ client = new addon.MsgpackClient(shmName);
148
+ break; // Success!
149
+ } catch (err: any) {
150
+ // Connection failed, will retry
151
+ if (attempt === maxAttempts - 1) {
152
+ // Last attempt failed - check one more time if process exited
153
+ if (processExited && exitError) {
154
+ throw exitError;
155
+ }
156
+ throw new Error(`Failed to connect to shared memory after ${timeout}ms: ${err.message}`);
157
+ }
158
+ }
159
+ }
160
+
161
+ if (!client) {
162
+ throw new Error('Failed to create client connection');
163
+ }
164
+
165
+ return new BarretenbergNativeShmSyncBackend(bbProcess, client, logFd);
166
+ } finally {
167
+ // If we failed to connect, ensure the process is killed and log file closed
168
+ // kill() returns false if process already exited, but doesn't throw
169
+ if (!client) {
170
+ bbProcess.kill('SIGKILL');
171
+ if (logFd !== undefined) {
172
+ try {
173
+ closeSync(logFd);
174
+ } catch (e) {
175
+ // Ignore errors during cleanup
176
+ }
177
+ }
178
+ }
179
+ }
180
+ }
181
+
182
+ call(inputBuffer: Uint8Array): Uint8Array {
183
+ try {
184
+ const responseBuffer = this.client.call(Buffer.from(inputBuffer));
185
+ return new Uint8Array(responseBuffer);
186
+ } catch (err: any) {
187
+ throw new Error(`Shared memory call failed: ${err.message}`);
188
+ }
189
+ }
190
+
191
+ private cleanup(): void {
192
+ if (this.client) {
193
+ try {
194
+ this.client.close();
195
+ } catch (e) {
196
+ // Ignore errors during cleanup
197
+ }
198
+ }
199
+ if (this.logFd !== undefined) {
200
+ try {
201
+ closeSync(this.logFd);
202
+ } catch (e) {
203
+ // Ignore errors during cleanup
204
+ }
205
+ }
206
+ }
207
+
208
+ destroy(): void {
209
+ this.cleanup();
210
+ this.process.kill('SIGTERM');
211
+ // Remove process event listeners to prevent hanging
212
+ this.process.removeAllListeners();
213
+ }
214
+ }
@@ -0,0 +1,262 @@
1
+ import { createRequire } from 'module';
2
+ import { spawn, ChildProcess } from 'child_process';
3
+ import { openSync, closeSync } from 'fs';
4
+ import { IMsgpackBackendAsync } from '../interface.js';
5
+ import { findNapiBinary, findPackageRoot } from './platform.js';
6
+ import { threadId } from 'worker_threads';
7
+
8
+ let instanceCounter = 0;
9
+
10
+ /**
11
+ * Asynchronous shared memory backend that communicates with bb binary via shared memory.
12
+ * Uses NAPI module with background thread polling for async operations.
13
+ * Supports request pipelining - multiple requests can be in flight simultaneously.
14
+ *
15
+ * Architecture (matches socket backend pattern):
16
+ * - bb acts as the SERVER, TypeScript is the CLIENT
17
+ * - bb creates the shared memory region
18
+ * - TypeScript connects via NAPI wrapper (MsgpackClientAsync)
19
+ * - TypeScript manages promise queue (single-threaded, no mutex needed)
20
+ * - C++ background thread polls for responses, calls JavaScript callback
21
+ * - JavaScript callback pops queue and resolves promises in FIFO order
22
+ */
23
+ export class BarretenbergNativeShmAsyncBackend implements IMsgpackBackendAsync {
24
+ private process: ChildProcess;
25
+ private client: any; // NAPI MsgpackClientAsync instance
26
+ private logFd?: number; // File descriptor for logs
27
+
28
+ // Queue of pending callbacks for pipelined requests
29
+ // Responses come back in FIFO order, so we match them with queued callbacks
30
+ private pendingCallbacks: Array<{
31
+ resolve: (data: Uint8Array) => void;
32
+ reject: (error: Error) => void;
33
+ }> = [];
34
+
35
+ private constructor(process: ChildProcess, client: any, logFd?: number) {
36
+ this.process = process;
37
+ this.client = client;
38
+ this.logFd = logFd;
39
+
40
+ // Register our response handler with the C++ client
41
+ // This callback will be invoked from the background thread via ThreadSafeFunction
42
+ this.client.setResponseCallback((responseBuffer: Buffer) => {
43
+ this.handleResponse(responseBuffer);
44
+ });
45
+ }
46
+
47
+ /**
48
+ * Handle response from C++ background thread
49
+ * Dequeues the next pending callback and resolves it (FIFO order)
50
+ */
51
+ private handleResponse(responseBuffer: Buffer): void {
52
+ // Response is complete - dequeue the next pending callback (FIFO)
53
+ const callback = this.pendingCallbacks.shift();
54
+ if (callback) {
55
+ callback.resolve(new Uint8Array(responseBuffer));
56
+ } else {
57
+ // This shouldn't happen - response without a pending request
58
+ console.warn('Received response but no pending callback');
59
+ }
60
+
61
+ // If no more pending callbacks, release ref to allow process to exit
62
+ if (this.pendingCallbacks.length === 0) {
63
+ this.client.release();
64
+ }
65
+ }
66
+
67
+ /**
68
+ * Create and initialize an async shared memory backend.
69
+ * @param bbBinaryPath Path to bb binary
70
+ * @param threads Optional number of threads (defaults to min(32, num_cpus))
71
+ * @param logger Optional logger function for bb output
72
+ */
73
+ static async new(
74
+ bbBinaryPath: string,
75
+ napiPath: string,
76
+ threads?: number,
77
+ logger?: (msg: string) => void,
78
+ ): Promise<BarretenbergNativeShmAsyncBackend> {
79
+ // Import the NAPI module
80
+ // The addon is built to the nodejs_module directory
81
+ const addonPath = findNapiBinary(napiPath);
82
+ // Try loading
83
+ let addon: any = null;
84
+ try {
85
+ const require = createRequire(findPackageRoot()!);
86
+ addon = require(addonPath!);
87
+ } catch (err) {
88
+ // Addon not built yet or not available
89
+ throw new Error('Shared memory async NAPI not available.');
90
+ }
91
+
92
+ // Create a unique shared memory name
93
+ const shmName = `bb-async-${process.pid}-${threadId}-${instanceCounter++}`;
94
+
95
+ // If threads not set use num cpu cores, max 16 (same as socket backend)
96
+ const hwc = threads ? threads.toString() : '16';
97
+ const env = { ...process.env, HARDWARE_CONCURRENCY: hwc };
98
+
99
+ // Set up file logging if logger is provided
100
+ // Direct file redirection bypasses Node event loop - logs are written even if process hangs
101
+ let logFd: number | undefined;
102
+ let logPath: string | undefined;
103
+ if (logger) {
104
+ logPath = `/tmp/${shmName}.log`;
105
+ logFd = openSync(logPath, 'w');
106
+ logger(`BB process logs redirected to: ${logPath}`);
107
+ }
108
+
109
+ // Spawn bb process with shared memory mode
110
+ // Use larger ring buffers for async mode to support pipelining
111
+ const args = [
112
+ 'msgpack',
113
+ 'run',
114
+ '--input',
115
+ `${shmName}.shm`,
116
+ '--request-ring-size',
117
+ `${1024 * 1024 * 4}`,
118
+ '--response-ring-size',
119
+ `${1024 * 1024 * 4}`,
120
+ ];
121
+ const bbProcess = spawn(bbBinaryPath, args, {
122
+ stdio: ['ignore', logFd ?? 'ignore', logFd ?? 'ignore'],
123
+ env,
124
+ });
125
+
126
+ // Disconnect from event loop so process can exit without waiting for bb
127
+ // The bb process has parent death monitoring (prctl on Linux, kqueue on macOS)
128
+ // so it will automatically exit when Node.js exits
129
+ bbProcess.unref();
130
+
131
+ // Track if process has exited
132
+ let processExited = false;
133
+ let exitError: Error | null = null;
134
+
135
+ bbProcess.on('error', err => {
136
+ processExited = true;
137
+ exitError = new Error(`Native backend process error: ${err.message}`);
138
+ });
139
+
140
+ bbProcess.on('exit', (code, signal) => {
141
+ processExited = true;
142
+ if (code !== null && code !== 0) {
143
+ exitError = new Error(`Native backend process exited with code ${code}`);
144
+ } else if (signal && signal !== 'SIGTERM') {
145
+ exitError = new Error(`Native backend process killed with signal ${signal}`);
146
+ }
147
+ });
148
+
149
+ // Wait for bb to create shared memory
150
+ // Retry connection every 100ms for up to 5 seconds (longer than sync for thread startup)
151
+ const retryInterval = 100; // ms
152
+ const timeout = 5000; // ms
153
+ const maxAttempts = Math.floor(timeout / retryInterval);
154
+ let client: any = null;
155
+
156
+ try {
157
+ for (let attempt = 0; attempt < maxAttempts; attempt++) {
158
+ // Check if bb process has exited before attempting connection
159
+ if (processExited) {
160
+ throw exitError || new Error('Native backend process exited unexpectedly during startup');
161
+ }
162
+
163
+ // Wait before attempting connection (except first attempt)
164
+ if (attempt > 0) {
165
+ await new Promise(resolve => setTimeout(resolve, retryInterval));
166
+ }
167
+
168
+ try {
169
+ // Create NAPI async client
170
+ client = new addon.MsgpackClientAsync(shmName);
171
+ break; // Success!
172
+ } catch (err: any) {
173
+ // Connection failed, will retry
174
+ if (attempt === maxAttempts - 1) {
175
+ // Last attempt failed - check one more time if process exited
176
+ if (processExited && exitError) {
177
+ throw exitError;
178
+ }
179
+ throw new Error(`Failed to connect to shared memory after ${timeout}ms: ${err.message}`);
180
+ }
181
+ }
182
+ }
183
+
184
+ if (!client) {
185
+ throw new Error('Failed to create client connection');
186
+ }
187
+
188
+ return new BarretenbergNativeShmAsyncBackend(bbProcess, client, logFd);
189
+ } finally {
190
+ // If we failed to connect, ensure the process is killed and log file closed
191
+ if (!client) {
192
+ bbProcess.kill('SIGKILL');
193
+ if (logFd !== undefined) {
194
+ try {
195
+ closeSync(logFd);
196
+ } catch (e) {
197
+ // Ignore errors during cleanup
198
+ }
199
+ }
200
+ }
201
+ }
202
+ }
203
+
204
+ /**
205
+ * Send a msgpack request asynchronously.
206
+ * Supports pipelining - can be called multiple times before awaiting responses.
207
+ * Use Promise.all() to send multiple requests concurrently.
208
+ *
209
+ * Example:
210
+ * const results = await Promise.all([
211
+ * backend.call(buf1),
212
+ * backend.call(buf2),
213
+ * backend.call(buf3)
214
+ * ]);
215
+ *
216
+ * @param inputBuffer The msgpack-encoded request
217
+ * @returns Promise resolving to msgpack-encoded response
218
+ */
219
+ async call(inputBuffer: Uint8Array): Promise<Uint8Array> {
220
+ return new Promise((resolve, reject) => {
221
+ // If this is the first pending callback, acquire ref to keep event loop alive
222
+ if (this.pendingCallbacks.length === 0) {
223
+ this.client.acquire();
224
+ }
225
+
226
+ // Enqueue this promise's callbacks (FIFO order)
227
+ this.pendingCallbacks.push({ resolve, reject });
228
+
229
+ try {
230
+ // Send request to shared memory (synchronous write)
231
+ // C++ call() no longer returns a promise - we manage them here
232
+ this.client.call(Buffer.from(inputBuffer));
233
+ } catch (err: any) {
234
+ // Send failed - dequeue the callback we just added and reject
235
+ this.pendingCallbacks.pop();
236
+
237
+ // If queue is now empty, release ref to allow exit
238
+ if (this.pendingCallbacks.length === 0) {
239
+ this.client.release();
240
+ }
241
+
242
+ reject(new Error(`Shared memory async call failed: ${err.message}`));
243
+ }
244
+ });
245
+ }
246
+
247
+ async destroy(): Promise<void> {
248
+ // Kill the bb process
249
+ // Background thread and callbacks will be cleaned up by OS on process exit
250
+ this.process.kill('SIGTERM');
251
+ this.process.removeAllListeners();
252
+
253
+ // Close log file if open
254
+ if (this.logFd !== undefined) {
255
+ try {
256
+ closeSync(this.logFd);
257
+ } catch (e) {
258
+ // Ignore errors during cleanup
259
+ }
260
+ }
261
+ }
262
+ }