@aztec/bb.js 0.0.1-alpha.7 → 0.0.1-commit.21caa21
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/README.md +55 -84
- 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/{async_map → browser/async_map}/index.d.ts +1 -1
- package/dest/browser/async_map/index.d.ts.map +1 -0
- package/dest/{async_map → browser/async_map}/index.js +1 -1
- package/dest/browser/barretenberg/backend.d.ts +61 -0
- package/dest/browser/barretenberg/backend.d.ts.map +1 -0
- package/dest/browser/barretenberg/backend.js +250 -0
- package/dest/browser/barretenberg/index.d.ts +65 -0
- package/dest/browser/barretenberg/index.d.ts.map +1 -0
- package/dest/browser/barretenberg/index.js +182 -0
- 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 +45 -0
- package/dest/browser/barretenberg_wasm/barretenberg_wasm_base/index.d.ts.map +1 -0
- package/dest/browser/barretenberg_wasm/barretenberg_wasm_base/index.js +124 -0
- package/dest/browser/barretenberg_wasm/barretenberg_wasm_main/factory/browser/index.d.ts +2 -0
- package/dest/browser/barretenberg_wasm/barretenberg_wasm_main/factory/browser/index.d.ts.map +1 -0
- package/dest/browser/barretenberg_wasm/barretenberg_wasm_main/factory/browser/index.js +9 -0
- package/dest/browser/barretenberg_wasm/barretenberg_wasm_main/factory/browser/main.worker.d.ts +2 -0
- package/dest/browser/barretenberg_wasm/barretenberg_wasm_main/factory/browser/main.worker.d.ts.map +1 -0
- package/dest/browser/barretenberg_wasm/barretenberg_wasm_main/factory/browser/main.worker.js +6 -0
- package/dest/browser/barretenberg_wasm/barretenberg_wasm_main/heap_allocator.d.ts +21 -0
- package/dest/browser/barretenberg_wasm/barretenberg_wasm_main/heap_allocator.d.ts.map +1 -0
- package/dest/browser/barretenberg_wasm/barretenberg_wasm_main/heap_allocator.js +71 -0
- package/dest/browser/barretenberg_wasm/barretenberg_wasm_main/index.d.ts +59 -0
- package/dest/browser/barretenberg_wasm/barretenberg_wasm_main/index.d.ts.map +1 -0
- package/dest/browser/barretenberg_wasm/barretenberg_wasm_main/index.js +197 -0
- package/dest/browser/barretenberg_wasm/barretenberg_wasm_thread/factory/browser/index.d.ts +2 -0
- package/dest/browser/barretenberg_wasm/barretenberg_wasm_thread/factory/browser/index.d.ts.map +1 -0
- package/dest/browser/barretenberg_wasm/barretenberg_wasm_thread/factory/browser/index.js +9 -0
- package/dest/browser/barretenberg_wasm/barretenberg_wasm_thread/factory/browser/thread.worker.d.ts +2 -0
- package/dest/browser/barretenberg_wasm/barretenberg_wasm_thread/factory/browser/thread.worker.d.ts.map +1 -0
- package/dest/browser/barretenberg_wasm/barretenberg_wasm_thread/factory/browser/thread.worker.js +6 -0
- package/dest/browser/barretenberg_wasm/barretenberg_wasm_thread/index.d.ts +30 -0
- package/dest/browser/barretenberg_wasm/barretenberg_wasm_thread/index.d.ts.map +1 -0
- package/dest/browser/barretenberg_wasm/barretenberg_wasm_thread/index.js +41 -0
- package/dest/browser/barretenberg_wasm/fetch_code/browser/barretenberg-threads.d.ts +3 -0
- package/dest/browser/barretenberg_wasm/fetch_code/browser/barretenberg-threads.d.ts.map +1 -0
- package/dest/browser/barretenberg_wasm/fetch_code/browser/barretenberg-threads.js +2 -0
- package/dest/browser/barretenberg_wasm/fetch_code/browser/barretenberg.d.ts +3 -0
- package/dest/browser/barretenberg_wasm/fetch_code/browser/barretenberg.d.ts.map +1 -0
- package/dest/browser/barretenberg_wasm/fetch_code/browser/barretenberg.js +2 -0
- package/dest/browser/barretenberg_wasm/fetch_code/browser/index.d.ts +2 -0
- package/dest/browser/barretenberg_wasm/fetch_code/browser/index.d.ts.map +1 -0
- package/dest/browser/barretenberg_wasm/fetch_code/browser/index.js +36 -0
- package/dest/browser/barretenberg_wasm/fetch_code/index.d.ts +2 -0
- package/dest/browser/barretenberg_wasm/fetch_code/index.d.ts.map +1 -0
- package/dest/browser/barretenberg_wasm/fetch_code/index.js +2 -0
- package/dest/browser/barretenberg_wasm/helpers/browser/index.d.ts +13 -0
- package/dest/browser/barretenberg_wasm/helpers/browser/index.d.ts.map +1 -0
- package/dest/browser/barretenberg_wasm/helpers/browser/index.js +47 -0
- package/dest/browser/barretenberg_wasm/helpers/index.d.ts +2 -0
- package/dest/browser/barretenberg_wasm/helpers/index.d.ts.map +1 -0
- package/dest/browser/barretenberg_wasm/helpers/index.js +2 -0
- package/dest/browser/barretenberg_wasm/index.d.ts +5 -0
- package/dest/browser/barretenberg_wasm/index.d.ts.map +1 -0
- package/dest/browser/barretenberg_wasm/index.js +15 -0
- package/dest/browser/bb_backends/browser/index.d.ts +11 -0
- package/dest/browser/bb_backends/browser/index.d.ts.map +1 -0
- package/dest/browser/bb_backends/browser/index.js +39 -0
- 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 +48 -0
- package/dest/browser/bb_backends/index.d.ts.map +1 -0
- package/dest/browser/bb_backends/index.js +16 -0
- package/dest/browser/bb_backends/interface.d.ts +33 -0
- package/dest/browser/bb_backends/interface.d.ts.map +1 -0
- package/dest/browser/bb_backends/interface.js +2 -0
- package/dest/browser/bb_backends/wasm.d.ts +49 -0
- package/dest/browser/bb_backends/wasm.d.ts.map +1 -0
- package/dest/browser/bb_backends/wasm.js +85 -0
- 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/{bindgen → browser/bin}/index.d.ts.map +1 -1
- package/dest/browser/bin/index.js +11 -0
- package/dest/browser/cbind/generate.d.ts +5 -0
- package/dest/browser/cbind/generate.d.ts.map +1 -0
- package/dest/browser/cbind/generate.js +151 -0
- package/dest/browser/cbind/generated/api_types.d.ts +2051 -0
- package/dest/browser/cbind/generated/api_types.d.ts.map +1 -0
- package/dest/browser/cbind/generated/api_types.js +2747 -0
- package/dest/browser/cbind/generated/async.d.ts +62 -0
- package/dest/browser/cbind/generated/async.d.ts.map +1 -0
- package/dest/browser/cbind/generated/async.js +663 -0
- 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 +62 -0
- package/dest/browser/cbind/generated/sync.d.ts.map +1 -0
- package/dest/browser/cbind/generated/sync.js +610 -0
- package/dest/browser/cbind/schema_compiler.d.ts +68 -0
- package/dest/browser/cbind/schema_compiler.d.ts.map +1 -0
- package/dest/browser/cbind/schema_compiler.js +600 -0
- package/dest/browser/crs/browser/cached_net_crs.d.ts +43 -0
- package/dest/browser/crs/browser/cached_net_crs.d.ts.map +1 -0
- package/dest/browser/crs/browser/cached_net_crs.js +95 -0
- package/dest/browser/crs/browser/index.d.ts +2 -0
- package/dest/browser/crs/browser/index.d.ts.map +1 -0
- package/dest/browser/crs/browser/index.js +2 -0
- package/dest/browser/crs/index.d.ts +2 -0
- package/dest/browser/crs/index.d.ts.map +1 -0
- package/dest/browser/crs/index.js +2 -0
- package/dest/browser/crs/net_crs.d.ts +70 -0
- package/dest/browser/crs/net_crs.d.ts.map +1 -0
- package/dest/browser/crs/net_crs.js +141 -0
- package/dest/browser/index.d.ts +9 -0
- package/dest/browser/index.d.ts.map +1 -0
- package/dest/browser/index.js +9 -0
- package/dest/browser/proof/index.d.ts +21 -0
- package/dest/browser/proof/index.d.ts.map +1 -0
- package/dest/browser/proof/index.js +63 -0
- package/dest/browser/random/browser/index.d.ts +2 -0
- package/dest/browser/random/browser/index.d.ts.map +1 -0
- package/dest/browser/random/browser/index.js +31 -0
- package/dest/browser/random/index.d.ts +2 -0
- package/dest/browser/random/index.d.ts.map +1 -0
- package/dest/browser/random/index.js +2 -0
- package/dest/browser/retry/index.d.ts +26 -0
- package/dest/browser/retry/index.d.ts.map +1 -0
- package/dest/browser/retry/index.js +50 -0
- package/dest/node/async_map/index.d.ts +10 -0
- package/dest/node/async_map/index.d.ts.map +1 -0
- package/dest/node/async_map/index.js +16 -0
- package/dest/node/barretenberg/__snapshots__/pedersen.test.js.snap +156 -0
- package/dest/node/barretenberg/__snapshots__/poseidon.test.js.snap +40 -0
- package/dest/node/barretenberg/backend.d.ts +61 -0
- package/dest/node/barretenberg/backend.d.ts.map +1 -0
- package/dest/node/barretenberg/backend.js +250 -0
- package/dest/node/barretenberg/blake2s.test.d.ts +2 -0
- package/dest/node/barretenberg/blake2s.test.d.ts.map +1 -0
- package/dest/node/barretenberg/blake2s.test.js +57 -0
- package/dest/node/barretenberg/index.d.ts +65 -0
- package/dest/node/barretenberg/index.d.ts.map +1 -0
- package/dest/node/barretenberg/index.js +182 -0
- package/dest/node/barretenberg/pedersen.test.d.ts +2 -0
- package/dest/node/barretenberg/pedersen.test.d.ts.map +1 -0
- package/dest/node/barretenberg/pedersen.test.js +62 -0
- package/dest/node/barretenberg/poseidon.bench.test.d.ts +2 -0
- package/dest/node/barretenberg/poseidon.bench.test.d.ts.map +1 -0
- package/dest/node/barretenberg/poseidon.bench.test.js +218 -0
- package/dest/node/barretenberg/poseidon.test.d.ts +2 -0
- package/dest/node/barretenberg/poseidon.test.d.ts.map +1 -0
- package/dest/node/barretenberg/poseidon.test.js +35 -0
- 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 +45 -0
- package/dest/node/barretenberg_wasm/barretenberg_wasm_base/index.d.ts.map +1 -0
- package/dest/node/barretenberg_wasm/barretenberg_wasm_base/index.js +124 -0
- package/dest/node/barretenberg_wasm/barretenberg_wasm_main/factory/browser/index.d.ts +2 -0
- package/dest/node/barretenberg_wasm/barretenberg_wasm_main/factory/browser/index.d.ts.map +1 -0
- package/dest/node/barretenberg_wasm/barretenberg_wasm_main/factory/browser/index.js +9 -0
- package/dest/node/barretenberg_wasm/barretenberg_wasm_main/factory/browser/main.worker.d.ts +2 -0
- package/dest/node/barretenberg_wasm/barretenberg_wasm_main/factory/browser/main.worker.d.ts.map +1 -0
- package/dest/node/barretenberg_wasm/barretenberg_wasm_main/factory/browser/main.worker.js +6 -0
- package/dest/node/barretenberg_wasm/barretenberg_wasm_main/factory/node/index.d.ts +3 -0
- package/dest/node/barretenberg_wasm/barretenberg_wasm_main/factory/node/index.d.ts.map +1 -0
- package/dest/node/barretenberg_wasm/barretenberg_wasm_main/factory/node/index.js +19 -0
- package/dest/node/barretenberg_wasm/barretenberg_wasm_main/factory/node/main.worker.d.ts +2 -0
- package/dest/node/barretenberg_wasm/barretenberg_wasm_main/factory/node/main.worker.d.ts.map +1 -0
- package/dest/node/barretenberg_wasm/barretenberg_wasm_main/factory/node/main.worker.js +9 -0
- package/dest/node/barretenberg_wasm/barretenberg_wasm_main/heap_allocator.d.ts +21 -0
- package/dest/node/barretenberg_wasm/barretenberg_wasm_main/heap_allocator.d.ts.map +1 -0
- package/dest/node/barretenberg_wasm/barretenberg_wasm_main/heap_allocator.js +71 -0
- package/dest/node/barretenberg_wasm/barretenberg_wasm_main/index.d.ts +59 -0
- package/dest/node/barretenberg_wasm/barretenberg_wasm_main/index.d.ts.map +1 -0
- package/dest/node/barretenberg_wasm/barretenberg_wasm_main/index.js +197 -0
- package/dest/node/barretenberg_wasm/barretenberg_wasm_thread/factory/browser/index.d.ts +2 -0
- package/dest/node/barretenberg_wasm/barretenberg_wasm_thread/factory/browser/index.d.ts.map +1 -0
- package/dest/node/barretenberg_wasm/barretenberg_wasm_thread/factory/browser/index.js +9 -0
- package/dest/node/barretenberg_wasm/barretenberg_wasm_thread/factory/browser/thread.worker.d.ts +2 -0
- package/dest/node/barretenberg_wasm/barretenberg_wasm_thread/factory/browser/thread.worker.d.ts.map +1 -0
- package/dest/node/barretenberg_wasm/barretenberg_wasm_thread/factory/browser/thread.worker.js +6 -0
- package/dest/node/barretenberg_wasm/barretenberg_wasm_thread/factory/node/index.d.ts +3 -0
- package/dest/node/barretenberg_wasm/barretenberg_wasm_thread/factory/node/index.d.ts.map +1 -0
- package/dest/node/barretenberg_wasm/barretenberg_wasm_thread/factory/node/index.js +19 -0
- package/dest/node/barretenberg_wasm/barretenberg_wasm_thread/factory/node/thread.worker.d.ts +2 -0
- package/dest/node/barretenberg_wasm/barretenberg_wasm_thread/factory/node/thread.worker.d.ts.map +1 -0
- package/dest/node/barretenberg_wasm/barretenberg_wasm_thread/factory/node/thread.worker.js +10 -0
- package/dest/node/barretenberg_wasm/barretenberg_wasm_thread/index.d.ts +30 -0
- package/dest/node/barretenberg_wasm/barretenberg_wasm_thread/index.d.ts.map +1 -0
- package/dest/node/barretenberg_wasm/barretenberg_wasm_thread/index.js +41 -0
- package/dest/node/barretenberg_wasm/fetch_code/browser/barretenberg-threads.d.ts +3 -0
- package/dest/node/barretenberg_wasm/fetch_code/browser/barretenberg-threads.d.ts.map +1 -0
- package/dest/node/barretenberg_wasm/fetch_code/browser/barretenberg-threads.js +3 -0
- package/dest/node/barretenberg_wasm/fetch_code/browser/barretenberg.d.ts +3 -0
- package/dest/node/barretenberg_wasm/fetch_code/browser/barretenberg.d.ts.map +1 -0
- package/dest/node/barretenberg_wasm/fetch_code/browser/barretenberg.js +3 -0
- package/dest/node/barretenberg_wasm/fetch_code/browser/index.d.ts +2 -0
- package/dest/node/barretenberg_wasm/fetch_code/browser/index.d.ts.map +1 -0
- package/dest/node/barretenberg_wasm/fetch_code/browser/index.js +36 -0
- package/dest/node/barretenberg_wasm/fetch_code/index.d.ts +2 -0
- package/dest/node/barretenberg_wasm/fetch_code/index.d.ts.map +1 -0
- package/dest/node/barretenberg_wasm/fetch_code/index.js +2 -0
- package/dest/node/barretenberg_wasm/fetch_code/node/index.d.ts +2 -0
- package/dest/node/barretenberg_wasm/fetch_code/node/index.d.ts.map +1 -0
- package/dest/node/barretenberg_wasm/fetch_code/node/index.js +35 -0
- package/dest/node/barretenberg_wasm/helpers/browser/index.d.ts +13 -0
- package/dest/node/barretenberg_wasm/helpers/browser/index.d.ts.map +1 -0
- package/dest/node/barretenberg_wasm/helpers/browser/index.js +47 -0
- package/dest/node/barretenberg_wasm/helpers/index.d.ts +2 -0
- package/dest/node/barretenberg_wasm/helpers/index.d.ts.map +1 -0
- package/dest/node/barretenberg_wasm/helpers/index.js +2 -0
- package/dest/node/barretenberg_wasm/helpers/node/index.d.ts +21 -0
- package/dest/node/barretenberg_wasm/helpers/node/index.d.ts.map +1 -0
- package/dest/node/barretenberg_wasm/helpers/node/index.js +56 -0
- package/dest/node/barretenberg_wasm/helpers/node/node_endpoint.d.ts +8 -0
- package/dest/node/barretenberg_wasm/helpers/node/node_endpoint.d.ts.map +1 -0
- package/dest/node/barretenberg_wasm/helpers/node/node_endpoint.js +28 -0
- package/dest/node/barretenberg_wasm/index.d.ts +5 -0
- package/dest/node/barretenberg_wasm/index.d.ts.map +1 -0
- package/dest/node/barretenberg_wasm/index.js +15 -0
- package/dest/node/barretenberg_wasm/index.test.d.ts +2 -0
- package/dest/node/barretenberg_wasm/index.test.d.ts.map +1 -0
- package/dest/node/barretenberg_wasm/index.test.js +39 -0
- package/dest/node/bb_backends/browser/index.d.ts +11 -0
- package/dest/node/bb_backends/browser/index.d.ts.map +1 -0
- package/dest/node/bb_backends/browser/index.js +39 -0
- 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 +48 -0
- package/dest/node/bb_backends/index.d.ts.map +1 -0
- package/dest/node/bb_backends/index.js +16 -0
- package/dest/node/bb_backends/interface.d.ts +33 -0
- package/dest/node/bb_backends/interface.d.ts.map +1 -0
- package/dest/node/bb_backends/interface.js +2 -0
- package/dest/node/bb_backends/node/index.d.ts +11 -0
- package/dest/node/bb_backends/node/index.d.ts.map +1 -0
- package/dest/node/bb_backends/node/index.js +86 -0
- package/dest/node/bb_backends/node/native_pipe.d.ts +25 -0
- package/dest/node/bb_backends/node/native_pipe.d.ts.map +1 -0
- package/dest/node/bb_backends/node/native_pipe.js +114 -0
- package/dest/node/bb_backends/node/native_shm.d.ts +28 -0
- package/dest/node/bb_backends/node/native_shm.d.ts.map +1 -0
- package/dest/node/bb_backends/node/native_shm.js +177 -0
- 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 +237 -0
- package/dest/node/bb_backends/node/native_socket.d.ts +34 -0
- package/dest/node/bb_backends/node/native_socket.d.ts.map +1 -0
- package/dest/node/bb_backends/node/native_socket.js +281 -0
- package/dest/node/bb_backends/node/platform.d.ts +27 -0
- package/dest/node/bb_backends/node/platform.d.ts.map +1 -0
- package/dest/node/bb_backends/node/platform.js +124 -0
- package/dest/node/bb_backends/wasm.d.ts +49 -0
- package/dest/node/bb_backends/wasm.d.ts.map +1 -0
- package/dest/node/bb_backends/wasm.js +85 -0
- 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 +3 -0
- package/dest/node/benchmark/index.d.ts.map +1 -0
- package/dest/node/benchmark/index.js +25 -0
- package/dest/node/benchmark/timer.d.ts +34 -0
- package/dest/node/benchmark/timer.d.ts.map +1 -0
- package/dest/node/benchmark/timer.js +42 -0
- 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 +5 -0
- package/dest/node/cbind/generate.d.ts.map +1 -0
- package/dest/node/cbind/generate.js +151 -0
- package/dest/node/cbind/generated/api_types.d.ts +2051 -0
- package/dest/node/cbind/generated/api_types.d.ts.map +1 -0
- package/dest/node/cbind/generated/api_types.js +2747 -0
- package/dest/node/cbind/generated/async.d.ts +62 -0
- package/dest/node/cbind/generated/async.d.ts.map +1 -0
- package/dest/node/cbind/generated/async.js +663 -0
- 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 +62 -0
- package/dest/node/cbind/generated/sync.d.ts.map +1 -0
- package/dest/node/cbind/generated/sync.js +610 -0
- package/dest/node/cbind/schema_compiler.d.ts +68 -0
- package/dest/node/cbind/schema_compiler.d.ts.map +1 -0
- package/dest/node/cbind/schema_compiler.js +600 -0
- package/dest/node/crs/browser/cached_net_crs.d.ts +43 -0
- package/dest/node/crs/browser/cached_net_crs.d.ts.map +1 -0
- package/dest/node/crs/browser/cached_net_crs.js +95 -0
- package/dest/node/crs/browser/index.d.ts +2 -0
- package/dest/node/crs/browser/index.d.ts.map +1 -0
- package/dest/node/crs/browser/index.js +2 -0
- package/dest/node/crs/index.d.ts +2 -0
- package/dest/node/crs/index.d.ts.map +1 -0
- package/dest/node/crs/index.js +2 -0
- package/dest/node/crs/net_crs.d.ts +70 -0
- package/dest/node/crs/net_crs.d.ts.map +1 -0
- package/dest/node/crs/net_crs.js +141 -0
- package/dest/node/crs/node/index.d.ts +38 -0
- package/dest/node/crs/node/index.d.ts.map +1 -0
- package/dest/node/crs/node/index.js +107 -0
- package/dest/node/index.d.ts +9 -0
- package/dest/node/index.d.ts.map +1 -0
- package/dest/node/index.js +9 -0
- package/dest/node/proof/index.d.ts +21 -0
- package/dest/node/proof/index.d.ts.map +1 -0
- package/dest/node/proof/index.js +63 -0
- package/dest/node/random/browser/index.d.ts +2 -0
- package/dest/node/random/browser/index.d.ts.map +1 -0
- package/dest/node/random/browser/index.js +31 -0
- package/dest/node/random/index.d.ts +2 -0
- package/dest/node/random/index.d.ts.map +1 -0
- package/dest/{random → node/random}/index.js +1 -1
- package/dest/node/random/node/index.d.ts +2 -0
- package/dest/node/random/node/index.d.ts.map +1 -0
- package/dest/node/random/node/index.js +5 -0
- package/dest/node/retry/index.d.ts +26 -0
- package/dest/node/retry/index.d.ts.map +1 -0
- package/dest/node/retry/index.js +50 -0
- package/dest/node-cjs/async_map/index.d.ts +10 -0
- package/dest/node-cjs/async_map/index.d.ts.map +1 -0
- package/dest/node-cjs/async_map/index.js +19 -0
- package/dest/node-cjs/barretenberg/backend.d.ts +61 -0
- package/dest/node-cjs/barretenberg/backend.d.ts.map +1 -0
- package/dest/node-cjs/barretenberg/backend.js +257 -0
- package/dest/node-cjs/barretenberg/blake2s.test.d.ts +2 -0
- package/dest/node-cjs/barretenberg/blake2s.test.d.ts.map +1 -0
- package/dest/node-cjs/barretenberg/blake2s.test.js +59 -0
- package/dest/node-cjs/barretenberg/index.d.ts +65 -0
- package/dest/node-cjs/barretenberg/index.d.ts.map +1 -0
- package/dest/node-cjs/barretenberg/index.js +191 -0
- package/dest/node-cjs/barretenberg/pedersen.test.d.ts +2 -0
- package/dest/node-cjs/barretenberg/pedersen.test.d.ts.map +1 -0
- package/dest/node-cjs/barretenberg/pedersen.test.js +64 -0
- package/dest/node-cjs/barretenberg/poseidon.bench.test.d.ts +2 -0
- package/dest/node-cjs/barretenberg/poseidon.bench.test.d.ts.map +1 -0
- package/dest/node-cjs/barretenberg/poseidon.bench.test.js +220 -0
- package/dest/node-cjs/barretenberg/poseidon.test.d.ts +2 -0
- package/dest/node-cjs/barretenberg/poseidon.test.d.ts.map +1 -0
- package/dest/node-cjs/barretenberg/poseidon.test.js +37 -0
- 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 +45 -0
- package/dest/node-cjs/barretenberg_wasm/barretenberg_wasm_base/index.d.ts.map +1 -0
- package/dest/node-cjs/barretenberg_wasm/barretenberg_wasm_base/index.js +128 -0
- package/dest/node-cjs/barretenberg_wasm/barretenberg_wasm_main/factory/browser/index.d.ts +2 -0
- package/dest/node-cjs/barretenberg_wasm/barretenberg_wasm_main/factory/browser/index.d.ts.map +1 -0
- package/dest/node-cjs/barretenberg_wasm/barretenberg_wasm_main/factory/browser/index.js +12 -0
- package/dest/node-cjs/barretenberg_wasm/barretenberg_wasm_main/factory/browser/main.worker.d.ts +2 -0
- package/dest/node-cjs/barretenberg_wasm/barretenberg_wasm_main/factory/browser/main.worker.d.ts.map +1 -0
- package/dest/node-cjs/barretenberg_wasm/barretenberg_wasm_main/factory/browser/main.worker.js +8 -0
- package/dest/node-cjs/barretenberg_wasm/barretenberg_wasm_main/factory/node/index.d.ts +3 -0
- package/dest/node-cjs/barretenberg_wasm/barretenberg_wasm_main/factory/node/index.d.ts.map +1 -0
- package/dest/node-cjs/barretenberg_wasm/barretenberg_wasm_main/factory/node/index.js +22 -0
- package/dest/node-cjs/barretenberg_wasm/barretenberg_wasm_main/factory/node/main.worker.d.ts +2 -0
- package/dest/node-cjs/barretenberg_wasm/barretenberg_wasm_main/factory/node/main.worker.d.ts.map +1 -0
- package/dest/node-cjs/barretenberg_wasm/barretenberg_wasm_main/factory/node/main.worker.js +11 -0
- package/dest/node-cjs/barretenberg_wasm/barretenberg_wasm_main/heap_allocator.d.ts +21 -0
- package/dest/node-cjs/barretenberg_wasm/barretenberg_wasm_main/heap_allocator.d.ts.map +1 -0
- package/dest/node-cjs/barretenberg_wasm/barretenberg_wasm_main/heap_allocator.js +75 -0
- package/dest/node-cjs/barretenberg_wasm/barretenberg_wasm_main/index.d.ts +59 -0
- package/dest/node-cjs/barretenberg_wasm/barretenberg_wasm_main/index.d.ts.map +1 -0
- package/dest/node-cjs/barretenberg_wasm/barretenberg_wasm_main/index.js +201 -0
- package/dest/node-cjs/barretenberg_wasm/barretenberg_wasm_thread/factory/browser/index.d.ts +2 -0
- package/dest/node-cjs/barretenberg_wasm/barretenberg_wasm_thread/factory/browser/index.d.ts.map +1 -0
- package/dest/node-cjs/barretenberg_wasm/barretenberg_wasm_thread/factory/browser/index.js +12 -0
- package/dest/node-cjs/barretenberg_wasm/barretenberg_wasm_thread/factory/browser/thread.worker.d.ts +2 -0
- package/dest/node-cjs/barretenberg_wasm/barretenberg_wasm_thread/factory/browser/thread.worker.d.ts.map +1 -0
- package/dest/node-cjs/barretenberg_wasm/barretenberg_wasm_thread/factory/browser/thread.worker.js +8 -0
- package/dest/node-cjs/barretenberg_wasm/barretenberg_wasm_thread/factory/node/index.d.ts +3 -0
- package/dest/node-cjs/barretenberg_wasm/barretenberg_wasm_thread/factory/node/index.d.ts.map +1 -0
- package/dest/node-cjs/barretenberg_wasm/barretenberg_wasm_thread/factory/node/index.js +22 -0
- package/dest/node-cjs/barretenberg_wasm/barretenberg_wasm_thread/factory/node/thread.worker.d.ts +2 -0
- package/dest/node-cjs/barretenberg_wasm/barretenberg_wasm_thread/factory/node/thread.worker.d.ts.map +1 -0
- package/dest/node-cjs/barretenberg_wasm/barretenberg_wasm_thread/factory/node/thread.worker.js +12 -0
- package/dest/node-cjs/barretenberg_wasm/barretenberg_wasm_thread/index.d.ts +30 -0
- package/dest/node-cjs/barretenberg_wasm/barretenberg_wasm_thread/index.d.ts.map +1 -0
- package/dest/node-cjs/barretenberg_wasm/barretenberg_wasm_thread/index.js +45 -0
- package/dest/node-cjs/barretenberg_wasm/fetch_code/browser/barretenberg-threads.d.ts +3 -0
- package/dest/node-cjs/barretenberg_wasm/fetch_code/browser/barretenberg-threads.d.ts.map +1 -0
- package/dest/node-cjs/barretenberg_wasm/fetch_code/browser/barretenberg-threads.js +6 -0
- package/dest/node-cjs/barretenberg_wasm/fetch_code/browser/barretenberg.d.ts +3 -0
- package/dest/node-cjs/barretenberg_wasm/fetch_code/browser/barretenberg.d.ts.map +1 -0
- package/dest/node-cjs/barretenberg_wasm/fetch_code/browser/barretenberg.js +6 -0
- package/dest/node-cjs/barretenberg_wasm/fetch_code/browser/index.d.ts +2 -0
- package/dest/node-cjs/barretenberg_wasm/fetch_code/browser/index.d.ts.map +1 -0
- package/dest/node-cjs/barretenberg_wasm/fetch_code/browser/index.js +40 -0
- package/dest/node-cjs/barretenberg_wasm/fetch_code/index.d.ts +2 -0
- package/dest/node-cjs/barretenberg_wasm/fetch_code/index.d.ts.map +1 -0
- package/dest/node-cjs/barretenberg_wasm/fetch_code/index.js +5 -0
- package/dest/node-cjs/barretenberg_wasm/fetch_code/node/index.d.ts +2 -0
- package/dest/node-cjs/barretenberg_wasm/fetch_code/node/index.d.ts.map +1 -0
- package/dest/node-cjs/barretenberg_wasm/fetch_code/node/index.js +39 -0
- package/dest/node-cjs/barretenberg_wasm/helpers/browser/index.d.ts +13 -0
- package/dest/node-cjs/barretenberg_wasm/helpers/browser/index.d.ts.map +1 -0
- package/dest/node-cjs/barretenberg_wasm/helpers/browser/index.js +57 -0
- package/dest/node-cjs/barretenberg_wasm/helpers/index.d.ts +2 -0
- package/dest/node-cjs/barretenberg_wasm/helpers/index.d.ts.map +1 -0
- package/dest/node-cjs/barretenberg_wasm/helpers/index.js +5 -0
- package/dest/node-cjs/barretenberg_wasm/helpers/node/index.d.ts +21 -0
- package/dest/node-cjs/barretenberg_wasm/helpers/node/index.d.ts.map +1 -0
- package/dest/node-cjs/barretenberg_wasm/helpers/node/index.js +65 -0
- package/dest/node-cjs/barretenberg_wasm/helpers/node/node_endpoint.d.ts +8 -0
- package/dest/node-cjs/barretenberg_wasm/helpers/node/node_endpoint.d.ts.map +1 -0
- package/dest/node-cjs/barretenberg_wasm/helpers/node/node_endpoint.js +31 -0
- package/dest/node-cjs/barretenberg_wasm/index.d.ts +5 -0
- package/dest/node-cjs/barretenberg_wasm/index.d.ts.map +1 -0
- package/dest/node-cjs/barretenberg_wasm/index.js +18 -0
- package/dest/node-cjs/barretenberg_wasm/index.test.d.ts +2 -0
- package/dest/node-cjs/barretenberg_wasm/index.test.d.ts.map +1 -0
- package/dest/node-cjs/barretenberg_wasm/index.test.js +41 -0
- package/dest/node-cjs/bb_backends/browser/index.d.ts +11 -0
- package/dest/node-cjs/bb_backends/browser/index.d.ts.map +1 -0
- package/dest/node-cjs/bb_backends/browser/index.js +43 -0
- 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 +48 -0
- package/dest/node-cjs/bb_backends/index.d.ts.map +1 -0
- package/dest/node-cjs/bb_backends/index.js +18 -0
- package/dest/node-cjs/bb_backends/interface.d.ts +33 -0
- package/dest/node-cjs/bb_backends/interface.d.ts.map +1 -0
- package/dest/node-cjs/bb_backends/interface.js +3 -0
- package/dest/node-cjs/bb_backends/node/index.d.ts +11 -0
- package/dest/node-cjs/bb_backends/node/index.d.ts.map +1 -0
- package/dest/node-cjs/bb_backends/node/index.js +90 -0
- package/dest/node-cjs/bb_backends/node/native_pipe.d.ts +25 -0
- package/dest/node-cjs/bb_backends/node/native_pipe.d.ts.map +1 -0
- package/dest/node-cjs/bb_backends/node/native_pipe.js +118 -0
- package/dest/node-cjs/bb_backends/node/native_shm.d.ts +28 -0
- package/dest/node-cjs/bb_backends/node/native_shm.d.ts.map +1 -0
- package/dest/node-cjs/bb_backends/node/native_shm.js +181 -0
- 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 +241 -0
- package/dest/node-cjs/bb_backends/node/native_socket.d.ts +34 -0
- package/dest/node-cjs/bb_backends/node/native_socket.d.ts.map +1 -0
- package/dest/node-cjs/bb_backends/node/native_socket.js +286 -0
- package/dest/node-cjs/bb_backends/node/platform.d.ts +27 -0
- package/dest/node-cjs/bb_backends/node/platform.d.ts.map +1 -0
- package/dest/node-cjs/bb_backends/node/platform.js +131 -0
- package/dest/node-cjs/bb_backends/wasm.d.ts +49 -0
- package/dest/node-cjs/bb_backends/wasm.d.ts.map +1 -0
- package/dest/node-cjs/bb_backends/wasm.js +90 -0
- 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 +3 -0
- package/dest/node-cjs/benchmark/index.d.ts.map +1 -0
- package/dest/node-cjs/benchmark/index.js +29 -0
- package/dest/node-cjs/benchmark/timer.d.ts +34 -0
- package/dest/node-cjs/benchmark/timer.d.ts.map +1 -0
- package/dest/node-cjs/benchmark/timer.js +46 -0
- 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 +5 -0
- package/dest/node-cjs/cbind/generate.d.ts.map +1 -0
- package/dest/node-cjs/cbind/generate.js +153 -0
- package/dest/node-cjs/cbind/generated/api_types.d.ts +2051 -0
- package/dest/node-cjs/cbind/generated/api_types.d.ts.map +1 -0
- package/dest/node-cjs/cbind/generated/api_types.js +2989 -0
- package/dest/node-cjs/cbind/generated/async.d.ts +62 -0
- package/dest/node-cjs/cbind/generated/async.d.ts.map +1 -0
- package/dest/node-cjs/cbind/generated/async.js +667 -0
- 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 +62 -0
- package/dest/node-cjs/cbind/generated/sync.d.ts.map +1 -0
- package/dest/node-cjs/cbind/generated/sync.js +614 -0
- package/dest/node-cjs/cbind/schema_compiler.d.ts +68 -0
- package/dest/node-cjs/cbind/schema_compiler.d.ts.map +1 -0
- package/dest/node-cjs/cbind/schema_compiler.js +607 -0
- package/dest/node-cjs/crs/browser/cached_net_crs.d.ts +43 -0
- package/dest/node-cjs/crs/browser/cached_net_crs.d.ts.map +1 -0
- package/dest/node-cjs/crs/browser/cached_net_crs.js +100 -0
- package/dest/node-cjs/crs/browser/index.d.ts +2 -0
- package/dest/node-cjs/crs/browser/index.d.ts.map +1 -0
- package/dest/node-cjs/crs/browser/index.js +7 -0
- package/dest/node-cjs/crs/index.d.ts +2 -0
- package/dest/node-cjs/crs/index.d.ts.map +1 -0
- package/dest/node-cjs/crs/index.js +7 -0
- package/dest/node-cjs/crs/net_crs.d.ts +70 -0
- package/dest/node-cjs/crs/net_crs.d.ts.map +1 -0
- package/dest/node-cjs/crs/net_crs.js +146 -0
- package/dest/node-cjs/crs/node/index.d.ts +38 -0
- package/dest/node-cjs/crs/node/index.d.ts.map +1 -0
- package/dest/node-cjs/crs/node/index.js +112 -0
- package/dest/node-cjs/index.d.ts +9 -0
- package/dest/node-cjs/index.d.ts.map +1 -0
- package/dest/node-cjs/index.js +39 -0
- package/dest/node-cjs/package.json +3 -0
- package/dest/node-cjs/proof/index.d.ts +21 -0
- package/dest/node-cjs/proof/index.d.ts.map +1 -0
- package/dest/node-cjs/proof/index.js +72 -0
- package/dest/node-cjs/random/browser/index.d.ts +2 -0
- package/dest/node-cjs/random/browser/index.d.ts.map +1 -0
- package/dest/node-cjs/random/browser/index.js +35 -0
- package/dest/node-cjs/random/index.d.ts +2 -0
- package/dest/node-cjs/random/index.d.ts.map +1 -0
- package/dest/node-cjs/random/index.js +5 -0
- package/dest/node-cjs/random/node/index.d.ts +2 -0
- package/dest/node-cjs/random/node/index.d.ts.map +1 -0
- package/dest/node-cjs/random/node/index.js +8 -0
- package/dest/node-cjs/retry/index.d.ts +26 -0
- package/dest/node-cjs/retry/index.d.ts.map +1 -0
- package/dest/node-cjs/retry/index.js +55 -0
- package/package.json +59 -46
- package/src/barretenberg/__snapshots__/pedersen.test.ts.snap +156 -0
- package/src/barretenberg/__snapshots__/poseidon.test.ts.snap +40 -0
- package/src/barretenberg/backend.ts +312 -0
- package/src/barretenberg/blake2s.test.ts +69 -0
- package/src/barretenberg/index.ts +212 -0
- package/src/barretenberg/pedersen.test.ts +69 -0
- package/src/barretenberg/poseidon.bench.test.ts +271 -0
- package/src/barretenberg/poseidon.test.ts +39 -0
- package/src/barretenberg/testing/bigint-buffer.ts +43 -0
- package/src/barretenberg/testing/fields.ts +63 -0
- package/src/barretenberg_wasm/barretenberg_wasm_base/index.ts +137 -0
- package/src/barretenberg_wasm/barretenberg_wasm_main/factory/browser/index.ts +9 -0
- package/src/barretenberg_wasm/barretenberg_wasm_main/factory/browser/main.worker.ts +6 -0
- package/src/barretenberg_wasm/barretenberg_wasm_main/factory/node/index.ts +19 -0
- package/src/barretenberg_wasm/barretenberg_wasm_main/factory/node/main.worker.ts +10 -0
- package/src/barretenberg_wasm/barretenberg_wasm_main/heap_allocator.ts +72 -0
- package/src/barretenberg_wasm/barretenberg_wasm_main/index.ts +251 -0
- package/src/barretenberg_wasm/barretenberg_wasm_thread/factory/browser/index.ts +9 -0
- package/src/barretenberg_wasm/barretenberg_wasm_thread/factory/browser/thread.worker.ts +6 -0
- package/src/barretenberg_wasm/barretenberg_wasm_thread/factory/node/index.ts +19 -0
- package/src/barretenberg_wasm/barretenberg_wasm_thread/factory/node/thread.worker.ts +12 -0
- package/src/barretenberg_wasm/barretenberg_wasm_thread/index.ts +48 -0
- package/src/barretenberg_wasm/fetch_code/browser/barretenberg-threads.ts +3 -0
- package/src/barretenberg_wasm/fetch_code/browser/barretenberg.ts +3 -0
- package/src/barretenberg_wasm/fetch_code/browser/index.ts +34 -0
- package/src/barretenberg_wasm/fetch_code/index.ts +1 -0
- package/src/barretenberg_wasm/fetch_code/node/index.ts +34 -0
- package/src/barretenberg_wasm/fetch_code/wasm-module.d.ts +4 -0
- package/src/barretenberg_wasm/helpers/browser/index.ts +54 -0
- package/src/barretenberg_wasm/helpers/index.ts +1 -0
- package/src/barretenberg_wasm/helpers/node/index.ts +62 -0
- package/src/barretenberg_wasm/index.test.ts +46 -0
- package/src/barretenberg_wasm/index.ts +21 -1
- package/src/bb_backends/browser/index.ts +50 -0
- package/src/bb_backends/browser/platform.ts +11 -0
- package/src/bb_backends/index.ts +52 -0
- package/src/bb_backends/interface.ts +35 -0
- package/src/bb_backends/node/index.ts +102 -0
- package/src/bb_backends/node/native_pipe.ts +127 -0
- package/src/bb_backends/node/native_shm.ts +195 -0
- package/src/bb_backends/node/native_shm_async.ts +266 -0
- package/src/bb_backends/node/native_socket.ts +326 -0
- package/src/bb_backends/node/platform.ts +151 -0
- package/src/bb_backends/wasm.ts +102 -0
- package/src/bbapi/exception_handling.test.ts +54 -0
- package/src/bbapi_exception.ts +13 -0
- package/src/benchmark/index.ts +26 -0
- package/src/benchmark/timer.ts +45 -0
- package/src/bin/index.ts +14 -0
- package/src/cbind/README.md +1 -0
- package/src/cbind/generate.ts +182 -0
- package/src/cbind/schema_compiler.ts +745 -0
- package/src/crs/browser/cached_net_crs.ts +41 -1
- package/src/crs/browser/index.ts +1 -1
- package/src/crs/index.ts +1 -1
- package/src/crs/net_crs.ts +114 -19
- package/src/crs/node/index.ts +95 -26
- package/src/index.html +1 -1
- package/src/index.ts +43 -5
- package/src/proof/index.ts +94 -0
- package/src/random/browser/index.ts +1 -1
- package/src/retry/index.ts +50 -0
- package/dest/async_map/index.d.ts.map +0 -1
- package/dest/barretenberg-threads.wasm +0 -0
- package/dest/barretenberg.wasm +0 -0
- package/dest/barretenberg_api/blake2s.test.d.ts +0 -2
- package/dest/barretenberg_api/blake2s.test.d.ts.map +0 -1
- package/dest/barretenberg_api/blake2s.test.js +0 -30
- package/dest/barretenberg_api/common.test.d.ts +0 -2
- package/dest/barretenberg_api/common.test.d.ts.map +0 -1
- package/dest/barretenberg_api/common.test.js +0 -18
- package/dest/barretenberg_api/index.d.ts +0 -103
- package/dest/barretenberg_api/index.d.ts.map +0 -1
- package/dest/barretenberg_api/index.js +0 -379
- package/dest/barretenberg_api/pedersen.test.d.ts +0 -2
- package/dest/barretenberg_api/pedersen.test.d.ts.map +0 -1
- package/dest/barretenberg_api/pedersen.test.js +0 -69
- package/dest/barretenberg_api/schnorr.test.d.ts +0 -2
- package/dest/barretenberg_api/schnorr.test.d.ts.map +0 -1
- package/dest/barretenberg_api/schnorr.test.js +0 -113
- package/dest/barretenberg_binder/heap_allocator.d.ts +0 -22
- package/dest/barretenberg_binder/heap_allocator.d.ts.map +0 -1
- package/dest/barretenberg_binder/heap_allocator.js +0 -59
- package/dest/barretenberg_binder/heap_allocator_sync.d.ts +0 -22
- package/dest/barretenberg_binder/heap_allocator_sync.d.ts.map +0 -1
- package/dest/barretenberg_binder/heap_allocator_sync.js +0 -58
- package/dest/barretenberg_binder/index.d.ts +0 -32
- package/dest/barretenberg_binder/index.d.ts.map +0 -1
- package/dest/barretenberg_binder/index.js +0 -73
- package/dest/barretenberg_wasm/barretenberg_wasm.d.ts +0 -50
- package/dest/barretenberg_wasm/barretenberg_wasm.d.ts.map +0 -1
- package/dest/barretenberg_wasm/barretenberg_wasm.js +0 -212
- package/dest/barretenberg_wasm/barretenberg_wasm.test.d.ts +0 -2
- package/dest/barretenberg_wasm/barretenberg_wasm.test.d.ts.map +0 -1
- package/dest/barretenberg_wasm/barretenberg_wasm.test.js +0 -43
- package/dest/barretenberg_wasm/browser/index.d.ts +0 -8
- package/dest/barretenberg_wasm/browser/index.d.ts.map +0 -1
- package/dest/barretenberg_wasm/browser/index.js +0 -26
- package/dest/barretenberg_wasm/browser/worker.d.ts +0 -2
- package/dest/barretenberg_wasm/browser/worker.d.ts.map +0 -1
- package/dest/barretenberg_wasm/browser/worker.js +0 -11
- package/dest/barretenberg_wasm/index.d.ts +0 -2
- package/dest/barretenberg_wasm/index.d.ts.map +0 -1
- package/dest/barretenberg_wasm/index.js +0 -2
- package/dest/barretenberg_wasm/node/index.d.ts +0 -17
- package/dest/barretenberg_wasm/node/index.d.ts.map +0 -1
- package/dest/barretenberg_wasm/node/index.js +0 -40
- package/dest/barretenberg_wasm/node/node_endpoint.d.ts +0 -8
- package/dest/barretenberg_wasm/node/node_endpoint.d.ts.map +0 -1
- package/dest/barretenberg_wasm/node/node_endpoint.js +0 -28
- package/dest/barretenberg_wasm/node/worker.d.ts +0 -2
- package/dest/barretenberg_wasm/node/worker.d.ts.map +0 -1
- package/dest/barretenberg_wasm/node/worker.js +0 -9
- package/dest/barretenberg_wasm.js +0 -2
- package/dest/barretenberg_wasm.js.LICENSE.txt +0 -5
- package/dest/bigint-array/index.d.ts +0 -3
- package/dest/bigint-array/index.d.ts.map +0 -1
- package/dest/bigint-array/index.js +0 -21
- package/dest/bindgen/function_declaration.d.ts +0 -11
- package/dest/bindgen/function_declaration.d.ts.map +0 -1
- package/dest/bindgen/function_declaration.js +0 -2
- package/dest/bindgen/index.d.ts +0 -2
- package/dest/bindgen/index.js +0 -15
- package/dest/bindgen/mappings.d.ts +0 -4
- package/dest/bindgen/mappings.d.ts.map +0 -1
- package/dest/bindgen/mappings.js +0 -63
- package/dest/bindgen/rust.d.ts +0 -2
- package/dest/bindgen/rust.d.ts.map +0 -1
- package/dest/bindgen/rust.js +0 -43
- package/dest/bindgen/to_camel_case.d.ts +0 -2
- package/dest/bindgen/to_camel_case.d.ts.map +0 -1
- package/dest/bindgen/to_camel_case.js +0 -11
- package/dest/bindgen/typescript.d.ts +0 -2
- package/dest/bindgen/typescript.d.ts.map +0 -1
- package/dest/bindgen/typescript.js +0 -80
- package/dest/crs/browser/cached_net_crs.d.ts +0 -25
- package/dest/crs/browser/cached_net_crs.d.ts.map +0 -1
- package/dest/crs/browser/cached_net_crs.js +0 -54
- package/dest/crs/browser/index.d.ts +0 -2
- package/dest/crs/browser/index.d.ts.map +0 -1
- package/dest/crs/browser/index.js +0 -2
- package/dest/crs/index.d.ts +0 -2
- package/dest/crs/index.d.ts.map +0 -1
- package/dest/crs/index.js +0 -2
- package/dest/crs/net_crs.d.ts +0 -36
- package/dest/crs/net_crs.d.ts.map +0 -1
- package/dest/crs/net_crs.js +0 -59
- package/dest/crs/node/ignition_files_crs.d.ts +0 -37
- package/dest/crs/node/ignition_files_crs.d.ts.map +0 -1
- package/dest/crs/node/ignition_files_crs.js +0 -51
- package/dest/crs/node/index.d.ts +0 -21
- package/dest/crs/node/index.d.ts.map +0 -1
- package/dest/crs/node/index.js +0 -54
- package/dest/examples/simple.rawtest.d.ts +0 -2
- package/dest/examples/simple.rawtest.d.ts.map +0 -1
- package/dest/examples/simple.rawtest.js +0 -29
- package/dest/examples/simple.test.d.ts +0 -2
- package/dest/examples/simple.test.d.ts.map +0 -1
- package/dest/examples/simple.test.js +0 -22
- package/dest/factory/index.d.ts +0 -21
- package/dest/factory/index.d.ts.map +0 -1
- package/dest/factory/index.js +0 -34
- package/dest/index.d.ts +0 -6
- package/dest/index.d.ts.map +0 -1
- package/dest/index.html +0 -1
- package/dest/index.js +0 -6
- package/dest/main.d.ts +0 -10
- package/dest/main.d.ts.map +0 -1
- package/dest/main.js +0 -275
- package/dest/random/browser/index.d.ts +0 -2
- package/dest/random/browser/index.d.ts.map +0 -1
- package/dest/random/browser/index.js +0 -31
- package/dest/random/index.d.ts +0 -2
- package/dest/random/index.d.ts.map +0 -1
- package/dest/random/node/index.d.ts +0 -2
- package/dest/random/node/index.d.ts.map +0 -1
- package/dest/random/node/index.js +0 -5
- package/dest/serialize/buffer_reader.d.ts +0 -28
- package/dest/serialize/buffer_reader.d.ts.map +0 -1
- package/dest/serialize/buffer_reader.js +0 -66
- package/dest/serialize/index.d.ts +0 -4
- package/dest/serialize/index.d.ts.map +0 -1
- package/dest/serialize/index.js +0 -4
- package/dest/serialize/output_type.d.ts +0 -11
- package/dest/serialize/output_type.d.ts.map +0 -1
- package/dest/serialize/output_type.js +0 -44
- package/dest/serialize/serialize.d.ts +0 -53
- package/dest/serialize/serialize.d.ts.map +0 -1
- package/dest/serialize/serialize.js +0 -139
- package/dest/simple_test.js +0 -2
- package/dest/simple_test.js.LICENSE.txt +0 -14
- package/dest/types/fields.d.ts +0 -33
- package/dest/types/fields.d.ts.map +0 -1
- package/dest/types/fields.js +0 -86
- package/dest/types/fixed_size_buffer.d.ts +0 -26
- package/dest/types/fixed_size_buffer.d.ts.map +0 -1
- package/dest/types/fixed_size_buffer.js +0 -54
- package/dest/types/index.d.ts +0 -6
- package/dest/types/index.d.ts.map +0 -1
- package/dest/types/index.js +0 -6
- package/dest/types/point.d.ts +0 -17
- package/dest/types/point.d.ts.map +0 -1
- package/dest/types/point.js +0 -32
- package/dest/types/ptr.d.ts +0 -13
- package/dest/types/ptr.d.ts.map +0 -1
- package/dest/types/ptr.js +0 -20
- package/dest/types/raw_buffer.d.ts +0 -3
- package/dest/types/raw_buffer.d.ts.map +0 -1
- package/dest/types/raw_buffer.js +0 -5
- package/src/barretenberg_api/blake2s.test.ts +0 -39
- package/src/barretenberg_api/common.test.ts +0 -21
- package/src/barretenberg_api/index.ts +0 -649
- package/src/barretenberg_api/pedersen.test.ts +0 -84
- package/src/barretenberg_api/schnorr.test.ts +0 -169
- package/src/barretenberg_binder/heap_allocator.ts +0 -62
- package/src/barretenberg_binder/heap_allocator_sync.ts +0 -61
- package/src/barretenberg_binder/index.ts +0 -76
- package/src/barretenberg_wasm/barretenberg_wasm.test.ts +0 -52
- package/src/barretenberg_wasm/barretenberg_wasm.ts +0 -246
- package/src/barretenberg_wasm/browser/index.ts +0 -32
- package/src/barretenberg_wasm/browser/worker.ts +0 -13
- package/src/barretenberg_wasm/node/index.ts +0 -46
- package/src/barretenberg_wasm/node/worker.ts +0 -10
- package/src/bigint-array/index.ts +0 -21
- package/src/bindgen/function_declaration.ts +0 -11
- package/src/bindgen/index.ts +0 -17
- package/src/bindgen/mappings.ts +0 -66
- package/src/bindgen/rust.ts +0 -52
- package/src/bindgen/to_camel_case.ts +0 -10
- package/src/bindgen/typescript.ts +0 -91
- package/src/crs/node/ignition_files_crs.ts +0 -60
- package/src/examples/simple.rawtest.ts +0 -37
- package/src/examples/simple.test.ts +0 -27
- package/src/factory/index.ts +0 -36
- package/src/main.ts +0 -311
- package/src/serialize/buffer_reader.ts +0 -82
- package/src/serialize/index.ts +0 -3
- package/src/serialize/output_type.ts +0 -53
- package/src/serialize/serialize.ts +0 -157
- package/src/types/fields.ts +0 -98
- package/src/types/fixed_size_buffer.ts +0 -59
- package/src/types/index.ts +0 -5
- package/src/types/point.ts +0 -35
- package/src/types/ptr.ts +0 -20
- package/src/types/raw_buffer.ts +0 -3
- /package/src/barretenberg_wasm/{node → helpers/node}/node_endpoint.ts +0 -0
|
@@ -0,0 +1,271 @@
|
|
|
1
|
+
import { Barretenberg, BarretenbergSync } from '../index.js';
|
|
2
|
+
import { BarretenbergWasmMain } from '../barretenberg_wasm/barretenberg_wasm_main/index.js';
|
|
3
|
+
import { fetchModuleAndThreads } from '../barretenberg_wasm/index.js';
|
|
4
|
+
import { BackendType } from './index.js';
|
|
5
|
+
import { Fr } from './testing/fields.js';
|
|
6
|
+
|
|
7
|
+
/**
|
|
8
|
+
* Async API benchmark test: WASM vs Native backends with proper non-blocking I/O
|
|
9
|
+
*
|
|
10
|
+
* This test uses the async Barretenberg API which properly handles:
|
|
11
|
+
* - Non-blocking I/O for native backend (event-based)
|
|
12
|
+
* - Concurrent operations via promises
|
|
13
|
+
* - Better performance for native backend compared to sync API
|
|
14
|
+
*/
|
|
15
|
+
describe('poseidon2Hash benchmark (Async API): WASM vs Native', () => {
|
|
16
|
+
const ITERATIONS = 10000;
|
|
17
|
+
const SIZES = [2, 4, 8];
|
|
18
|
+
|
|
19
|
+
let wasmApi: Barretenberg | null = null;
|
|
20
|
+
let nativeSocketApi: Barretenberg | null = null;
|
|
21
|
+
let nativeShmApi: Barretenberg | null = null;
|
|
22
|
+
let nativeShmSyncApi: BarretenbergSync | null = null;
|
|
23
|
+
let wasm: BarretenbergWasmMain;
|
|
24
|
+
|
|
25
|
+
beforeAll(async () => {
|
|
26
|
+
// Setup direct WASM access for baseline benchmark (always required)
|
|
27
|
+
wasm = new BarretenbergWasmMain();
|
|
28
|
+
const { module } = await fetchModuleAndThreads(1);
|
|
29
|
+
await wasm.init(module, 1);
|
|
30
|
+
|
|
31
|
+
// Setup WASM API
|
|
32
|
+
try {
|
|
33
|
+
wasmApi = await Barretenberg.new({ backend: BackendType.Wasm, threads: 1 });
|
|
34
|
+
} catch (error) {
|
|
35
|
+
console.warn('Failed to initialize WASM backend:', error instanceof Error ? error.message : String(error));
|
|
36
|
+
}
|
|
37
|
+
|
|
38
|
+
// Setup native socket API
|
|
39
|
+
try {
|
|
40
|
+
nativeSocketApi = await Barretenberg.new({ backend: BackendType.NativeUnixSocket, threads: 1 });
|
|
41
|
+
} catch (error) {
|
|
42
|
+
console.warn(
|
|
43
|
+
'Failed to initialize Native Socket backend:',
|
|
44
|
+
error instanceof Error ? error.message : String(error),
|
|
45
|
+
);
|
|
46
|
+
}
|
|
47
|
+
|
|
48
|
+
// Setup native shared memory API (async)
|
|
49
|
+
try {
|
|
50
|
+
nativeShmApi = await Barretenberg.new({ backend: BackendType.NativeSharedMemory, threads: 1 });
|
|
51
|
+
} catch (error) {
|
|
52
|
+
console.warn(
|
|
53
|
+
'Failed to initialize Native Shared Memory (async) backend:',
|
|
54
|
+
error instanceof Error ? error.message : String(error),
|
|
55
|
+
);
|
|
56
|
+
}
|
|
57
|
+
|
|
58
|
+
// Setup native shared memory API (sync)
|
|
59
|
+
try {
|
|
60
|
+
nativeShmSyncApi = await BarretenbergSync.new({ backend: BackendType.NativeSharedMemory, threads: 1 });
|
|
61
|
+
} catch (error) {
|
|
62
|
+
console.warn(
|
|
63
|
+
'Failed to initialize Native Shared Memory (sync) backend:',
|
|
64
|
+
error instanceof Error ? error.message : String(error),
|
|
65
|
+
);
|
|
66
|
+
}
|
|
67
|
+
}, 20000);
|
|
68
|
+
|
|
69
|
+
it.each(SIZES)(
|
|
70
|
+
'benchmark with %p field elements',
|
|
71
|
+
async size => {
|
|
72
|
+
// Generate random inputs
|
|
73
|
+
const inputs = Array(size)
|
|
74
|
+
.fill(0)
|
|
75
|
+
.map(() => Fr.random().toBuffer());
|
|
76
|
+
|
|
77
|
+
// Benchmark 1: WASM (async)
|
|
78
|
+
let wasmTime = 0;
|
|
79
|
+
if (wasmApi) {
|
|
80
|
+
const wasmStart = performance.now();
|
|
81
|
+
for (let i = 0; i < ITERATIONS; i++) {
|
|
82
|
+
await wasmApi.poseidon2Hash({ inputs });
|
|
83
|
+
}
|
|
84
|
+
wasmTime = performance.now() - wasmStart;
|
|
85
|
+
}
|
|
86
|
+
|
|
87
|
+
// Benchmark 2: Native Socket (async with non-blocking I/O)
|
|
88
|
+
let nativeSocketTime = 0;
|
|
89
|
+
if (nativeSocketApi) {
|
|
90
|
+
const nativeSocketStart = performance.now();
|
|
91
|
+
for (let i = 0; i < ITERATIONS; i++) {
|
|
92
|
+
await nativeSocketApi.poseidon2Hash({ inputs });
|
|
93
|
+
}
|
|
94
|
+
nativeSocketTime = performance.now() - nativeSocketStart;
|
|
95
|
+
}
|
|
96
|
+
|
|
97
|
+
// Benchmark 3: Native Socket (async, request pipelined)
|
|
98
|
+
let nativeSocketPipelinedTime = 0;
|
|
99
|
+
if (nativeSocketApi) {
|
|
100
|
+
const nativeSocketPipelinedStart = performance.now();
|
|
101
|
+
// Use promise.all to pipeline requests
|
|
102
|
+
const promises = [];
|
|
103
|
+
for (let i = 0; i < ITERATIONS; i++) {
|
|
104
|
+
promises.push(nativeSocketApi.poseidon2Hash({ inputs }));
|
|
105
|
+
}
|
|
106
|
+
await Promise.all(promises);
|
|
107
|
+
nativeSocketPipelinedTime = performance.now() - nativeSocketPipelinedStart;
|
|
108
|
+
}
|
|
109
|
+
|
|
110
|
+
// Benchmark 4: Native Shared Memory (async)
|
|
111
|
+
let nativeShmTime = 0;
|
|
112
|
+
if (nativeShmApi) {
|
|
113
|
+
const nativeShmStart = performance.now();
|
|
114
|
+
for (let i = 0; i < ITERATIONS; i++) {
|
|
115
|
+
await nativeShmApi.poseidon2Hash({ inputs });
|
|
116
|
+
}
|
|
117
|
+
nativeShmTime = performance.now() - nativeShmStart;
|
|
118
|
+
}
|
|
119
|
+
|
|
120
|
+
// Benchmark 5: Native Shared Memory (async, request pipelined)
|
|
121
|
+
let nativeShmPipelinedTime = 0;
|
|
122
|
+
if (nativeShmApi) {
|
|
123
|
+
const nativeShmPipelinedStart = performance.now();
|
|
124
|
+
// Use promise.all to pipeline requests
|
|
125
|
+
const promises = [];
|
|
126
|
+
for (let i = 0; i < ITERATIONS; i++) {
|
|
127
|
+
promises.push(nativeShmApi.poseidon2Hash({ inputs }));
|
|
128
|
+
}
|
|
129
|
+
await Promise.all(promises);
|
|
130
|
+
nativeShmPipelinedTime = performance.now() - nativeShmPipelinedStart;
|
|
131
|
+
}
|
|
132
|
+
|
|
133
|
+
// Benchmark 6: Native Shared Memory (sync)
|
|
134
|
+
let nativeShmSyncTime = 0;
|
|
135
|
+
if (nativeShmSyncApi) {
|
|
136
|
+
const nativeShmSyncStart = performance.now();
|
|
137
|
+
for (let i = 0; i < ITERATIONS; i++) {
|
|
138
|
+
nativeShmSyncApi.poseidon2Hash({ inputs });
|
|
139
|
+
}
|
|
140
|
+
nativeShmSyncTime = performance.now() - nativeShmSyncStart;
|
|
141
|
+
}
|
|
142
|
+
|
|
143
|
+
// Calculate metrics (all relative to WASM baseline)
|
|
144
|
+
const nativeSocketOverhead = ((nativeSocketTime - wasmTime) / wasmTime) * 100;
|
|
145
|
+
const nativeSocketPipelinedOverhead = ((nativeSocketPipelinedTime - wasmTime) / wasmTime) * 100;
|
|
146
|
+
const nativeShmOverhead = ((nativeShmTime - wasmTime) / wasmTime) * 100;
|
|
147
|
+
const nativeShmPipelinedOverhead = ((nativeShmPipelinedTime - wasmTime) / wasmTime) * 100;
|
|
148
|
+
const nativeShmSyncOverhead = ((nativeShmSyncTime - wasmTime) / wasmTime) * 100;
|
|
149
|
+
|
|
150
|
+
const avgWasmTimeUs = (wasmTime / ITERATIONS) * 1000;
|
|
151
|
+
const avgNativeSocketTimeUs = (nativeSocketTime / ITERATIONS) * 1000;
|
|
152
|
+
const avgNativeSocketPipelinedTimeUs = (nativeSocketPipelinedTime / ITERATIONS) * 1000;
|
|
153
|
+
const avgNativeShmTimeUs = (nativeShmTime / ITERATIONS) * 1000;
|
|
154
|
+
const avgNativeShmPipelinedTimeUs = (nativeShmPipelinedTime / ITERATIONS) * 1000;
|
|
155
|
+
const avgNativeShmSyncTimeUs = (nativeShmSyncTime / ITERATIONS) * 1000;
|
|
156
|
+
|
|
157
|
+
process.stdout.write(
|
|
158
|
+
`┌─ Size ${size.toString().padStart(3)} field elements ───────────────────────────────────────┐\n`,
|
|
159
|
+
);
|
|
160
|
+
const formatOverhead = (overhead: number): string => {
|
|
161
|
+
const sign = overhead >= 0 ? '+' : '-';
|
|
162
|
+
const value = Math.abs(overhead).toFixed(1).padStart(6);
|
|
163
|
+
return `${sign}${value}%`;
|
|
164
|
+
};
|
|
165
|
+
|
|
166
|
+
if (wasmApi) {
|
|
167
|
+
process.stdout.write(
|
|
168
|
+
`│ WASM: ${wasmTime.toFixed(2).padStart(8)}ms (${avgWasmTimeUs.toFixed(2).padStart(7)}µs/call) [baseline] │\n`,
|
|
169
|
+
);
|
|
170
|
+
} else {
|
|
171
|
+
process.stdout.write(`│ WASM: unavailable │\n`);
|
|
172
|
+
}
|
|
173
|
+
|
|
174
|
+
if (nativeSocketApi) {
|
|
175
|
+
process.stdout.write(
|
|
176
|
+
`│ Native Socket: ${nativeSocketTime.toFixed(2).padStart(8)}ms (${avgNativeSocketTimeUs.toFixed(2).padStart(7)}µs/call) ${formatOverhead(nativeSocketOverhead)} │\n`,
|
|
177
|
+
);
|
|
178
|
+
} else {
|
|
179
|
+
process.stdout.write(`│ Native Socket: unavailable │\n`);
|
|
180
|
+
}
|
|
181
|
+
|
|
182
|
+
if (nativeSocketApi) {
|
|
183
|
+
process.stdout.write(
|
|
184
|
+
`│ Native Socket Pipelined: ${nativeSocketPipelinedTime
|
|
185
|
+
.toFixed(2)
|
|
186
|
+
.padStart(8)}ms (${avgNativeSocketPipelinedTimeUs.toFixed(2).padStart(7)}µs/call) ${formatOverhead(
|
|
187
|
+
nativeSocketPipelinedOverhead,
|
|
188
|
+
)} │\n`,
|
|
189
|
+
);
|
|
190
|
+
} else {
|
|
191
|
+
process.stdout.write(`│ Native Socket Pipelined: unavailable │\n`);
|
|
192
|
+
}
|
|
193
|
+
|
|
194
|
+
if (nativeShmApi) {
|
|
195
|
+
process.stdout.write(
|
|
196
|
+
`│ Native Shared: ${nativeShmTime.toFixed(2).padStart(8)}ms (${avgNativeShmTimeUs.toFixed(2).padStart(7)}µs/call) ${formatOverhead(nativeShmOverhead)} │\n`,
|
|
197
|
+
);
|
|
198
|
+
} else {
|
|
199
|
+
process.stdout.write(`│ Native Shared: unavailable │\n`);
|
|
200
|
+
}
|
|
201
|
+
|
|
202
|
+
if (nativeShmApi) {
|
|
203
|
+
process.stdout.write(
|
|
204
|
+
`│ Native Shared Pipelined: ${nativeShmPipelinedTime.toFixed(2).padStart(8)}ms (${avgNativeShmPipelinedTimeUs.toFixed(2).padStart(7)}µs/call) ${formatOverhead(nativeShmPipelinedOverhead)} │\n`,
|
|
205
|
+
);
|
|
206
|
+
} else {
|
|
207
|
+
process.stdout.write(`│ Native Shared Pipelined: unavailable │\n`);
|
|
208
|
+
}
|
|
209
|
+
|
|
210
|
+
if (nativeShmSyncApi) {
|
|
211
|
+
process.stdout.write(
|
|
212
|
+
`│ Native Shared Sync: ${nativeShmSyncTime.toFixed(2).padStart(8)}ms (${avgNativeShmSyncTimeUs.toFixed(2).padStart(7)}µs/call) ${formatOverhead(nativeShmSyncOverhead)} │\n`,
|
|
213
|
+
);
|
|
214
|
+
} else {
|
|
215
|
+
process.stdout.write(`│ Native Shared Sync: unavailable │\n`);
|
|
216
|
+
}
|
|
217
|
+
|
|
218
|
+
process.stdout.write(`└─────────────────────────────────────────────────────────────────┘\n`);
|
|
219
|
+
|
|
220
|
+
const wasmResult = await wasmApi!.poseidon2Hash({ inputs });
|
|
221
|
+
|
|
222
|
+
if (nativeSocketApi) {
|
|
223
|
+
const nativeSocketResult = await nativeSocketApi.poseidon2Hash({ inputs });
|
|
224
|
+
expect(Buffer.from(nativeSocketResult.hash)).toEqual(wasmResult.hash);
|
|
225
|
+
}
|
|
226
|
+
|
|
227
|
+
if (nativeShmApi) {
|
|
228
|
+
const nativeShmResult = await nativeShmApi.poseidon2Hash({ inputs });
|
|
229
|
+
expect(Buffer.from(nativeShmResult.hash)).toEqual(wasmResult.hash);
|
|
230
|
+
}
|
|
231
|
+
|
|
232
|
+
if (nativeShmSyncApi) {
|
|
233
|
+
const nativeShmSyncResult = nativeShmSyncApi.poseidon2Hash({ inputs });
|
|
234
|
+
expect(Buffer.from(nativeShmSyncResult.hash)).toEqual(wasmResult.hash);
|
|
235
|
+
}
|
|
236
|
+
|
|
237
|
+
// Test always passes, this is just for measuring performance
|
|
238
|
+
expect(true).toBe(true);
|
|
239
|
+
},
|
|
240
|
+
10000,
|
|
241
|
+
);
|
|
242
|
+
|
|
243
|
+
const TEST_VECTORS = [1, 2, 3, 5, 10, 50, 100];
|
|
244
|
+
const NUM_RANDOM_TESTS = 10;
|
|
245
|
+
|
|
246
|
+
it.each(TEST_VECTORS)('produces identical results for %p field elements', async size => {
|
|
247
|
+
// Test with multiple random input vectors
|
|
248
|
+
for (let test = 0; test < NUM_RANDOM_TESTS; test++) {
|
|
249
|
+
const inputs = Array(size)
|
|
250
|
+
.fill(0)
|
|
251
|
+
.map(() => Fr.random().toBuffer());
|
|
252
|
+
|
|
253
|
+
const wasmResult = await wasmApi!.poseidon2Hash({ inputs });
|
|
254
|
+
|
|
255
|
+
if (nativeSocketApi) {
|
|
256
|
+
const nativeSocketResult = await nativeSocketApi.poseidon2Hash({ inputs });
|
|
257
|
+
expect(Buffer.from(nativeSocketResult.hash)).toEqual(wasmResult.hash);
|
|
258
|
+
}
|
|
259
|
+
|
|
260
|
+
if (nativeShmApi) {
|
|
261
|
+
const nativeShmResult = await nativeShmApi.poseidon2Hash({ inputs });
|
|
262
|
+
expect(Buffer.from(nativeShmResult.hash)).toEqual(wasmResult.hash);
|
|
263
|
+
}
|
|
264
|
+
|
|
265
|
+
if (nativeShmSyncApi) {
|
|
266
|
+
const nativeShmSyncResult = nativeShmSyncApi.poseidon2Hash({ inputs });
|
|
267
|
+
expect(Buffer.from(nativeShmSyncResult.hash)).toEqual(wasmResult.hash);
|
|
268
|
+
}
|
|
269
|
+
}
|
|
270
|
+
});
|
|
271
|
+
});
|
|
@@ -0,0 +1,39 @@
|
|
|
1
|
+
import { BarretenbergSync } from './index.js';
|
|
2
|
+
import { Timer } from '../benchmark/timer.js';
|
|
3
|
+
import { Fr } from './testing/fields.js';
|
|
4
|
+
|
|
5
|
+
describe('poseidon sync', () => {
|
|
6
|
+
let api: BarretenbergSync;
|
|
7
|
+
|
|
8
|
+
beforeAll(async () => {
|
|
9
|
+
api = await BarretenbergSync.initSingleton();
|
|
10
|
+
});
|
|
11
|
+
|
|
12
|
+
it('poseidonHash', () => {
|
|
13
|
+
const result = api.poseidon2Hash({ inputs: [new Fr(4n).toBuffer(), new Fr(8n).toBuffer()] });
|
|
14
|
+
expect(result).toMatchSnapshot();
|
|
15
|
+
});
|
|
16
|
+
|
|
17
|
+
it('poseidonHash perf test', () => {
|
|
18
|
+
const loops = 1000;
|
|
19
|
+
const fields = Array.from({ length: loops * 2 }).map(() => Fr.random().toBuffer());
|
|
20
|
+
const t = new Timer();
|
|
21
|
+
for (let i = 0; i < loops; ++i) {
|
|
22
|
+
api.poseidon2Hash({ inputs: [fields[i * 2], fields[i * 2 + 1]] });
|
|
23
|
+
}
|
|
24
|
+
const us = t.us() / loops;
|
|
25
|
+
console.log(`Executed ${loops} hashes at an average ${us}us / hash`);
|
|
26
|
+
});
|
|
27
|
+
|
|
28
|
+
// it('poseidonHashes perf test', () => {
|
|
29
|
+
// const loops = 10;
|
|
30
|
+
// const numHashesPerLoop = 1024;
|
|
31
|
+
// const fields = Array.from({ length: numHashesPerLoop * 2 }).map(() => Fr.random());
|
|
32
|
+
// const t = new Timer();
|
|
33
|
+
// for (let i = 0; i < loops; ++i) {
|
|
34
|
+
// api.poseidon2Hashes(fields);
|
|
35
|
+
// }
|
|
36
|
+
// const us = t.us() / (numHashesPerLoop * loops);
|
|
37
|
+
// console.log(`Executed ${numHashesPerLoop * loops} hashes at an average ${us}us / hash`);
|
|
38
|
+
// });
|
|
39
|
+
});
|
|
@@ -0,0 +1,43 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Convert a 32-byte BE Buffer to a BigInt.
|
|
3
|
+
*/
|
|
4
|
+
export function buffer32BytesToBigIntBE(buf: Buffer): bigint {
|
|
5
|
+
return (
|
|
6
|
+
(buf.readBigUInt64BE(0) << 192n) +
|
|
7
|
+
(buf.readBigUInt64BE(8) << 128n) +
|
|
8
|
+
(buf.readBigUInt64BE(16) << 64n) +
|
|
9
|
+
buf.readBigUInt64BE(24)
|
|
10
|
+
);
|
|
11
|
+
}
|
|
12
|
+
|
|
13
|
+
/**
|
|
14
|
+
* Convert a BE Uint8Array to a BigInt.
|
|
15
|
+
*/
|
|
16
|
+
export function uint8ArrayToBigIntBE(bytes: Uint8Array): bigint {
|
|
17
|
+
const buffer = Buffer.from(bytes);
|
|
18
|
+
return buffer32BytesToBigIntBE(buffer);
|
|
19
|
+
}
|
|
20
|
+
|
|
21
|
+
/**
|
|
22
|
+
* Convert a BigInt to a 32-byte BE Buffer.
|
|
23
|
+
*/
|
|
24
|
+
export function bigIntToBufferBE(value: bigint, byteLength = 32): Buffer {
|
|
25
|
+
if (byteLength != 32) {
|
|
26
|
+
throw new Error(
|
|
27
|
+
`Only 32 bytes supported for conversion from bigint to buffer, attempted byte length: ${byteLength}`,
|
|
28
|
+
);
|
|
29
|
+
}
|
|
30
|
+
const buf = Buffer.alloc(byteLength);
|
|
31
|
+
buf.writeBigUInt64BE(value >> 192n, 0);
|
|
32
|
+
buf.writeBigUInt64BE((value >> 128n) & 0xffffffffffffffffn, 8);
|
|
33
|
+
buf.writeBigUInt64BE((value >> 64n) & 0xffffffffffffffffn, 16);
|
|
34
|
+
buf.writeBigUInt64BE(value & 0xffffffffffffffffn, 24);
|
|
35
|
+
return buf;
|
|
36
|
+
}
|
|
37
|
+
|
|
38
|
+
/**
|
|
39
|
+
* Convert a BigInt to a 32-byte BE Uint8Array.
|
|
40
|
+
*/
|
|
41
|
+
export function bigIntToUint8ArrayBE(value: bigint, byteLength = 32): Uint8Array {
|
|
42
|
+
return new Uint8Array(bigIntToBufferBE(value, byteLength));
|
|
43
|
+
}
|
|
@@ -0,0 +1,63 @@
|
|
|
1
|
+
import { randomBytes } from '../../random/index.js';
|
|
2
|
+
import {
|
|
3
|
+
buffer32BytesToBigIntBE,
|
|
4
|
+
uint8ArrayToBigIntBE,
|
|
5
|
+
bigIntToBufferBE,
|
|
6
|
+
bigIntToUint8ArrayBE,
|
|
7
|
+
} from './bigint-buffer.js';
|
|
8
|
+
|
|
9
|
+
export class Fr {
|
|
10
|
+
static ZERO = new Fr(0n);
|
|
11
|
+
static MODULUS = 0x30644e72e131a029b85045b68181585d2833e84879b9709143e1f593f0000001n;
|
|
12
|
+
static MAX_VALUE = this.MODULUS - 1n;
|
|
13
|
+
static SIZE_IN_BYTES = 32;
|
|
14
|
+
value: Uint8Array;
|
|
15
|
+
|
|
16
|
+
constructor(value: Uint8Array | Buffer | bigint) {
|
|
17
|
+
// We convert buffer value to bigint to be able to check it fits within modulus
|
|
18
|
+
const valueBigInt =
|
|
19
|
+
typeof value === 'bigint'
|
|
20
|
+
? value
|
|
21
|
+
: value instanceof Buffer
|
|
22
|
+
? buffer32BytesToBigIntBE(value)
|
|
23
|
+
: uint8ArrayToBigIntBE(value);
|
|
24
|
+
|
|
25
|
+
if (valueBigInt > Fr.MAX_VALUE) {
|
|
26
|
+
throw new Error(`Value 0x${valueBigInt.toString(16)} is greater or equal to field modulus.`);
|
|
27
|
+
}
|
|
28
|
+
|
|
29
|
+
this.value =
|
|
30
|
+
typeof value === 'bigint' ? bigIntToUint8ArrayBE(value) : value instanceof Buffer ? new Uint8Array(value) : value;
|
|
31
|
+
}
|
|
32
|
+
|
|
33
|
+
static random() {
|
|
34
|
+
const r = uint8ArrayToBigIntBE(randomBytes(64)) % Fr.MODULUS;
|
|
35
|
+
return new this(r);
|
|
36
|
+
}
|
|
37
|
+
|
|
38
|
+
toBuffer() {
|
|
39
|
+
return this.value;
|
|
40
|
+
}
|
|
41
|
+
|
|
42
|
+
toString() {
|
|
43
|
+
return '0x' + this.toBuffer().reduce((accumulator, byte) => accumulator + byte.toString(16).padStart(2, '0'), '');
|
|
44
|
+
}
|
|
45
|
+
|
|
46
|
+
equals(rhs: Fr) {
|
|
47
|
+
return this.value.every((v, i) => v === rhs.value[i]);
|
|
48
|
+
}
|
|
49
|
+
|
|
50
|
+
isZero() {
|
|
51
|
+
return this.value.every(v => v === 0);
|
|
52
|
+
}
|
|
53
|
+
|
|
54
|
+
static fromBuffer(value: Uint8Array): Fr {
|
|
55
|
+
return Fr.fromBufferReduce(value);
|
|
56
|
+
}
|
|
57
|
+
|
|
58
|
+
static fromBufferReduce(value: Uint8Array): Fr {
|
|
59
|
+
const valueBigInt = uint8ArrayToBigIntBE(value);
|
|
60
|
+
const reducedValue = valueBigInt % Fr.MODULUS;
|
|
61
|
+
return new Fr(reducedValue);
|
|
62
|
+
}
|
|
63
|
+
}
|
|
@@ -0,0 +1,137 @@
|
|
|
1
|
+
import { randomBytes } from '../../random/index.js';
|
|
2
|
+
|
|
3
|
+
/**
|
|
4
|
+
* Base implementation of BarretenbergWasm.
|
|
5
|
+
* Contains code that is common to the "main thread" implementation and the "child thread" implementation.
|
|
6
|
+
*/
|
|
7
|
+
export class BarretenbergWasmBase {
|
|
8
|
+
protected memStore: { [key: string]: Uint8Array } = {};
|
|
9
|
+
protected memory!: WebAssembly.Memory;
|
|
10
|
+
protected instance!: WebAssembly.Instance;
|
|
11
|
+
protected logger: (msg: string) => void = () => {};
|
|
12
|
+
|
|
13
|
+
protected getImportObj(memory: WebAssembly.Memory) {
|
|
14
|
+
/* eslint-disable camelcase */
|
|
15
|
+
const importObj = {
|
|
16
|
+
// We need to implement a part of the wasi api:
|
|
17
|
+
// https://github.com/WebAssembly/WASI/blob/main/phases/snapshot/docs.md
|
|
18
|
+
// We literally only need to support random_get, everything else is noop implementated in barretenberg.wasm.
|
|
19
|
+
wasi_snapshot_preview1: {
|
|
20
|
+
random_get: (out: any, length: number) => {
|
|
21
|
+
out = out >>> 0;
|
|
22
|
+
const randomData = randomBytes(length);
|
|
23
|
+
const mem = this.getMemory();
|
|
24
|
+
mem.set(randomData, out);
|
|
25
|
+
},
|
|
26
|
+
clock_time_get: (a1: number, a2: number, out: number) => {
|
|
27
|
+
out = out >>> 0;
|
|
28
|
+
const ts = BigInt(new Date().getTime()) * 1000000n;
|
|
29
|
+
const view = new DataView(this.getMemory().buffer);
|
|
30
|
+
view.setBigUint64(out, ts, true);
|
|
31
|
+
},
|
|
32
|
+
proc_exit: () => {
|
|
33
|
+
this.logger('PANIC: proc_exit was called.');
|
|
34
|
+
throw new Error();
|
|
35
|
+
},
|
|
36
|
+
},
|
|
37
|
+
|
|
38
|
+
// These are functions implementations for imports we've defined are needed.
|
|
39
|
+
// The native C++ build defines these in a module called "env". We must implement TypeScript versions here.
|
|
40
|
+
env: {
|
|
41
|
+
/**
|
|
42
|
+
* The 'info' call we use for logging in C++, calls this under the hood.
|
|
43
|
+
* The native code will just print to std:err (to avoid std::cout which is used for IPC).
|
|
44
|
+
* Here we just emit the log line for the client to decide what to do with.
|
|
45
|
+
*/
|
|
46
|
+
logstr: (addr: number) => {
|
|
47
|
+
const str = this.stringFromAddress(addr);
|
|
48
|
+
const m = this.getMemory();
|
|
49
|
+
const str2 = `${str} (mem: ${(m.length / (1024 * 1024)).toFixed(2)}MiB)`;
|
|
50
|
+
this.logger(str2);
|
|
51
|
+
},
|
|
52
|
+
|
|
53
|
+
throw_or_abort_impl: (addr: number) => {
|
|
54
|
+
const str = this.stringFromAddress(addr);
|
|
55
|
+
throw new Error(str);
|
|
56
|
+
},
|
|
57
|
+
|
|
58
|
+
get_data: (keyAddr: number, outBufAddr: number) => {
|
|
59
|
+
const key = this.stringFromAddress(keyAddr);
|
|
60
|
+
outBufAddr = outBufAddr >>> 0;
|
|
61
|
+
const data = this.memStore[key];
|
|
62
|
+
if (!data) {
|
|
63
|
+
this.logger(`get_data miss ${key}`);
|
|
64
|
+
return;
|
|
65
|
+
}
|
|
66
|
+
// this.logger(`get_data hit ${key} size: ${data.length} dest: ${outBufAddr}`);
|
|
67
|
+
// this.logger(Buffer.from(data.slice(0, 64)).toString('hex'));
|
|
68
|
+
this.writeMemory(outBufAddr, data);
|
|
69
|
+
},
|
|
70
|
+
|
|
71
|
+
set_data: (keyAddr: number, dataAddr: number, dataLength: number) => {
|
|
72
|
+
const key = this.stringFromAddress(keyAddr);
|
|
73
|
+
dataAddr = dataAddr >>> 0;
|
|
74
|
+
this.memStore[key] = this.getMemorySlice(dataAddr, dataAddr + dataLength);
|
|
75
|
+
// this.logger(`set_data: ${key} length: ${dataLength}`);
|
|
76
|
+
},
|
|
77
|
+
|
|
78
|
+
memory,
|
|
79
|
+
},
|
|
80
|
+
};
|
|
81
|
+
/* eslint-enable camelcase */
|
|
82
|
+
|
|
83
|
+
return importObj;
|
|
84
|
+
}
|
|
85
|
+
|
|
86
|
+
public exports(): any {
|
|
87
|
+
return this.instance.exports;
|
|
88
|
+
}
|
|
89
|
+
|
|
90
|
+
/**
|
|
91
|
+
* When returning values from the WASM, use >>> operator to convert signed representation to unsigned representation.
|
|
92
|
+
*/
|
|
93
|
+
public call(name: string, ...args: any) {
|
|
94
|
+
if (!this.exports()[name]) {
|
|
95
|
+
throw new Error(`WASM function ${name} not found.`);
|
|
96
|
+
}
|
|
97
|
+
try {
|
|
98
|
+
return this.exports()[name](...args) >>> 0;
|
|
99
|
+
} catch (err: any) {
|
|
100
|
+
const message = `WASM function ${name} aborted, error: ${err}`;
|
|
101
|
+
this.logger(message);
|
|
102
|
+
this.logger(err.stack);
|
|
103
|
+
throw err;
|
|
104
|
+
}
|
|
105
|
+
}
|
|
106
|
+
|
|
107
|
+
public memSize() {
|
|
108
|
+
return this.getMemory().length;
|
|
109
|
+
}
|
|
110
|
+
|
|
111
|
+
/**
|
|
112
|
+
* Returns a copy of the data, not a view.
|
|
113
|
+
*/
|
|
114
|
+
public getMemorySlice(start: number, end: number) {
|
|
115
|
+
return this.getMemory().subarray(start, end).slice();
|
|
116
|
+
}
|
|
117
|
+
|
|
118
|
+
public writeMemory(offset: number, arr: Uint8Array) {
|
|
119
|
+
const mem = this.getMemory();
|
|
120
|
+
mem.set(arr, offset);
|
|
121
|
+
}
|
|
122
|
+
|
|
123
|
+
public getMemory() {
|
|
124
|
+
return new Uint8Array(this.memory.buffer);
|
|
125
|
+
}
|
|
126
|
+
|
|
127
|
+
// PRIVATE METHODS
|
|
128
|
+
|
|
129
|
+
private stringFromAddress(addr: number) {
|
|
130
|
+
addr = addr >>> 0;
|
|
131
|
+
const m = this.getMemory();
|
|
132
|
+
let i = addr;
|
|
133
|
+
for (; m[i] !== 0; ++i);
|
|
134
|
+
const textDecoder = new TextDecoder('ascii');
|
|
135
|
+
return textDecoder.decode(m.slice(addr, i));
|
|
136
|
+
}
|
|
137
|
+
}
|
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
import { readinessListener } from '../../../helpers/browser/index.js';
|
|
2
|
+
|
|
3
|
+
export async function createMainWorker() {
|
|
4
|
+
// eslint-disable-next-line @typescript-eslint/ban-ts-comment
|
|
5
|
+
// @ts-ignore
|
|
6
|
+
const worker = new Worker(new URL('./main.worker.js', import.meta.url), { type: 'module' });
|
|
7
|
+
await new Promise<void>(resolve => readinessListener(worker, resolve));
|
|
8
|
+
return worker;
|
|
9
|
+
}
|
|
@@ -0,0 +1,19 @@
|
|
|
1
|
+
import { Worker } from 'worker_threads';
|
|
2
|
+
import { dirname } from 'path';
|
|
3
|
+
import { fileURLToPath } from 'url';
|
|
4
|
+
|
|
5
|
+
function getCurrentDir() {
|
|
6
|
+
if (typeof __dirname !== 'undefined') {
|
|
7
|
+
return __dirname;
|
|
8
|
+
} else {
|
|
9
|
+
// eslint-disable-next-line @typescript-eslint/ban-ts-comment
|
|
10
|
+
// @ts-ignore
|
|
11
|
+
return dirname(fileURLToPath(import.meta.url));
|
|
12
|
+
}
|
|
13
|
+
}
|
|
14
|
+
|
|
15
|
+
export function createMainWorker() {
|
|
16
|
+
const __dirname = getCurrentDir();
|
|
17
|
+
const worker = new Worker(__dirname + `/main.worker.js`);
|
|
18
|
+
return Promise.resolve(worker);
|
|
19
|
+
}
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
import { parentPort } from 'worker_threads';
|
|
2
|
+
import { expose } from 'comlink';
|
|
3
|
+
import { BarretenbergWasmMain } from '../../index.js';
|
|
4
|
+
import { nodeEndpoint } from '../../../helpers/node/node_endpoint.js';
|
|
5
|
+
|
|
6
|
+
if (!parentPort) {
|
|
7
|
+
throw new Error('No parentPort');
|
|
8
|
+
}
|
|
9
|
+
|
|
10
|
+
expose(new BarretenbergWasmMain(), nodeEndpoint(parentPort));
|
|
@@ -0,0 +1,72 @@
|
|
|
1
|
+
import { type BarretenbergWasmMain } from './index.js';
|
|
2
|
+
|
|
3
|
+
/**
|
|
4
|
+
* Keeps track of heap allocations so they can be easily freed.
|
|
5
|
+
* The WASM memory layout has 1024 bytes of unused "scratch" space at the start (addresses 0-1023).
|
|
6
|
+
* We can leverage this for IO rather than making expensive bb_malloc bb_free calls.
|
|
7
|
+
* Heap allocations will be created for input/output args that don't fit into the scratch space.
|
|
8
|
+
* Input scratch grows UP from 0, output scratch grows DOWN from 1024, meeting in the middle.
|
|
9
|
+
* This maximizes space utilization while preventing overlap.
|
|
10
|
+
*/
|
|
11
|
+
export class HeapAllocator {
|
|
12
|
+
private allocs: number[] = [];
|
|
13
|
+
private inScratchPtr = 0; // Next input starts here, grows UP
|
|
14
|
+
private outScratchPtr = 1024; // Next output ends here, grows DOWN
|
|
15
|
+
|
|
16
|
+
constructor(private wasm: BarretenbergWasmMain) {}
|
|
17
|
+
|
|
18
|
+
getInputs(buffers: (Uint8Array | number)[]) {
|
|
19
|
+
return buffers.map(bufOrNum => {
|
|
20
|
+
if (typeof bufOrNum === 'object') {
|
|
21
|
+
const size = bufOrNum.length;
|
|
22
|
+
// Check if there's room in scratch space (inputs grow up, outputs grow down)
|
|
23
|
+
if (this.inScratchPtr + size <= this.outScratchPtr) {
|
|
24
|
+
const ptr = this.inScratchPtr;
|
|
25
|
+
this.inScratchPtr += size; // Grow UP
|
|
26
|
+
this.wasm.writeMemory(ptr, bufOrNum);
|
|
27
|
+
return ptr;
|
|
28
|
+
} else {
|
|
29
|
+
// Fall back to heap allocation
|
|
30
|
+
const ptr = this.wasm.call('bbmalloc', size);
|
|
31
|
+
this.wasm.writeMemory(ptr, bufOrNum);
|
|
32
|
+
this.allocs.push(ptr);
|
|
33
|
+
return ptr;
|
|
34
|
+
}
|
|
35
|
+
} else {
|
|
36
|
+
return bufOrNum;
|
|
37
|
+
}
|
|
38
|
+
});
|
|
39
|
+
}
|
|
40
|
+
|
|
41
|
+
getOutputPtrs(outLens: (number | undefined)[]) {
|
|
42
|
+
return outLens.map(len => {
|
|
43
|
+
// If the obj is variable length, we need a 4 byte ptr to write the serialized data address to.
|
|
44
|
+
// WARNING: 4 only works with WASM as it has 32 bit memory.
|
|
45
|
+
const size = len || 4;
|
|
46
|
+
|
|
47
|
+
// Check if there's room in scratch space (inputs grow up, outputs grow down)
|
|
48
|
+
if (this.inScratchPtr + size <= this.outScratchPtr) {
|
|
49
|
+
this.outScratchPtr -= size; // Grow DOWN
|
|
50
|
+
return this.outScratchPtr;
|
|
51
|
+
} else {
|
|
52
|
+
// Fall back to heap allocation
|
|
53
|
+
const ptr = this.wasm.call('bbmalloc', size);
|
|
54
|
+
this.allocs.push(ptr);
|
|
55
|
+
return ptr;
|
|
56
|
+
}
|
|
57
|
+
});
|
|
58
|
+
}
|
|
59
|
+
|
|
60
|
+
addOutputPtr(ptr: number) {
|
|
61
|
+
// Only add to dealloc list if it's a heap allocation (not in scratch space 0-1023)
|
|
62
|
+
if (ptr >= 1024) {
|
|
63
|
+
this.allocs.push(ptr);
|
|
64
|
+
}
|
|
65
|
+
}
|
|
66
|
+
|
|
67
|
+
freeAll() {
|
|
68
|
+
for (const ptr of this.allocs) {
|
|
69
|
+
this.wasm.call('bbfree', ptr);
|
|
70
|
+
}
|
|
71
|
+
}
|
|
72
|
+
}
|