@aztec/bb.js 3.0.0-devnet.2 → 3.0.0-devnet.2-patch.1
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.
- package/build/amd64-linux/bb +0 -0
- package/build/amd64-linux/nodejs_module.node +0 -0
- package/build/amd64-macos/bb +0 -0
- package/build/amd64-macos/nodejs_module.node +0 -0
- package/build/arm64-linux/bb +0 -0
- package/build/arm64-linux/nodejs_module.node +0 -0
- package/build/arm64-macos/bb +0 -0
- package/build/arm64-macos/nodejs_module.node +0 -0
- package/dest/browser/async_map/index.d.ts +1 -1
- package/dest/browser/async_map/index.js +1 -1
- package/dest/browser/barretenberg/backend.d.ts +30 -39
- package/dest/browser/barretenberg/backend.d.ts.map +1 -1
- package/dest/browser/barretenberg/backend.js +103 -98
- package/dest/browser/barretenberg/index.d.ts +4 -6
- package/dest/browser/barretenberg/index.d.ts.map +1 -1
- package/dest/browser/barretenberg/index.js +20 -29
- package/dest/browser/barretenberg/testing/bigint-buffer.d.ts +17 -0
- package/dest/browser/barretenberg/testing/bigint-buffer.d.ts.map +1 -0
- package/dest/browser/barretenberg/testing/bigint-buffer.js +37 -0
- package/dest/browser/barretenberg/testing/fields.d.ts +16 -0
- package/dest/browser/barretenberg/testing/fields.d.ts.map +1 -0
- package/dest/browser/barretenberg/testing/fields.js +47 -0
- package/dest/browser/barretenberg_wasm/barretenberg_wasm_base/index.d.ts +1 -1
- package/dest/browser/barretenberg_wasm/barretenberg_wasm_base/index.d.ts.map +1 -1
- package/dest/browser/barretenberg_wasm/barretenberg_wasm_base/index.js +5 -6
- package/dest/browser/barretenberg_wasm/barretenberg_wasm_main/factory/browser/index.d.ts +1 -1
- package/dest/browser/barretenberg_wasm/barretenberg_wasm_main/factory/browser/index.d.ts.map +1 -1
- package/dest/browser/barretenberg_wasm/barretenberg_wasm_main/factory/browser/index.js +1 -3
- package/dest/browser/barretenberg_wasm/barretenberg_wasm_main/factory/browser/main.worker.d.ts +1 -1
- package/dest/browser/barretenberg_wasm/barretenberg_wasm_main/factory/browser/main.worker.js +1 -7
- package/dest/browser/barretenberg_wasm/barretenberg_wasm_main/heap_allocator.d.ts +1 -1
- package/dest/browser/barretenberg_wasm/barretenberg_wasm_main/heap_allocator.d.ts.map +1 -1
- package/dest/browser/barretenberg_wasm/barretenberg_wasm_main/heap_allocator.js +5 -4
- package/dest/browser/barretenberg_wasm/barretenberg_wasm_main/index.d.ts +13 -7
- package/dest/browser/barretenberg_wasm/barretenberg_wasm_main/index.d.ts.map +1 -1
- package/dest/browser/barretenberg_wasm/barretenberg_wasm_main/index.js +45 -18
- package/dest/browser/barretenberg_wasm/barretenberg_wasm_thread/factory/browser/index.d.ts +1 -1
- package/dest/browser/barretenberg_wasm/barretenberg_wasm_thread/factory/browser/index.d.ts.map +1 -1
- package/dest/browser/barretenberg_wasm/barretenberg_wasm_thread/factory/browser/index.js +1 -3
- package/dest/browser/barretenberg_wasm/barretenberg_wasm_thread/factory/browser/thread.worker.d.ts +1 -1
- package/dest/browser/barretenberg_wasm/barretenberg_wasm_thread/factory/browser/thread.worker.js +1 -7
- package/dest/browser/barretenberg_wasm/barretenberg_wasm_thread/index.d.ts +9 -8
- package/dest/browser/barretenberg_wasm/barretenberg_wasm_thread/index.d.ts.map +1 -1
- package/dest/browser/barretenberg_wasm/barretenberg_wasm_thread/index.js +4 -3
- package/dest/browser/barretenberg_wasm/fetch_code/browser/barretenberg-threads.d.ts +1 -1
- package/dest/browser/barretenberg_wasm/fetch_code/browser/barretenberg-threads.js +1 -1
- package/dest/browser/barretenberg_wasm/fetch_code/browser/barretenberg.d.ts +1 -1
- package/dest/browser/barretenberg_wasm/fetch_code/browser/barretenberg.js +1 -1
- package/dest/browser/barretenberg_wasm/fetch_code/browser/index.d.ts +1 -1
- package/dest/browser/barretenberg_wasm/fetch_code/browser/index.js +1 -1
- package/dest/browser/barretenberg_wasm/fetch_code/index.d.ts +1 -1
- package/dest/browser/barretenberg_wasm/helpers/browser/index.d.ts +2 -2
- package/dest/browser/barretenberg_wasm/helpers/browser/index.d.ts.map +1 -1
- package/dest/browser/barretenberg_wasm/helpers/browser/index.js +9 -2
- package/dest/browser/barretenberg_wasm/helpers/index.d.ts +1 -1
- package/dest/browser/barretenberg_wasm/index.d.ts +1 -1
- package/dest/browser/barretenberg_wasm/index.d.ts.map +1 -1
- package/dest/browser/barretenberg_wasm/index.js +2 -3
- package/dest/browser/bb_backends/browser/index.d.ts +1 -1
- package/dest/browser/bb_backends/browser/index.js +1 -1
- package/dest/browser/bb_backends/browser/platform.d.ts +4 -0
- package/dest/browser/bb_backends/browser/platform.d.ts.map +1 -0
- package/dest/browser/bb_backends/browser/platform.js +10 -0
- package/dest/browser/bb_backends/index.d.ts +12 -7
- package/dest/browser/bb_backends/index.d.ts.map +1 -1
- package/dest/browser/bb_backends/index.js +8 -7
- package/dest/browser/bb_backends/interface.d.ts +1 -1
- package/dest/browser/bb_backends/wasm.d.ts +1 -1
- package/dest/browser/bb_backends/wasm.d.ts.map +1 -1
- package/dest/browser/bb_backends/wasm.js +5 -3
- package/dest/browser/bbapi_exception.d.ts +7 -0
- package/dest/browser/bbapi_exception.d.ts.map +1 -0
- package/dest/browser/bbapi_exception.js +14 -0
- package/dest/browser/bin/index.d.ts +3 -0
- package/dest/browser/bin/index.d.ts.map +1 -0
- package/dest/browser/bin/index.js +11 -0
- package/dest/browser/cbind/generate.d.ts +1 -1
- package/dest/browser/cbind/generate.js +93 -1
- package/dest/browser/cbind/generated/api_types.d.ts +632 -400
- package/dest/browser/cbind/generated/api_types.d.ts.map +1 -1
- package/dest/browser/cbind/generated/api_types.js +773 -465
- package/dest/browser/cbind/generated/async.d.ts +16 -11
- package/dest/browser/cbind/generated/async.d.ts.map +1 -1
- package/dest/browser/cbind/generated/async.js +305 -96
- package/dest/browser/cbind/generated/curve_constants.d.ts +45 -0
- package/dest/browser/cbind/generated/curve_constants.d.ts.map +1 -0
- package/dest/browser/cbind/generated/curve_constants.js +45 -0
- package/dest/browser/cbind/generated/sync.d.ts +16 -11
- package/dest/browser/cbind/generated/sync.d.ts.map +1 -1
- package/dest/browser/cbind/generated/sync.js +300 -96
- package/dest/browser/cbind/schema_compiler.d.ts +1 -1
- package/dest/browser/cbind/schema_compiler.d.ts.map +1 -1
- package/dest/browser/cbind/schema_compiler.js +29 -8
- package/dest/browser/crs/browser/cached_net_crs.d.ts +1 -1
- package/dest/browser/crs/browser/cached_net_crs.d.ts.map +1 -1
- package/dest/browser/crs/browser/cached_net_crs.js +6 -1
- package/dest/browser/crs/browser/index.d.ts +1 -1
- package/dest/browser/crs/index.d.ts +1 -1
- package/dest/browser/crs/net_crs.d.ts +1 -16
- package/dest/browser/crs/net_crs.d.ts.map +1 -1
- package/dest/browser/crs/net_crs.js +6 -1
- package/dest/browser/index.d.ts +6 -3
- package/dest/browser/index.d.ts.map +1 -1
- package/dest/browser/index.js +5 -2
- package/dest/browser/proof/index.d.ts +1 -1
- package/dest/browser/proof/index.js +1 -1
- package/dest/browser/random/browser/index.d.ts +1 -1
- package/dest/browser/random/browser/index.d.ts.map +1 -1
- package/dest/browser/random/browser/index.js +1 -1
- package/dest/browser/random/index.d.ts +1 -1
- package/dest/browser/retry/index.d.ts +1 -1
- package/dest/browser/retry/index.js +1 -1
- package/dest/node/async_map/index.d.ts +1 -1
- package/dest/node/async_map/index.js +1 -1
- package/dest/node/barretenberg/backend.d.ts +30 -39
- package/dest/node/barretenberg/backend.d.ts.map +1 -1
- package/dest/node/barretenberg/backend.js +103 -98
- package/dest/node/barretenberg/blake2s.test.d.ts +1 -1
- package/dest/node/barretenberg/blake2s.test.js +2 -2
- package/dest/node/barretenberg/index.d.ts +4 -6
- package/dest/node/barretenberg/index.d.ts.map +1 -1
- package/dest/node/barretenberg/index.js +20 -29
- package/dest/node/barretenberg/pedersen.test.d.ts +1 -1
- package/dest/node/barretenberg/pedersen.test.js +2 -2
- package/dest/node/barretenberg/poseidon.bench.test.d.ts +1 -1
- package/dest/node/barretenberg/poseidon.bench.test.js +81 -79
- package/dest/node/barretenberg/poseidon.test.d.ts +1 -1
- package/dest/node/barretenberg/poseidon.test.js +2 -2
- package/dest/node/barretenberg/testing/bigint-buffer.d.ts +17 -0
- package/dest/node/barretenberg/testing/bigint-buffer.d.ts.map +1 -0
- package/dest/node/barretenberg/testing/bigint-buffer.js +37 -0
- package/dest/node/barretenberg/testing/fields.d.ts +16 -0
- package/dest/node/barretenberg/testing/fields.d.ts.map +1 -0
- package/dest/node/barretenberg/testing/fields.js +47 -0
- package/dest/node/barretenberg_wasm/barretenberg-threads.wasm.gz +0 -0
- package/dest/node/barretenberg_wasm/barretenberg_wasm_base/index.d.ts +1 -1
- package/dest/node/barretenberg_wasm/barretenberg_wasm_base/index.d.ts.map +1 -1
- package/dest/node/barretenberg_wasm/barretenberg_wasm_base/index.js +5 -6
- package/dest/node/barretenberg_wasm/barretenberg_wasm_main/factory/browser/index.d.ts +1 -1
- package/dest/node/barretenberg_wasm/barretenberg_wasm_main/factory/browser/index.d.ts.map +1 -1
- package/dest/node/barretenberg_wasm/barretenberg_wasm_main/factory/browser/index.js +1 -3
- package/dest/node/barretenberg_wasm/barretenberg_wasm_main/factory/browser/main.worker.d.ts +1 -1
- package/dest/node/barretenberg_wasm/barretenberg_wasm_main/factory/browser/main.worker.js +1 -7
- package/dest/node/barretenberg_wasm/barretenberg_wasm_main/factory/node/index.d.ts +1 -1
- package/dest/node/barretenberg_wasm/barretenberg_wasm_main/factory/node/index.d.ts.map +1 -1
- package/dest/node/barretenberg_wasm/barretenberg_wasm_main/factory/node/index.js +1 -3
- package/dest/node/barretenberg_wasm/barretenberg_wasm_main/factory/node/main.worker.d.ts +1 -1
- package/dest/node/barretenberg_wasm/barretenberg_wasm_main/factory/node/main.worker.js +1 -8
- package/dest/node/barretenberg_wasm/barretenberg_wasm_main/heap_allocator.d.ts +1 -1
- package/dest/node/barretenberg_wasm/barretenberg_wasm_main/heap_allocator.d.ts.map +1 -1
- package/dest/node/barretenberg_wasm/barretenberg_wasm_main/heap_allocator.js +5 -4
- package/dest/node/barretenberg_wasm/barretenberg_wasm_main/index.d.ts +13 -7
- package/dest/node/barretenberg_wasm/barretenberg_wasm_main/index.d.ts.map +1 -1
- package/dest/node/barretenberg_wasm/barretenberg_wasm_main/index.js +45 -18
- package/dest/node/barretenberg_wasm/barretenberg_wasm_thread/factory/browser/index.d.ts +1 -1
- package/dest/node/barretenberg_wasm/barretenberg_wasm_thread/factory/browser/index.d.ts.map +1 -1
- package/dest/node/barretenberg_wasm/barretenberg_wasm_thread/factory/browser/index.js +1 -3
- package/dest/node/barretenberg_wasm/barretenberg_wasm_thread/factory/browser/thread.worker.d.ts +1 -1
- package/dest/node/barretenberg_wasm/barretenberg_wasm_thread/factory/browser/thread.worker.js +1 -7
- package/dest/node/barretenberg_wasm/barretenberg_wasm_thread/factory/node/index.d.ts +1 -1
- package/dest/node/barretenberg_wasm/barretenberg_wasm_thread/factory/node/index.d.ts.map +1 -1
- package/dest/node/barretenberg_wasm/barretenberg_wasm_thread/factory/node/index.js +1 -3
- package/dest/node/barretenberg_wasm/barretenberg_wasm_thread/factory/node/thread.worker.d.ts +1 -1
- package/dest/node/barretenberg_wasm/barretenberg_wasm_thread/factory/node/thread.worker.js +1 -7
- package/dest/node/barretenberg_wasm/barretenberg_wasm_thread/index.d.ts +9 -8
- package/dest/node/barretenberg_wasm/barretenberg_wasm_thread/index.d.ts.map +1 -1
- package/dest/node/barretenberg_wasm/barretenberg_wasm_thread/index.js +4 -3
- package/dest/node/barretenberg_wasm/fetch_code/browser/barretenberg-threads.d.ts +1 -1
- package/dest/node/barretenberg_wasm/fetch_code/browser/barretenberg.d.ts +1 -1
- package/dest/node/barretenberg_wasm/fetch_code/browser/index.d.ts +1 -1
- package/dest/node/barretenberg_wasm/fetch_code/browser/index.js +1 -1
- package/dest/node/barretenberg_wasm/fetch_code/index.d.ts +1 -1
- package/dest/node/barretenberg_wasm/fetch_code/node/index.d.ts +1 -1
- package/dest/node/barretenberg_wasm/fetch_code/node/index.js +1 -1
- package/dest/node/barretenberg_wasm/helpers/browser/index.d.ts +2 -2
- package/dest/node/barretenberg_wasm/helpers/browser/index.d.ts.map +1 -1
- package/dest/node/barretenberg_wasm/helpers/browser/index.js +9 -2
- package/dest/node/barretenberg_wasm/helpers/index.d.ts +1 -1
- package/dest/node/barretenberg_wasm/helpers/node/index.d.ts +5 -6
- package/dest/node/barretenberg_wasm/helpers/node/index.d.ts.map +1 -1
- package/dest/node/barretenberg_wasm/helpers/node/index.js +14 -6
- package/dest/node/barretenberg_wasm/helpers/node/node_endpoint.d.ts +2 -2
- package/dest/node/barretenberg_wasm/helpers/node/node_endpoint.d.ts.map +1 -1
- package/dest/node/barretenberg_wasm/helpers/node/node_endpoint.js +1 -1
- package/dest/node/barretenberg_wasm/index.d.ts +1 -1
- package/dest/node/barretenberg_wasm/index.d.ts.map +1 -1
- package/dest/node/barretenberg_wasm/index.js +2 -3
- package/dest/node/barretenberg_wasm/index.test.d.ts +1 -1
- package/dest/node/barretenberg_wasm/index.test.js +1 -1
- package/dest/node/bb_backends/browser/index.d.ts +1 -1
- package/dest/node/bb_backends/browser/index.js +1 -1
- package/dest/node/bb_backends/browser/platform.d.ts +4 -0
- package/dest/node/bb_backends/browser/platform.d.ts.map +1 -0
- package/dest/node/bb_backends/browser/platform.js +10 -0
- package/dest/node/bb_backends/index.d.ts +12 -7
- package/dest/node/bb_backends/index.d.ts.map +1 -1
- package/dest/node/bb_backends/index.js +8 -7
- package/dest/node/bb_backends/interface.d.ts +1 -1
- package/dest/node/bb_backends/node/index.d.ts +1 -1
- package/dest/node/bb_backends/node/index.d.ts.map +1 -1
- package/dest/node/bb_backends/node/index.js +17 -11
- package/dest/node/bb_backends/node/native_pipe.d.ts +1 -1
- package/dest/node/bb_backends/node/native_pipe.d.ts.map +1 -1
- package/dest/node/bb_backends/node/native_pipe.js +11 -10
- package/dest/node/bb_backends/node/native_shm.d.ts +3 -3
- package/dest/node/bb_backends/node/native_shm.d.ts.map +1 -1
- package/dest/node/bb_backends/node/native_shm.js +61 -39
- package/dest/node/bb_backends/node/native_shm_async.d.ts +51 -0
- package/dest/node/bb_backends/node/native_shm_async.d.ts.map +1 -0
- package/dest/node/bb_backends/node/native_shm_async.js +232 -0
- package/dest/node/bb_backends/node/native_socket.d.ts +2 -2
- package/dest/node/bb_backends/node/native_socket.d.ts.map +1 -1
- package/dest/node/bb_backends/node/native_socket.js +43 -31
- package/dest/node/bb_backends/node/platform.d.ts +1 -1
- package/dest/node/bb_backends/node/platform.d.ts.map +1 -1
- package/dest/node/bb_backends/node/platform.js +7 -2
- package/dest/node/bb_backends/wasm.d.ts +1 -1
- package/dest/node/bb_backends/wasm.d.ts.map +1 -1
- package/dest/node/bb_backends/wasm.js +5 -3
- package/dest/node/bbapi/exception_handling.test.d.ts +2 -0
- package/dest/node/bbapi/exception_handling.test.d.ts.map +1 -0
- package/dest/node/bbapi/exception_handling.test.js +48 -0
- package/dest/node/bbapi_exception.d.ts +7 -0
- package/dest/node/bbapi_exception.d.ts.map +1 -0
- package/dest/node/bbapi_exception.js +14 -0
- package/dest/node/benchmark/index.d.ts +1 -1
- package/dest/node/benchmark/index.js +1 -1
- package/dest/node/benchmark/timer.d.ts +1 -1
- package/dest/node/benchmark/timer.d.ts.map +1 -1
- package/dest/node/benchmark/timer.js +2 -1
- package/dest/node/bin/index.d.ts +3 -0
- package/dest/node/bin/index.d.ts.map +1 -0
- package/dest/node/bin/index.js +11 -0
- package/dest/node/cbind/generate.d.ts +1 -1
- package/dest/node/cbind/generate.js +93 -1
- package/dest/node/cbind/generated/api_types.d.ts +632 -400
- package/dest/node/cbind/generated/api_types.d.ts.map +1 -1
- package/dest/node/cbind/generated/api_types.js +773 -465
- package/dest/node/cbind/generated/async.d.ts +16 -11
- package/dest/node/cbind/generated/async.d.ts.map +1 -1
- package/dest/node/cbind/generated/async.js +305 -96
- package/dest/node/cbind/generated/curve_constants.d.ts +45 -0
- package/dest/node/cbind/generated/curve_constants.d.ts.map +1 -0
- package/dest/node/cbind/generated/curve_constants.js +45 -0
- package/dest/node/cbind/generated/sync.d.ts +16 -11
- package/dest/node/cbind/generated/sync.d.ts.map +1 -1
- package/dest/node/cbind/generated/sync.js +300 -96
- package/dest/node/cbind/schema_compiler.d.ts +1 -1
- package/dest/node/cbind/schema_compiler.d.ts.map +1 -1
- package/dest/node/cbind/schema_compiler.js +29 -8
- package/dest/node/crs/browser/cached_net_crs.d.ts +1 -1
- package/dest/node/crs/browser/cached_net_crs.d.ts.map +1 -1
- package/dest/node/crs/browser/cached_net_crs.js +6 -1
- package/dest/node/crs/browser/index.d.ts +1 -1
- package/dest/node/crs/index.d.ts +1 -1
- package/dest/node/crs/net_crs.d.ts +1 -16
- package/dest/node/crs/net_crs.d.ts.map +1 -1
- package/dest/node/crs/net_crs.js +6 -1
- package/dest/node/crs/node/index.d.ts +1 -1
- package/dest/node/crs/node/index.d.ts.map +1 -1
- package/dest/node/crs/node/index.js +11 -6
- package/dest/node/index.d.ts +6 -3
- package/dest/node/index.d.ts.map +1 -1
- package/dest/node/index.js +5 -2
- package/dest/node/proof/index.d.ts +1 -1
- package/dest/node/proof/index.js +1 -1
- package/dest/node/random/browser/index.d.ts +1 -1
- package/dest/node/random/browser/index.d.ts.map +1 -1
- package/dest/node/random/browser/index.js +1 -1
- package/dest/node/random/index.d.ts +1 -1
- package/dest/node/random/node/index.d.ts +1 -1
- package/dest/node/random/node/index.js +1 -1
- package/dest/node/retry/index.d.ts +1 -1
- package/dest/node/retry/index.js +1 -1
- package/dest/node-cjs/async_map/index.d.ts +1 -1
- package/dest/node-cjs/async_map/index.js +1 -1
- package/dest/node-cjs/barretenberg/backend.d.ts +30 -39
- package/dest/node-cjs/barretenberg/backend.d.ts.map +1 -1
- package/dest/node-cjs/barretenberg/backend.js +108 -103
- package/dest/node-cjs/barretenberg/blake2s.test.d.ts +1 -1
- package/dest/node-cjs/barretenberg/blake2s.test.js +6 -6
- package/dest/node-cjs/barretenberg/index.d.ts +4 -6
- package/dest/node-cjs/barretenberg/index.d.ts.map +1 -1
- package/dest/node-cjs/barretenberg/index.js +25 -34
- package/dest/node-cjs/barretenberg/pedersen.test.d.ts +1 -1
- package/dest/node-cjs/barretenberg/pedersen.test.js +9 -9
- package/dest/node-cjs/barretenberg/poseidon.bench.test.d.ts +1 -1
- package/dest/node-cjs/barretenberg/poseidon.bench.test.js +89 -87
- package/dest/node-cjs/barretenberg/poseidon.test.d.ts +1 -1
- package/dest/node-cjs/barretenberg/poseidon.test.js +4 -4
- package/dest/node-cjs/barretenberg/testing/bigint-buffer.d.ts +17 -0
- package/dest/node-cjs/barretenberg/testing/bigint-buffer.d.ts.map +1 -0
- package/dest/node-cjs/barretenberg/testing/bigint-buffer.js +43 -0
- package/dest/node-cjs/barretenberg/testing/fields.d.ts +16 -0
- package/dest/node-cjs/barretenberg/testing/fields.d.ts.map +1 -0
- package/dest/node-cjs/barretenberg/testing/fields.js +51 -0
- package/dest/node-cjs/barretenberg_wasm/barretenberg-threads.wasm.gz +0 -0
- package/dest/node-cjs/barretenberg_wasm/barretenberg_wasm_base/index.d.ts +1 -1
- package/dest/node-cjs/barretenberg_wasm/barretenberg_wasm_base/index.d.ts.map +1 -1
- package/dest/node-cjs/barretenberg_wasm/barretenberg_wasm_base/index.js +7 -8
- package/dest/node-cjs/barretenberg_wasm/barretenberg_wasm_main/factory/browser/index.d.ts +1 -1
- package/dest/node-cjs/barretenberg_wasm/barretenberg_wasm_main/factory/browser/index.d.ts.map +1 -1
- package/dest/node-cjs/barretenberg_wasm/barretenberg_wasm_main/factory/browser/index.js +3 -5
- package/dest/node-cjs/barretenberg_wasm/barretenberg_wasm_main/factory/browser/main.worker.d.ts +1 -1
- package/dest/node-cjs/barretenberg_wasm/barretenberg_wasm_main/factory/browser/main.worker.js +1 -7
- package/dest/node-cjs/barretenberg_wasm/barretenberg_wasm_main/factory/node/index.d.ts +1 -1
- package/dest/node-cjs/barretenberg_wasm/barretenberg_wasm_main/factory/node/index.d.ts.map +1 -1
- package/dest/node-cjs/barretenberg_wasm/barretenberg_wasm_main/factory/node/index.js +1 -3
- package/dest/node-cjs/barretenberg_wasm/barretenberg_wasm_main/factory/node/main.worker.d.ts +1 -1
- package/dest/node-cjs/barretenberg_wasm/barretenberg_wasm_main/factory/node/main.worker.js +1 -8
- package/dest/node-cjs/barretenberg_wasm/barretenberg_wasm_main/heap_allocator.d.ts +1 -1
- package/dest/node-cjs/barretenberg_wasm/barretenberg_wasm_main/heap_allocator.d.ts.map +1 -1
- package/dest/node-cjs/barretenberg_wasm/barretenberg_wasm_main/heap_allocator.js +5 -4
- package/dest/node-cjs/barretenberg_wasm/barretenberg_wasm_main/index.d.ts +13 -7
- package/dest/node-cjs/barretenberg_wasm/barretenberg_wasm_main/index.d.ts.map +1 -1
- package/dest/node-cjs/barretenberg_wasm/barretenberg_wasm_main/index.js +45 -18
- package/dest/node-cjs/barretenberg_wasm/barretenberg_wasm_thread/factory/browser/index.d.ts +1 -1
- package/dest/node-cjs/barretenberg_wasm/barretenberg_wasm_thread/factory/browser/index.d.ts.map +1 -1
- package/dest/node-cjs/barretenberg_wasm/barretenberg_wasm_thread/factory/browser/index.js +3 -5
- package/dest/node-cjs/barretenberg_wasm/barretenberg_wasm_thread/factory/browser/thread.worker.d.ts +1 -1
- package/dest/node-cjs/barretenberg_wasm/barretenberg_wasm_thread/factory/browser/thread.worker.js +1 -7
- package/dest/node-cjs/barretenberg_wasm/barretenberg_wasm_thread/factory/node/index.d.ts +1 -1
- package/dest/node-cjs/barretenberg_wasm/barretenberg_wasm_thread/factory/node/index.d.ts.map +1 -1
- package/dest/node-cjs/barretenberg_wasm/barretenberg_wasm_thread/factory/node/index.js +1 -3
- package/dest/node-cjs/barretenberg_wasm/barretenberg_wasm_thread/factory/node/thread.worker.d.ts +1 -1
- package/dest/node-cjs/barretenberg_wasm/barretenberg_wasm_thread/factory/node/thread.worker.js +1 -7
- package/dest/node-cjs/barretenberg_wasm/barretenberg_wasm_thread/index.d.ts +9 -8
- package/dest/node-cjs/barretenberg_wasm/barretenberg_wasm_thread/index.d.ts.map +1 -1
- package/dest/node-cjs/barretenberg_wasm/barretenberg_wasm_thread/index.js +4 -3
- package/dest/node-cjs/barretenberg_wasm/fetch_code/browser/barretenberg-threads.d.ts +1 -1
- package/dest/node-cjs/barretenberg_wasm/fetch_code/browser/barretenberg-threads.js +1 -1
- package/dest/node-cjs/barretenberg_wasm/fetch_code/browser/barretenberg.d.ts +1 -1
- package/dest/node-cjs/barretenberg_wasm/fetch_code/browser/barretenberg.js +1 -1
- package/dest/node-cjs/barretenberg_wasm/fetch_code/browser/index.d.ts +1 -1
- package/dest/node-cjs/barretenberg_wasm/fetch_code/browser/index.js +2 -2
- package/dest/node-cjs/barretenberg_wasm/fetch_code/index.d.ts +1 -1
- package/dest/node-cjs/barretenberg_wasm/fetch_code/node/index.d.ts +1 -1
- package/dest/node-cjs/barretenberg_wasm/fetch_code/node/index.js +2 -2
- package/dest/node-cjs/barretenberg_wasm/helpers/browser/index.d.ts +2 -2
- package/dest/node-cjs/barretenberg_wasm/helpers/browser/index.d.ts.map +1 -1
- package/dest/node-cjs/barretenberg_wasm/helpers/browser/index.js +9 -2
- package/dest/node-cjs/barretenberg_wasm/helpers/index.d.ts +1 -1
- package/dest/node-cjs/barretenberg_wasm/helpers/node/index.d.ts +5 -6
- package/dest/node-cjs/barretenberg_wasm/helpers/node/index.d.ts.map +1 -1
- package/dest/node-cjs/barretenberg_wasm/helpers/node/index.js +15 -7
- package/dest/node-cjs/barretenberg_wasm/helpers/node/node_endpoint.d.ts +2 -2
- package/dest/node-cjs/barretenberg_wasm/helpers/node/node_endpoint.d.ts.map +1 -1
- package/dest/node-cjs/barretenberg_wasm/helpers/node/node_endpoint.js +1 -1
- package/dest/node-cjs/barretenberg_wasm/index.d.ts +1 -1
- package/dest/node-cjs/barretenberg_wasm/index.d.ts.map +1 -1
- package/dest/node-cjs/barretenberg_wasm/index.js +2 -3
- package/dest/node-cjs/barretenberg_wasm/index.test.d.ts +1 -1
- package/dest/node-cjs/barretenberg_wasm/index.test.js +1 -1
- package/dest/node-cjs/bb_backends/browser/index.d.ts +1 -1
- package/dest/node-cjs/bb_backends/browser/index.js +1 -1
- package/dest/node-cjs/bb_backends/browser/platform.d.ts +4 -0
- package/dest/node-cjs/bb_backends/browser/platform.d.ts.map +1 -0
- package/dest/node-cjs/bb_backends/browser/platform.js +15 -0
- package/dest/node-cjs/bb_backends/index.d.ts +12 -7
- package/dest/node-cjs/bb_backends/index.d.ts.map +1 -1
- package/dest/node-cjs/bb_backends/index.js +6 -6
- package/dest/node-cjs/bb_backends/interface.d.ts +1 -1
- package/dest/node-cjs/bb_backends/node/index.d.ts +1 -1
- package/dest/node-cjs/bb_backends/node/index.d.ts.map +1 -1
- package/dest/node-cjs/bb_backends/node/index.js +17 -11
- package/dest/node-cjs/bb_backends/node/native_pipe.d.ts +1 -1
- package/dest/node-cjs/bb_backends/node/native_pipe.d.ts.map +1 -1
- package/dest/node-cjs/bb_backends/node/native_pipe.js +11 -10
- package/dest/node-cjs/bb_backends/node/native_shm.d.ts +3 -3
- package/dest/node-cjs/bb_backends/node/native_shm.d.ts.map +1 -1
- package/dest/node-cjs/bb_backends/node/native_shm.js +61 -39
- package/dest/node-cjs/bb_backends/node/native_shm_async.d.ts +51 -0
- package/dest/node-cjs/bb_backends/node/native_shm_async.d.ts.map +1 -0
- package/dest/node-cjs/bb_backends/node/native_shm_async.js +236 -0
- package/dest/node-cjs/bb_backends/node/native_socket.d.ts +2 -2
- package/dest/node-cjs/bb_backends/node/native_socket.d.ts.map +1 -1
- package/dest/node-cjs/bb_backends/node/native_socket.js +43 -31
- package/dest/node-cjs/bb_backends/node/platform.d.ts +1 -1
- package/dest/node-cjs/bb_backends/node/platform.d.ts.map +1 -1
- package/dest/node-cjs/bb_backends/node/platform.js +8 -3
- package/dest/node-cjs/bb_backends/wasm.d.ts +1 -1
- package/dest/node-cjs/bb_backends/wasm.d.ts.map +1 -1
- package/dest/node-cjs/bb_backends/wasm.js +5 -3
- package/dest/node-cjs/bbapi/exception_handling.test.d.ts +2 -0
- package/dest/node-cjs/bbapi/exception_handling.test.d.ts.map +1 -0
- package/dest/node-cjs/bbapi/exception_handling.test.js +50 -0
- package/dest/node-cjs/bbapi_exception.d.ts +7 -0
- package/dest/node-cjs/bbapi_exception.d.ts.map +1 -0
- package/dest/node-cjs/bbapi_exception.js +18 -0
- package/dest/node-cjs/benchmark/index.d.ts +1 -1
- package/dest/node-cjs/benchmark/index.js +2 -2
- package/dest/node-cjs/benchmark/timer.d.ts +1 -1
- package/dest/node-cjs/benchmark/timer.d.ts.map +1 -1
- package/dest/node-cjs/benchmark/timer.js +2 -1
- package/dest/node-cjs/bin/index.d.ts +3 -0
- package/dest/node-cjs/bin/index.d.ts.map +1 -0
- package/dest/node-cjs/bin/index.js +13 -0
- package/dest/node-cjs/cbind/generate.d.ts +1 -1
- package/dest/node-cjs/cbind/generate.js +93 -1
- package/dest/node-cjs/cbind/generated/api_types.d.ts +632 -400
- package/dest/node-cjs/cbind/generated/api_types.d.ts.map +1 -1
- package/dest/node-cjs/cbind/generated/api_types.js +843 -507
- package/dest/node-cjs/cbind/generated/async.d.ts +16 -11
- package/dest/node-cjs/cbind/generated/async.d.ts.map +1 -1
- package/dest/node-cjs/cbind/generated/async.js +304 -95
- package/dest/node-cjs/cbind/generated/curve_constants.d.ts +45 -0
- package/dest/node-cjs/cbind/generated/curve_constants.d.ts.map +1 -0
- package/dest/node-cjs/cbind/generated/curve_constants.js +48 -0
- package/dest/node-cjs/cbind/generated/sync.d.ts +16 -11
- package/dest/node-cjs/cbind/generated/sync.d.ts.map +1 -1
- package/dest/node-cjs/cbind/generated/sync.js +299 -95
- package/dest/node-cjs/cbind/schema_compiler.d.ts +1 -1
- package/dest/node-cjs/cbind/schema_compiler.d.ts.map +1 -1
- package/dest/node-cjs/cbind/schema_compiler.js +29 -8
- package/dest/node-cjs/crs/browser/cached_net_crs.d.ts +1 -1
- package/dest/node-cjs/crs/browser/cached_net_crs.d.ts.map +1 -1
- package/dest/node-cjs/crs/browser/cached_net_crs.js +6 -1
- package/dest/node-cjs/crs/browser/index.d.ts +1 -1
- package/dest/node-cjs/crs/browser/index.js +2 -2
- package/dest/node-cjs/crs/index.d.ts +1 -1
- package/dest/node-cjs/crs/index.js +2 -2
- package/dest/node-cjs/crs/net_crs.d.ts +1 -16
- package/dest/node-cjs/crs/net_crs.d.ts.map +1 -1
- package/dest/node-cjs/crs/net_crs.js +6 -1
- package/dest/node-cjs/crs/node/index.d.ts +1 -1
- package/dest/node-cjs/crs/node/index.d.ts.map +1 -1
- package/dest/node-cjs/crs/node/index.js +11 -6
- package/dest/node-cjs/index.d.ts +6 -3
- package/dest/node-cjs/index.d.ts.map +1 -1
- package/dest/node-cjs/index.js +28 -11
- package/dest/node-cjs/proof/index.d.ts +1 -1
- package/dest/node-cjs/proof/index.js +1 -1
- package/dest/node-cjs/random/browser/index.d.ts +1 -1
- package/dest/node-cjs/random/browser/index.d.ts.map +1 -1
- package/dest/node-cjs/random/browser/index.js +1 -1
- package/dest/node-cjs/random/index.d.ts +1 -1
- package/dest/node-cjs/random/node/index.d.ts +1 -1
- package/dest/node-cjs/random/node/index.js +1 -1
- package/dest/node-cjs/retry/index.d.ts +1 -1
- package/dest/node-cjs/retry/index.js +1 -1
- package/package.json +8 -6
- package/src/barretenberg/backend.ts +125 -126
- package/src/barretenberg/blake2s.test.ts +1 -1
- package/src/barretenberg/index.ts +24 -29
- package/src/barretenberg/pedersen.test.ts +1 -1
- package/src/barretenberg/poseidon.bench.test.ts +161 -157
- package/src/barretenberg/poseidon.test.ts +1 -1
- package/src/barretenberg/testing/fields.ts +63 -0
- package/src/barretenberg_wasm/barretenberg_wasm_base/index.ts +1 -2
- package/src/barretenberg_wasm/barretenberg_wasm_main/factory/browser/index.ts +0 -2
- package/src/barretenberg_wasm/barretenberg_wasm_main/factory/browser/main.worker.ts +0 -7
- package/src/barretenberg_wasm/barretenberg_wasm_main/factory/node/index.ts +0 -2
- package/src/barretenberg_wasm/barretenberg_wasm_main/factory/node/main.worker.ts +0 -9
- package/src/barretenberg_wasm/barretenberg_wasm_main/heap_allocator.ts +4 -4
- package/src/barretenberg_wasm/barretenberg_wasm_main/index.ts +37 -4
- package/src/barretenberg_wasm/barretenberg_wasm_thread/factory/browser/index.ts +0 -2
- package/src/barretenberg_wasm/barretenberg_wasm_thread/factory/browser/thread.worker.ts +0 -7
- package/src/barretenberg_wasm/barretenberg_wasm_thread/factory/node/index.ts +0 -2
- package/src/barretenberg_wasm/barretenberg_wasm_thread/factory/node/thread.worker.ts +0 -7
- package/src/barretenberg_wasm/barretenberg_wasm_thread/index.ts +3 -2
- package/src/barretenberg_wasm/helpers/browser/index.ts +8 -1
- package/src/barretenberg_wasm/helpers/node/index.ts +13 -6
- package/src/barretenberg_wasm/index.ts +1 -2
- package/src/bb_backends/browser/platform.ts +11 -0
- package/src/bb_backends/index.ts +12 -6
- package/src/bb_backends/node/index.ts +23 -10
- package/src/bb_backends/node/native_shm.ts +59 -40
- package/src/bb_backends/node/native_shm_async.ts +261 -0
- package/src/bb_backends/node/native_socket.ts +31 -18
- package/src/bb_backends/node/platform.ts +6 -1
- package/src/bb_backends/wasm.ts +1 -2
- package/src/bbapi/exception_handling.test.ts +54 -0
- package/src/bbapi_exception.ts +13 -0
- package/src/bin/index.ts +14 -0
- package/src/cbind/generate.ts +99 -0
- package/src/cbind/generated/api_types.ts +1267 -783
- package/src/cbind/generated/async.ts +308 -95
- package/src/cbind/generated/curve_constants.ts +53 -0
- package/src/cbind/generated/sync.ts +303 -95
- package/src/cbind/schema_compiler.ts +25 -3
- package/src/crs/node/index.ts +4 -5
- package/src/index.ts +32 -1
- package/dest/browser/bb_backends/sync_to_async_adapter.d.ts +0 -15
- package/dest/browser/bb_backends/sync_to_async_adapter.d.ts.map +0 -1
- package/dest/browser/bb_backends/sync_to_async_adapter.js +0 -20
- package/dest/browser/bigint-array/index.d.ts +0 -17
- package/dest/browser/bigint-array/index.d.ts.map +0 -1
- package/dest/browser/bigint-array/index.js +0 -37
- package/dest/browser/log/browser/index.d.ts +0 -6
- package/dest/browser/log/browser/index.d.ts.map +0 -1
- package/dest/browser/log/browser/index.js +0 -28
- package/dest/browser/log/index.d.ts +0 -2
- package/dest/browser/log/index.d.ts.map +0 -1
- package/dest/browser/log/index.js +0 -2
- package/dest/browser/log/types.d.ts +0 -6
- package/dest/browser/log/types.d.ts.map +0 -1
- package/dest/browser/log/types.js +0 -2
- package/dest/browser/serialize/buffer_reader.d.ts +0 -28
- package/dest/browser/serialize/buffer_reader.d.ts.map +0 -1
- package/dest/browser/serialize/buffer_reader.js +0 -66
- package/dest/browser/serialize/index.d.ts +0 -3
- package/dest/browser/serialize/index.d.ts.map +0 -1
- package/dest/browser/serialize/index.js +0 -3
- package/dest/browser/serialize/serialize.d.ts +0 -18
- package/dest/browser/serialize/serialize.d.ts.map +0 -1
- package/dest/browser/serialize/serialize.js +0 -72
- package/dest/browser/types/fields.d.ts +0 -43
- package/dest/browser/types/fields.d.ts.map +0 -1
- package/dest/browser/types/fields.js +0 -102
- package/dest/browser/types/index.d.ts +0 -3
- package/dest/browser/types/index.d.ts.map +0 -1
- package/dest/browser/types/index.js +0 -3
- package/dest/browser/types/point.d.ts +0 -16
- package/dest/browser/types/point.d.ts.map +0 -1
- package/dest/browser/types/point.js +0 -31
- package/dest/node/bb_backends/sync_to_async_adapter.d.ts +0 -15
- package/dest/node/bb_backends/sync_to_async_adapter.d.ts.map +0 -1
- package/dest/node/bb_backends/sync_to_async_adapter.js +0 -20
- package/dest/node/bigint-array/index.d.ts +0 -17
- package/dest/node/bigint-array/index.d.ts.map +0 -1
- package/dest/node/bigint-array/index.js +0 -37
- package/dest/node/log/browser/index.d.ts +0 -6
- package/dest/node/log/browser/index.d.ts.map +0 -1
- package/dest/node/log/browser/index.js +0 -28
- package/dest/node/log/index.d.ts +0 -2
- package/dest/node/log/index.d.ts.map +0 -1
- package/dest/node/log/index.js +0 -2
- package/dest/node/log/node/index.d.ts +0 -6
- package/dest/node/log/node/index.d.ts.map +0 -1
- package/dest/node/log/node/index.js +0 -40
- package/dest/node/log/types.d.ts +0 -6
- package/dest/node/log/types.d.ts.map +0 -1
- package/dest/node/log/types.js +0 -2
- package/dest/node/serialize/buffer_reader.d.ts +0 -28
- package/dest/node/serialize/buffer_reader.d.ts.map +0 -1
- package/dest/node/serialize/buffer_reader.js +0 -66
- package/dest/node/serialize/index.d.ts +0 -3
- package/dest/node/serialize/index.d.ts.map +0 -1
- package/dest/node/serialize/index.js +0 -3
- package/dest/node/serialize/serialize.d.ts +0 -18
- package/dest/node/serialize/serialize.d.ts.map +0 -1
- package/dest/node/serialize/serialize.js +0 -72
- package/dest/node/types/fields.d.ts +0 -43
- package/dest/node/types/fields.d.ts.map +0 -1
- package/dest/node/types/fields.js +0 -102
- package/dest/node/types/index.d.ts +0 -3
- package/dest/node/types/index.d.ts.map +0 -1
- package/dest/node/types/index.js +0 -3
- package/dest/node/types/point.d.ts +0 -16
- package/dest/node/types/point.d.ts.map +0 -1
- package/dest/node/types/point.js +0 -31
- package/dest/node-cjs/bb_backends/sync_to_async_adapter.d.ts +0 -15
- package/dest/node-cjs/bb_backends/sync_to_async_adapter.d.ts.map +0 -1
- package/dest/node-cjs/bb_backends/sync_to_async_adapter.js +0 -24
- package/dest/node-cjs/bigint-array/index.d.ts +0 -17
- package/dest/node-cjs/bigint-array/index.d.ts.map +0 -1
- package/dest/node-cjs/bigint-array/index.js +0 -43
- package/dest/node-cjs/log/browser/index.d.ts +0 -6
- package/dest/node-cjs/log/browser/index.d.ts.map +0 -1
- package/dest/node-cjs/log/browser/index.js +0 -30
- package/dest/node-cjs/log/index.d.ts +0 -2
- package/dest/node-cjs/log/index.d.ts.map +0 -1
- package/dest/node-cjs/log/index.js +0 -8
- package/dest/node-cjs/log/node/index.d.ts +0 -6
- package/dest/node-cjs/log/node/index.d.ts.map +0 -1
- package/dest/node-cjs/log/node/index.js +0 -42
- package/dest/node-cjs/log/types.d.ts +0 -6
- package/dest/node-cjs/log/types.d.ts.map +0 -1
- package/dest/node-cjs/log/types.js +0 -3
- package/dest/node-cjs/serialize/buffer_reader.d.ts +0 -28
- package/dest/node-cjs/serialize/buffer_reader.d.ts.map +0 -1
- package/dest/node-cjs/serialize/buffer_reader.js +0 -70
- package/dest/node-cjs/serialize/index.d.ts +0 -3
- package/dest/node-cjs/serialize/index.d.ts.map +0 -1
- package/dest/node-cjs/serialize/index.js +0 -6
- package/dest/node-cjs/serialize/serialize.d.ts +0 -18
- package/dest/node-cjs/serialize/serialize.d.ts.map +0 -1
- package/dest/node-cjs/serialize/serialize.js +0 -82
- package/dest/node-cjs/types/fields.d.ts +0 -43
- package/dest/node-cjs/types/fields.d.ts.map +0 -1
- package/dest/node-cjs/types/fields.js +0 -107
- package/dest/node-cjs/types/index.d.ts +0 -3
- package/dest/node-cjs/types/index.d.ts.map +0 -1
- package/dest/node-cjs/types/index.js +0 -6
- package/dest/node-cjs/types/point.d.ts +0 -16
- package/dest/node-cjs/types/point.d.ts.map +0 -1
- package/dest/node-cjs/types/point.js +0 -35
- package/src/bb_backends/sync_to_async_adapter.ts +0 -21
- package/src/log/browser/index.ts +0 -35
- package/src/log/index.ts +0 -1
- package/src/log/node/index.ts +0 -52
- package/src/log/types.ts +0 -6
- package/src/serialize/buffer_reader.ts +0 -85
- package/src/serialize/index.ts +0 -2
- package/src/serialize/serialize.ts +0 -75
- package/src/types/fields.ts +0 -126
- package/src/types/index.ts +0 -2
- package/src/types/point.ts +0 -38
- /package/src/{bigint-array/index.ts → barretenberg/testing/bigint-buffer.ts} +0 -0
|
@@ -0,0 +1,261 @@
|
|
|
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
|
+
|
|
7
|
+
let instanceCounter = 0;
|
|
8
|
+
|
|
9
|
+
/**
|
|
10
|
+
* Asynchronous shared memory backend that communicates with bb binary via shared memory.
|
|
11
|
+
* Uses NAPI module with background thread polling for async operations.
|
|
12
|
+
* Supports request pipelining - multiple requests can be in flight simultaneously.
|
|
13
|
+
*
|
|
14
|
+
* Architecture (matches socket backend pattern):
|
|
15
|
+
* - bb acts as the SERVER, TypeScript is the CLIENT
|
|
16
|
+
* - bb creates the shared memory region
|
|
17
|
+
* - TypeScript connects via NAPI wrapper (MsgpackClientAsync)
|
|
18
|
+
* - TypeScript manages promise queue (single-threaded, no mutex needed)
|
|
19
|
+
* - C++ background thread polls for responses, calls JavaScript callback
|
|
20
|
+
* - JavaScript callback pops queue and resolves promises in FIFO order
|
|
21
|
+
*/
|
|
22
|
+
export class BarretenbergNativeShmAsyncBackend implements IMsgpackBackendAsync {
|
|
23
|
+
private process: ChildProcess;
|
|
24
|
+
private client: any; // NAPI MsgpackClientAsync instance
|
|
25
|
+
private logFd?: number; // File descriptor for logs
|
|
26
|
+
|
|
27
|
+
// Queue of pending callbacks for pipelined requests
|
|
28
|
+
// Responses come back in FIFO order, so we match them with queued callbacks
|
|
29
|
+
private pendingCallbacks: Array<{
|
|
30
|
+
resolve: (data: Uint8Array) => void;
|
|
31
|
+
reject: (error: Error) => void;
|
|
32
|
+
}> = [];
|
|
33
|
+
|
|
34
|
+
private constructor(process: ChildProcess, client: any, logFd?: number) {
|
|
35
|
+
this.process = process;
|
|
36
|
+
this.client = client;
|
|
37
|
+
this.logFd = logFd;
|
|
38
|
+
|
|
39
|
+
// Register our response handler with the C++ client
|
|
40
|
+
// This callback will be invoked from the background thread via ThreadSafeFunction
|
|
41
|
+
this.client.setResponseCallback((responseBuffer: Buffer) => {
|
|
42
|
+
this.handleResponse(responseBuffer);
|
|
43
|
+
});
|
|
44
|
+
}
|
|
45
|
+
|
|
46
|
+
/**
|
|
47
|
+
* Handle response from C++ background thread
|
|
48
|
+
* Dequeues the next pending callback and resolves it (FIFO order)
|
|
49
|
+
*/
|
|
50
|
+
private handleResponse(responseBuffer: Buffer): void {
|
|
51
|
+
// Response is complete - dequeue the next pending callback (FIFO)
|
|
52
|
+
const callback = this.pendingCallbacks.shift();
|
|
53
|
+
if (callback) {
|
|
54
|
+
callback.resolve(new Uint8Array(responseBuffer));
|
|
55
|
+
} else {
|
|
56
|
+
// This shouldn't happen - response without a pending request
|
|
57
|
+
console.warn('Received response but no pending callback');
|
|
58
|
+
}
|
|
59
|
+
|
|
60
|
+
// If no more pending callbacks, release ref to allow process to exit
|
|
61
|
+
if (this.pendingCallbacks.length === 0) {
|
|
62
|
+
this.client.release();
|
|
63
|
+
}
|
|
64
|
+
}
|
|
65
|
+
|
|
66
|
+
/**
|
|
67
|
+
* Create and initialize an async shared memory backend.
|
|
68
|
+
* @param bbBinaryPath Path to bb binary
|
|
69
|
+
* @param threads Optional number of threads (defaults to min(32, num_cpus))
|
|
70
|
+
* @param logger Optional logger function for bb output
|
|
71
|
+
*/
|
|
72
|
+
static async new(
|
|
73
|
+
bbBinaryPath: string,
|
|
74
|
+
napiPath: string,
|
|
75
|
+
threads?: number,
|
|
76
|
+
logger?: (msg: string) => void,
|
|
77
|
+
): Promise<BarretenbergNativeShmAsyncBackend> {
|
|
78
|
+
// Import the NAPI module
|
|
79
|
+
// The addon is built to the nodejs_module directory
|
|
80
|
+
const addonPath = findNapiBinary(napiPath);
|
|
81
|
+
// Try loading
|
|
82
|
+
let addon: any = null;
|
|
83
|
+
try {
|
|
84
|
+
const require = createRequire(findPackageRoot()!);
|
|
85
|
+
addon = require(addonPath!);
|
|
86
|
+
} catch (err) {
|
|
87
|
+
// Addon not built yet or not available
|
|
88
|
+
throw new Error('Shared memory async NAPI not available.');
|
|
89
|
+
}
|
|
90
|
+
|
|
91
|
+
// Create a unique shared memory name
|
|
92
|
+
const shmName = `bb-async-${process.pid}-${instanceCounter++}`;
|
|
93
|
+
|
|
94
|
+
// If threads not set use num cpu cores, max 16 (same as socket backend)
|
|
95
|
+
const hwc = threads ? threads.toString() : '16';
|
|
96
|
+
const env = { ...process.env, HARDWARE_CONCURRENCY: hwc };
|
|
97
|
+
|
|
98
|
+
// Set up file logging if logger is provided
|
|
99
|
+
// Direct file redirection bypasses Node event loop - logs are written even if process hangs
|
|
100
|
+
let logFd: number | undefined;
|
|
101
|
+
let logPath: string | undefined;
|
|
102
|
+
if (logger) {
|
|
103
|
+
logPath = `/tmp/${shmName}.log`;
|
|
104
|
+
logFd = openSync(logPath, 'w');
|
|
105
|
+
logger(`BB process logs redirected to: ${logPath}`);
|
|
106
|
+
}
|
|
107
|
+
|
|
108
|
+
// Spawn bb process with shared memory mode
|
|
109
|
+
// Use larger ring buffers for async mode to support pipelining
|
|
110
|
+
const args = [
|
|
111
|
+
'msgpack',
|
|
112
|
+
'run',
|
|
113
|
+
'--input',
|
|
114
|
+
`${shmName}.shm`,
|
|
115
|
+
'--request-ring-size',
|
|
116
|
+
`${1024 * 1024 * 4}`,
|
|
117
|
+
'--response-ring-size',
|
|
118
|
+
`${1024 * 1024 * 4}`,
|
|
119
|
+
];
|
|
120
|
+
const bbProcess = spawn(bbBinaryPath, args, {
|
|
121
|
+
stdio: ['ignore', logFd ?? 'ignore', logFd ?? 'ignore'],
|
|
122
|
+
env,
|
|
123
|
+
});
|
|
124
|
+
|
|
125
|
+
// Disconnect from event loop so process can exit without waiting for bb
|
|
126
|
+
// The bb process has parent death monitoring (prctl on Linux, kqueue on macOS)
|
|
127
|
+
// so it will automatically exit when Node.js exits
|
|
128
|
+
bbProcess.unref();
|
|
129
|
+
|
|
130
|
+
// Track if process has exited
|
|
131
|
+
let processExited = false;
|
|
132
|
+
let exitError: Error | null = null;
|
|
133
|
+
|
|
134
|
+
bbProcess.on('error', err => {
|
|
135
|
+
processExited = true;
|
|
136
|
+
exitError = new Error(`Native backend process error: ${err.message}`);
|
|
137
|
+
});
|
|
138
|
+
|
|
139
|
+
bbProcess.on('exit', (code, signal) => {
|
|
140
|
+
processExited = true;
|
|
141
|
+
if (code !== null && code !== 0) {
|
|
142
|
+
exitError = new Error(`Native backend process exited with code ${code}`);
|
|
143
|
+
} else if (signal && signal !== 'SIGTERM') {
|
|
144
|
+
exitError = new Error(`Native backend process killed with signal ${signal}`);
|
|
145
|
+
}
|
|
146
|
+
});
|
|
147
|
+
|
|
148
|
+
// Wait for bb to create shared memory
|
|
149
|
+
// Retry connection every 100ms for up to 5 seconds (longer than sync for thread startup)
|
|
150
|
+
const retryInterval = 100; // ms
|
|
151
|
+
const timeout = 5000; // ms
|
|
152
|
+
const maxAttempts = Math.floor(timeout / retryInterval);
|
|
153
|
+
let client: any = null;
|
|
154
|
+
|
|
155
|
+
try {
|
|
156
|
+
for (let attempt = 0; attempt < maxAttempts; attempt++) {
|
|
157
|
+
// Check if bb process has exited before attempting connection
|
|
158
|
+
if (processExited) {
|
|
159
|
+
throw exitError || new Error('Native backend process exited unexpectedly during startup');
|
|
160
|
+
}
|
|
161
|
+
|
|
162
|
+
// Wait before attempting connection (except first attempt)
|
|
163
|
+
if (attempt > 0) {
|
|
164
|
+
await new Promise(resolve => setTimeout(resolve, retryInterval));
|
|
165
|
+
}
|
|
166
|
+
|
|
167
|
+
try {
|
|
168
|
+
// Create NAPI async client
|
|
169
|
+
client = new addon.MsgpackClientAsync(shmName);
|
|
170
|
+
break; // Success!
|
|
171
|
+
} catch (err: any) {
|
|
172
|
+
// Connection failed, will retry
|
|
173
|
+
if (attempt === maxAttempts - 1) {
|
|
174
|
+
// Last attempt failed - check one more time if process exited
|
|
175
|
+
if (processExited && exitError) {
|
|
176
|
+
throw exitError;
|
|
177
|
+
}
|
|
178
|
+
throw new Error(`Failed to connect to shared memory after ${timeout}ms: ${err.message}`);
|
|
179
|
+
}
|
|
180
|
+
}
|
|
181
|
+
}
|
|
182
|
+
|
|
183
|
+
if (!client) {
|
|
184
|
+
throw new Error('Failed to create client connection');
|
|
185
|
+
}
|
|
186
|
+
|
|
187
|
+
return new BarretenbergNativeShmAsyncBackend(bbProcess, client, logFd);
|
|
188
|
+
} finally {
|
|
189
|
+
// If we failed to connect, ensure the process is killed and log file closed
|
|
190
|
+
if (!client) {
|
|
191
|
+
bbProcess.kill('SIGKILL');
|
|
192
|
+
if (logFd !== undefined) {
|
|
193
|
+
try {
|
|
194
|
+
closeSync(logFd);
|
|
195
|
+
} catch (e) {
|
|
196
|
+
// Ignore errors during cleanup
|
|
197
|
+
}
|
|
198
|
+
}
|
|
199
|
+
}
|
|
200
|
+
}
|
|
201
|
+
}
|
|
202
|
+
|
|
203
|
+
/**
|
|
204
|
+
* Send a msgpack request asynchronously.
|
|
205
|
+
* Supports pipelining - can be called multiple times before awaiting responses.
|
|
206
|
+
* Use Promise.all() to send multiple requests concurrently.
|
|
207
|
+
*
|
|
208
|
+
* Example:
|
|
209
|
+
* const results = await Promise.all([
|
|
210
|
+
* backend.call(buf1),
|
|
211
|
+
* backend.call(buf2),
|
|
212
|
+
* backend.call(buf3)
|
|
213
|
+
* ]);
|
|
214
|
+
*
|
|
215
|
+
* @param inputBuffer The msgpack-encoded request
|
|
216
|
+
* @returns Promise resolving to msgpack-encoded response
|
|
217
|
+
*/
|
|
218
|
+
async call(inputBuffer: Uint8Array): Promise<Uint8Array> {
|
|
219
|
+
return new Promise((resolve, reject) => {
|
|
220
|
+
// If this is the first pending callback, acquire ref to keep event loop alive
|
|
221
|
+
if (this.pendingCallbacks.length === 0) {
|
|
222
|
+
this.client.acquire();
|
|
223
|
+
}
|
|
224
|
+
|
|
225
|
+
// Enqueue this promise's callbacks (FIFO order)
|
|
226
|
+
this.pendingCallbacks.push({ resolve, reject });
|
|
227
|
+
|
|
228
|
+
try {
|
|
229
|
+
// Send request to shared memory (synchronous write)
|
|
230
|
+
// C++ call() no longer returns a promise - we manage them here
|
|
231
|
+
this.client.call(Buffer.from(inputBuffer));
|
|
232
|
+
} catch (err: any) {
|
|
233
|
+
// Send failed - dequeue the callback we just added and reject
|
|
234
|
+
this.pendingCallbacks.pop();
|
|
235
|
+
|
|
236
|
+
// If queue is now empty, release ref to allow exit
|
|
237
|
+
if (this.pendingCallbacks.length === 0) {
|
|
238
|
+
this.client.release();
|
|
239
|
+
}
|
|
240
|
+
|
|
241
|
+
reject(new Error(`Shared memory async call failed: ${err.message}`));
|
|
242
|
+
}
|
|
243
|
+
});
|
|
244
|
+
}
|
|
245
|
+
|
|
246
|
+
async destroy(): Promise<void> {
|
|
247
|
+
// Kill the bb process
|
|
248
|
+
// Background thread and callbacks will be cleaned up by OS on process exit
|
|
249
|
+
this.process.kill('SIGTERM');
|
|
250
|
+
this.process.removeAllListeners();
|
|
251
|
+
|
|
252
|
+
// Close log file if open
|
|
253
|
+
if (this.logFd !== undefined) {
|
|
254
|
+
try {
|
|
255
|
+
closeSync(this.logFd);
|
|
256
|
+
} catch (e) {
|
|
257
|
+
// Ignore errors during cleanup
|
|
258
|
+
}
|
|
259
|
+
}
|
|
260
|
+
}
|
|
261
|
+
}
|
|
@@ -4,7 +4,7 @@ import * as fs from 'fs';
|
|
|
4
4
|
import * as os from 'os';
|
|
5
5
|
import * as path from 'path';
|
|
6
6
|
import { IMsgpackBackendAsync } from '../interface.js';
|
|
7
|
-
import
|
|
7
|
+
import readline from 'readline';
|
|
8
8
|
|
|
9
9
|
/**
|
|
10
10
|
* Asynchronous native backend that communicates with bb binary via Unix Domain Socket.
|
|
@@ -40,7 +40,7 @@ export class BarretenbergNativeSocketAsyncBackend implements IMsgpackBackendAsyn
|
|
|
40
40
|
private responseBuffer: Buffer | null = null;
|
|
41
41
|
private responseBytesRead: number = 0;
|
|
42
42
|
|
|
43
|
-
constructor(bbBinaryPath: string, threads?: number) {
|
|
43
|
+
constructor(bbBinaryPath: string, threads?: number, logger?: (msg: string) => void) {
|
|
44
44
|
// Create a unique socket path in temp directory
|
|
45
45
|
this.socketPath = path.join(os.tmpdir(), `bb-${process.pid}-${Date.now()}.sock`);
|
|
46
46
|
|
|
@@ -57,18 +57,28 @@ export class BarretenbergNativeSocketAsyncBackend implements IMsgpackBackendAsyn
|
|
|
57
57
|
connectionReject = reject;
|
|
58
58
|
});
|
|
59
59
|
|
|
60
|
-
//
|
|
61
|
-
const
|
|
60
|
+
// If threads not set use num cpu cores, max 16.
|
|
61
|
+
const hwc = threads ? threads.toString() : Math.min(16, os.cpus().length).toString();
|
|
62
|
+
const env = { ...process.env, HARDWARE_CONCURRENCY: hwc };
|
|
62
63
|
|
|
63
64
|
// Spawn bb process - it will create the socket server
|
|
64
|
-
const args = [
|
|
65
|
-
this.process = spawn(
|
|
66
|
-
stdio: ['ignore', 'ignore', 'ignore'],
|
|
65
|
+
const args = ['msgpack', 'run', '--input', this.socketPath];
|
|
66
|
+
this.process = spawn(bbBinaryPath, args, {
|
|
67
|
+
stdio: ['ignore', logger ? 'pipe' : 'ignore', logger ? 'pipe' : 'ignore'],
|
|
67
68
|
env,
|
|
68
69
|
});
|
|
69
|
-
|
|
70
|
+
|
|
71
|
+
// Disconnect from event loop so process can exit without waiting for bb
|
|
72
|
+
// The bb process has parent death monitoring (prctl on Linux, kqueue on macOS)
|
|
73
|
+
// so it will automatically exit when Node.js exits
|
|
70
74
|
this.process.unref();
|
|
71
75
|
|
|
76
|
+
if (logger) {
|
|
77
|
+
logger("Logger attached to bb process. DON'T FORGET TO DESTROY THE BACKEND to allow Node.js to exit.");
|
|
78
|
+
readline.createInterface({ input: this.process.stdout! }).on('line', logger);
|
|
79
|
+
readline.createInterface({ input: this.process.stderr! }).on('line', logger);
|
|
80
|
+
}
|
|
81
|
+
|
|
72
82
|
this.process.on('error', err => {
|
|
73
83
|
if (connectionReject) {
|
|
74
84
|
connectionReject(new Error(`Native backend process error: ${err.message}`));
|
|
@@ -157,7 +167,7 @@ export class BarretenbergNativeSocketAsyncBackend implements IMsgpackBackendAsyn
|
|
|
157
167
|
|
|
158
168
|
// Set up event handlers
|
|
159
169
|
this.socket.once('connect', () => {
|
|
160
|
-
|
|
170
|
+
// Socket starts referenced - will be unreferenced when no callbacks pending
|
|
161
171
|
|
|
162
172
|
// Clear connection timeout on successful connection
|
|
163
173
|
if (this.connectionTimeout) {
|
|
@@ -232,6 +242,11 @@ export class BarretenbergNativeSocketAsyncBackend implements IMsgpackBackendAsyn
|
|
|
232
242
|
console.warn('Received response but no pending callback');
|
|
233
243
|
}
|
|
234
244
|
|
|
245
|
+
// If no more pending callbacks, unref socket to allow process to exit
|
|
246
|
+
if (this.pendingCallbacks.length === 0 && this.socket) {
|
|
247
|
+
this.socket.unref();
|
|
248
|
+
}
|
|
249
|
+
|
|
235
250
|
// Reset state for next message
|
|
236
251
|
this.readingLength = true;
|
|
237
252
|
this.lengthBytesRead = 0;
|
|
@@ -252,6 +267,11 @@ export class BarretenbergNativeSocketAsyncBackend implements IMsgpackBackendAsyn
|
|
|
252
267
|
}
|
|
253
268
|
|
|
254
269
|
return new Promise((resolve, reject) => {
|
|
270
|
+
// If this is the first pending callback, ref the socket to keep event loop alive
|
|
271
|
+
if (this.pendingCallbacks.length === 0) {
|
|
272
|
+
this.socket!.ref();
|
|
273
|
+
}
|
|
274
|
+
|
|
255
275
|
// Enqueue this promise's callbacks (FIFO order)
|
|
256
276
|
this.pendingCallbacks.push({ resolve, reject });
|
|
257
277
|
|
|
@@ -298,15 +318,8 @@ export class BarretenbergNativeSocketAsyncBackend implements IMsgpackBackendAsyn
|
|
|
298
318
|
}
|
|
299
319
|
|
|
300
320
|
async destroy(): Promise<void> {
|
|
301
|
-
// Cleanup first (closes socket, unrefs everything)
|
|
302
321
|
this.cleanup();
|
|
303
|
-
|
|
304
|
-
|
|
305
|
-
// Process is unref'd so won't block event loop - just kill and return
|
|
306
|
-
try {
|
|
307
|
-
this.process.kill('SIGTERM');
|
|
308
|
-
} catch (e) {
|
|
309
|
-
// Already dead
|
|
310
|
-
}
|
|
322
|
+
this.process.kill('SIGTERM');
|
|
323
|
+
this.process.removeAllListeners();
|
|
311
324
|
}
|
|
312
325
|
}
|
|
@@ -24,7 +24,12 @@ export function findPackageRoot(): string | null {
|
|
|
24
24
|
while (currentDir !== root) {
|
|
25
25
|
const packageJsonPath = path.join(currentDir, 'package.json');
|
|
26
26
|
if (fs.existsSync(packageJsonPath)) {
|
|
27
|
-
|
|
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
|
+
}
|
|
28
33
|
}
|
|
29
34
|
currentDir = path.dirname(currentDir);
|
|
30
35
|
}
|
package/src/bb_backends/wasm.ts
CHANGED
|
@@ -3,7 +3,6 @@ import { fetchModuleAndThreads } from '../barretenberg_wasm/index.js';
|
|
|
3
3
|
import { IMsgpackBackendSync, IMsgpackBackendAsync } from './interface.js';
|
|
4
4
|
import { createMainWorker } from '../barretenberg_wasm/barretenberg_wasm_main/factory/node/index.js';
|
|
5
5
|
import { getRemoteBarretenbergWasm } from '../barretenberg_wasm/helpers/index.js';
|
|
6
|
-
import { createDebugLogger } from '../log/index.js';
|
|
7
6
|
import { proxy } from 'comlink';
|
|
8
7
|
|
|
9
8
|
/**
|
|
@@ -76,7 +75,7 @@ export class BarretenbergWasmAsyncBackend implements IMsgpackBackendAsync {
|
|
|
76
75
|
await wasm.init(
|
|
77
76
|
module,
|
|
78
77
|
threads,
|
|
79
|
-
proxy(options.logger ??
|
|
78
|
+
proxy(options.logger ?? (() => {})),
|
|
80
79
|
options.memory?.initial,
|
|
81
80
|
options.memory?.maximum,
|
|
82
81
|
);
|
|
@@ -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
|
+
}
|
package/src/bin/index.ts
ADDED
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
#!/usr/bin/env node
|
|
2
|
+
import { findBbBinary } from '../bb_backends/node/platform.js';
|
|
3
|
+
import { spawnSync } from 'node:child_process';
|
|
4
|
+
|
|
5
|
+
const bin = findBbBinary();
|
|
6
|
+
|
|
7
|
+
if (!bin) {
|
|
8
|
+
console.error('Could not find bb binary. Please ensure it is built and accessible.');
|
|
9
|
+
process.exit(1);
|
|
10
|
+
}
|
|
11
|
+
|
|
12
|
+
const result = spawnSync(bin, process.argv.slice(2), { stdio: 'inherit' });
|
|
13
|
+
|
|
14
|
+
process.exit(result.status ?? 1);
|
package/src/cbind/generate.ts
CHANGED
|
@@ -7,6 +7,7 @@ import { dirname, join } from 'path';
|
|
|
7
7
|
import { exec } from 'child_process';
|
|
8
8
|
import { promisify } from 'util';
|
|
9
9
|
import { fileURLToPath } from 'url';
|
|
10
|
+
import { unpack } from 'msgpackr';
|
|
10
11
|
import {
|
|
11
12
|
createSharedTypesCompiler,
|
|
12
13
|
createSyncApiCompiler,
|
|
@@ -73,9 +74,107 @@ async function generate() {
|
|
|
73
74
|
console.log(`✓ ${config.name}: ${outputPath}`);
|
|
74
75
|
}
|
|
75
76
|
|
|
77
|
+
// Generate curve constants
|
|
78
|
+
console.log('\nGenerating curve constants...');
|
|
79
|
+
await generateCurveConstants(bbBuildPath, outputDir);
|
|
80
|
+
|
|
76
81
|
console.log('\nGeneration complete!');
|
|
77
82
|
}
|
|
78
83
|
|
|
84
|
+
async function generateCurveConstants(bbBuildPath: string, outputDir: string) {
|
|
85
|
+
// Get curve constants from bb as msgpack binary
|
|
86
|
+
const { stdout: constantsBuffer } = await execAsync(`${bbBuildPath} msgpack curve_constants`, {
|
|
87
|
+
encoding: 'buffer',
|
|
88
|
+
maxBuffer: 10 * 1024 * 1024, // 10MB buffer
|
|
89
|
+
});
|
|
90
|
+
|
|
91
|
+
// Decode msgpack
|
|
92
|
+
const constants = unpack(constantsBuffer as Buffer);
|
|
93
|
+
|
|
94
|
+
// Helper to convert Uint8Array to hex string
|
|
95
|
+
const toHex = (bytes: Uint8Array) => '0x' + Buffer.from(bytes).toString('hex');
|
|
96
|
+
|
|
97
|
+
// Helper to convert Uint8Array to bigint (big-endian)
|
|
98
|
+
const toBigInt = (bytes: Uint8Array) => {
|
|
99
|
+
let result = 0n;
|
|
100
|
+
for (const byte of bytes) {
|
|
101
|
+
result = (result << 8n) | BigInt(byte);
|
|
102
|
+
}
|
|
103
|
+
return result;
|
|
104
|
+
};
|
|
105
|
+
|
|
106
|
+
// Helper to serialize point coordinate (handles both Uint8Array and array of Uint8Array for field2)
|
|
107
|
+
const serializeCoordinate = (coord: Uint8Array | Uint8Array[]) => {
|
|
108
|
+
if (Array.isArray(coord)) {
|
|
109
|
+
// For field2 (like BN254 G2), we have array of two Uint8Arrays
|
|
110
|
+
return `[${coord.map(c => `new Uint8Array([${Array.from(c).join(', ')}])`).join(', ')}]`;
|
|
111
|
+
} else {
|
|
112
|
+
// For regular fields, single Uint8Array
|
|
113
|
+
return `new Uint8Array([${Array.from(coord).join(', ')}])`;
|
|
114
|
+
}
|
|
115
|
+
};
|
|
116
|
+
|
|
117
|
+
// Generate TypeScript file
|
|
118
|
+
const content = `/**
|
|
119
|
+
* Curve constants generated from barretenberg native binary.
|
|
120
|
+
* DO NOT EDIT - This file is auto-generated by generate.ts
|
|
121
|
+
*/
|
|
122
|
+
|
|
123
|
+
/**
|
|
124
|
+
* BN254 curve constants
|
|
125
|
+
*/
|
|
126
|
+
export const BN254_FR_MODULUS = ${toBigInt(constants.bn254_fr_modulus)}n;
|
|
127
|
+
export const BN254_FQ_MODULUS = ${toBigInt(constants.bn254_fq_modulus)}n;
|
|
128
|
+
|
|
129
|
+
export const BN254_G1_GENERATOR = {
|
|
130
|
+
x: ${serializeCoordinate(constants.bn254_g1_generator.x)},
|
|
131
|
+
y: ${serializeCoordinate(constants.bn254_g1_generator.y)},
|
|
132
|
+
} as const;
|
|
133
|
+
|
|
134
|
+
export const BN254_G2_GENERATOR = {
|
|
135
|
+
x: ${serializeCoordinate(constants.bn254_g2_generator.x)},
|
|
136
|
+
y: ${serializeCoordinate(constants.bn254_g2_generator.y)},
|
|
137
|
+
} as const;
|
|
138
|
+
|
|
139
|
+
/**
|
|
140
|
+
* Grumpkin curve constants
|
|
141
|
+
*/
|
|
142
|
+
export const GRUMPKIN_FR_MODULUS = ${toBigInt(constants.grumpkin_fr_modulus)}n;
|
|
143
|
+
export const GRUMPKIN_FQ_MODULUS = ${toBigInt(constants.grumpkin_fq_modulus)}n;
|
|
144
|
+
|
|
145
|
+
export const GRUMPKIN_G1_GENERATOR = {
|
|
146
|
+
x: ${serializeCoordinate(constants.grumpkin_g1_generator.x)},
|
|
147
|
+
y: ${serializeCoordinate(constants.grumpkin_g1_generator.y)},
|
|
148
|
+
} as const;
|
|
149
|
+
|
|
150
|
+
/**
|
|
151
|
+
* Secp256k1 curve constants
|
|
152
|
+
*/
|
|
153
|
+
export const SECP256K1_FR_MODULUS = ${toBigInt(constants.secp256k1_fr_modulus)}n;
|
|
154
|
+
export const SECP256K1_FQ_MODULUS = ${toBigInt(constants.secp256k1_fq_modulus)}n;
|
|
155
|
+
|
|
156
|
+
export const SECP256K1_G1_GENERATOR = {
|
|
157
|
+
x: ${serializeCoordinate(constants.secp256k1_g1_generator.x)},
|
|
158
|
+
y: ${serializeCoordinate(constants.secp256k1_g1_generator.y)},
|
|
159
|
+
} as const;
|
|
160
|
+
|
|
161
|
+
/**
|
|
162
|
+
* Secp256r1 curve constants
|
|
163
|
+
*/
|
|
164
|
+
export const SECP256R1_FR_MODULUS = ${toBigInt(constants.secp256r1_fr_modulus)}n;
|
|
165
|
+
export const SECP256R1_FQ_MODULUS = ${toBigInt(constants.secp256r1_fq_modulus)}n;
|
|
166
|
+
|
|
167
|
+
export const SECP256R1_G1_GENERATOR = {
|
|
168
|
+
x: ${serializeCoordinate(constants.secp256r1_g1_generator.x)},
|
|
169
|
+
y: ${serializeCoordinate(constants.secp256r1_g1_generator.y)},
|
|
170
|
+
} as const;
|
|
171
|
+
`;
|
|
172
|
+
|
|
173
|
+
const outputPath = join(outputDir, 'curve_constants.ts');
|
|
174
|
+
writeFileSync(outputPath, content);
|
|
175
|
+
console.log(`✓ Curve constants: ${outputPath}`);
|
|
176
|
+
}
|
|
177
|
+
|
|
79
178
|
// Run the generator
|
|
80
179
|
generate().catch(error => {
|
|
81
180
|
console.error('Generation failed:', error);
|