@aztec/foundation 0.0.0-test.1 → 0.0.1-commit.1142ef1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (685) hide show
  1. package/dest/array/array.d.ts +6 -9
  2. package/dest/array/array.d.ts.map +1 -1
  3. package/dest/array/array.js +11 -11
  4. package/dest/array/index.d.ts +2 -1
  5. package/dest/array/index.d.ts.map +1 -1
  6. package/dest/array/index.js +1 -0
  7. package/dest/array/sorted_array.d.ts +10 -0
  8. package/dest/array/sorted_array.d.ts.map +1 -0
  9. package/dest/array/sorted_array.js +106 -0
  10. package/dest/async-map/index.d.ts +1 -1
  11. package/dest/async-pool/index.d.ts +1 -1
  12. package/dest/async-pool/index.d.ts.map +1 -1
  13. package/dest/async-pool/index.js +1 -0
  14. package/dest/bigint/index.d.ts +7 -0
  15. package/dest/bigint/index.d.ts.map +1 -0
  16. package/dest/bigint/index.js +15 -0
  17. package/dest/bigint-buffer/index.d.ts +1 -3
  18. package/dest/bigint-buffer/index.d.ts.map +1 -1
  19. package/dest/branded-types/block_number.d.ts +53 -0
  20. package/dest/branded-types/block_number.d.ts.map +1 -0
  21. package/dest/branded-types/block_number.js +75 -0
  22. package/dest/branded-types/checkpoint_number.d.ts +54 -0
  23. package/dest/branded-types/checkpoint_number.d.ts.map +1 -0
  24. package/dest/branded-types/checkpoint_number.js +77 -0
  25. package/dest/branded-types/epoch.d.ts +42 -0
  26. package/dest/branded-types/epoch.d.ts.map +1 -0
  27. package/dest/branded-types/epoch.js +59 -0
  28. package/dest/branded-types/index.d.ts +6 -0
  29. package/dest/branded-types/index.d.ts.map +1 -0
  30. package/dest/branded-types/index.js +4 -0
  31. package/dest/branded-types/slot.d.ts +42 -0
  32. package/dest/branded-types/slot.d.ts.map +1 -0
  33. package/dest/branded-types/slot.js +59 -0
  34. package/dest/branded-types/types.d.ts +5 -0
  35. package/dest/branded-types/types.d.ts.map +1 -0
  36. package/dest/branded-types/types.js +1 -0
  37. package/dest/buffer/buffer16.d.ts +77 -0
  38. package/dest/buffer/buffer16.d.ts.map +1 -0
  39. package/dest/buffer/buffer16.js +102 -0
  40. package/dest/buffer/buffer32.d.ts +5 -12
  41. package/dest/buffer/buffer32.d.ts.map +1 -1
  42. package/dest/buffer/buffer32.js +9 -7
  43. package/dest/buffer/index.d.ts +2 -1
  44. package/dest/buffer/index.d.ts.map +1 -1
  45. package/dest/buffer/index.js +1 -0
  46. package/dest/collection/array.d.ts +17 -4
  47. package/dest/collection/array.d.ts.map +1 -1
  48. package/dest/collection/array.js +57 -3
  49. package/dest/collection/index.d.ts +1 -1
  50. package/dest/collection/object.d.ts +17 -1
  51. package/dest/collection/object.d.ts.map +1 -1
  52. package/dest/collection/object.js +25 -0
  53. package/dest/committable/committable.d.ts +1 -1
  54. package/dest/committable/committable.d.ts.map +1 -1
  55. package/dest/committable/index.d.ts +1 -1
  56. package/dest/config/env_var.d.ts +2 -2
  57. package/dest/config/env_var.d.ts.map +1 -1
  58. package/dest/config/index.d.ts +58 -4
  59. package/dest/config/index.d.ts.map +1 -1
  60. package/dest/config/index.js +129 -12
  61. package/dest/config/network_config.d.ts +54 -0
  62. package/dest/config/network_config.d.ts.map +1 -0
  63. package/dest/config/network_config.js +11 -0
  64. package/dest/config/network_name.d.ts +3 -0
  65. package/dest/config/network_name.d.ts.map +1 -0
  66. package/dest/config/network_name.js +19 -0
  67. package/dest/config/parse-env.d.ts +3 -0
  68. package/dest/config/parse-env.d.ts.map +1 -0
  69. package/dest/config/parse-env.js +7 -0
  70. package/dest/config/secret_value.d.ts +28 -0
  71. package/dest/config/secret_value.d.ts.map +1 -0
  72. package/dest/config/secret_value.js +36 -0
  73. package/dest/crypto/aes128/index.d.ts +3 -5
  74. package/dest/crypto/aes128/index.d.ts.map +1 -1
  75. package/dest/crypto/aes128/index.js +19 -6
  76. package/dest/crypto/bls/bn254_keystore.d.ts +296 -0
  77. package/dest/crypto/bls/bn254_keystore.d.ts.map +1 -0
  78. package/dest/crypto/bls/bn254_keystore.js +218 -0
  79. package/dest/crypto/bls/index.d.ts +13 -0
  80. package/dest/crypto/bls/index.d.ts.map +1 -0
  81. package/dest/crypto/bls/index.js +87 -0
  82. package/dest/crypto/bn254/index.d.ts +39 -0
  83. package/dest/crypto/bn254/index.d.ts.map +1 -0
  84. package/dest/crypto/bn254/index.js +56 -0
  85. package/dest/crypto/ecdsa/index.d.ts +3 -3
  86. package/dest/crypto/ecdsa/index.d.ts.map +1 -1
  87. package/dest/crypto/ecdsa/index.js +62 -48
  88. package/dest/crypto/ecdsa/signature.d.ts +3 -14
  89. package/dest/crypto/ecdsa/signature.d.ts.map +1 -1
  90. package/dest/crypto/ecdsa/signature.js +2 -2
  91. package/dest/crypto/grumpkin/index.d.ts +10 -15
  92. package/dest/crypto/grumpkin/index.d.ts.map +1 -1
  93. package/dest/crypto/grumpkin/index.js +61 -55
  94. package/dest/crypto/keccak/index.d.ts +3 -5
  95. package/dest/crypto/keccak/index.d.ts.map +1 -1
  96. package/dest/crypto/keys/index.d.ts +2 -4
  97. package/dest/crypto/keys/index.d.ts.map +1 -1
  98. package/dest/crypto/keys/index.js +8 -5
  99. package/dest/crypto/pedersen/index.d.ts +1 -1
  100. package/dest/crypto/pedersen/pedersen.noble.d.ts +3 -5
  101. package/dest/crypto/pedersen/pedersen.noble.d.ts.map +1 -1
  102. package/dest/crypto/pedersen/pedersen.wasm.d.ts +4 -6
  103. package/dest/crypto/pedersen/pedersen.wasm.d.ts.map +1 -1
  104. package/dest/crypto/pedersen/pedersen.wasm.js +24 -14
  105. package/dest/crypto/poseidon/index.d.ts +2 -4
  106. package/dest/crypto/poseidon/index.d.ts.map +1 -1
  107. package/dest/crypto/poseidon/index.js +33 -18
  108. package/dest/crypto/random/index.d.ts +2 -4
  109. package/dest/crypto/random/index.d.ts.map +1 -1
  110. package/dest/crypto/random/index.js +2 -34
  111. package/dest/crypto/random/randomness_singleton.d.ts +2 -4
  112. package/dest/crypto/random/randomness_singleton.d.ts.map +1 -1
  113. package/dest/crypto/random/randomness_singleton.js +3 -3
  114. package/dest/crypto/schnorr/index.d.ts +3 -2
  115. package/dest/crypto/schnorr/index.d.ts.map +1 -1
  116. package/dest/crypto/schnorr/index.js +30 -38
  117. package/dest/crypto/schnorr/signature.d.ts +5 -7
  118. package/dest/crypto/schnorr/signature.d.ts.map +1 -1
  119. package/dest/crypto/schnorr/signature.js +2 -2
  120. package/dest/crypto/secp256k1/index.d.ts +5 -7
  121. package/dest/crypto/secp256k1/index.d.ts.map +1 -1
  122. package/dest/crypto/secp256k1/index.js +23 -18
  123. package/dest/crypto/secp256k1-signer/index.d.ts +1 -1
  124. package/dest/crypto/secp256k1-signer/secp256k1_signer.d.ts +1 -1
  125. package/dest/crypto/secp256k1-signer/secp256k1_signer.d.ts.map +1 -1
  126. package/dest/crypto/secp256k1-signer/utils.d.ts +56 -5
  127. package/dest/crypto/secp256k1-signer/utils.d.ts.map +1 -1
  128. package/dest/crypto/secp256k1-signer/utils.js +92 -6
  129. package/dest/crypto/serialize.d.ts +5 -7
  130. package/dest/crypto/serialize.d.ts.map +1 -1
  131. package/dest/crypto/sha256/index.d.ts +23 -6
  132. package/dest/crypto/sha256/index.d.ts.map +1 -1
  133. package/dest/crypto/sha256/index.js +43 -1
  134. package/dest/crypto/sha512/index.d.ts +3 -5
  135. package/dest/crypto/sha512/index.d.ts.map +1 -1
  136. package/dest/crypto/sha512/index.js +1 -1
  137. package/dest/crypto/signature/index.d.ts +2 -4
  138. package/dest/crypto/signature/index.d.ts.map +1 -1
  139. package/dest/crypto/sync/index.d.ts +1 -1
  140. package/dest/crypto/sync/index.js +1 -1
  141. package/dest/crypto/sync/pedersen/index.d.ts +4 -6
  142. package/dest/crypto/sync/pedersen/index.d.ts.map +1 -1
  143. package/dest/crypto/sync/pedersen/index.js +18 -11
  144. package/dest/crypto/sync/poseidon/index.d.ts +2 -4
  145. package/dest/crypto/sync/poseidon/index.d.ts.map +1 -1
  146. package/dest/crypto/sync/poseidon/index.js +28 -13
  147. package/dest/curves/bls12/field.d.ts +148 -0
  148. package/dest/curves/bls12/field.d.ts.map +1 -0
  149. package/dest/curves/bls12/field.js +362 -0
  150. package/dest/curves/bls12/index.d.ts +3 -0
  151. package/dest/curves/bls12/index.d.ts.map +1 -0
  152. package/dest/curves/bls12/index.js +2 -0
  153. package/dest/curves/bls12/point.d.ts +220 -0
  154. package/dest/curves/bls12/point.d.ts.map +1 -0
  155. package/dest/curves/bls12/point.js +400 -0
  156. package/dest/curves/bn254/field.d.ts +180 -0
  157. package/dest/curves/bn254/field.d.ts.map +1 -0
  158. package/dest/{fields/fields.js → curves/bn254/field.js} +90 -62
  159. package/dest/curves/bn254/index.d.ts +3 -0
  160. package/dest/curves/bn254/index.d.ts.map +1 -0
  161. package/dest/curves/bn254/index.js +2 -0
  162. package/dest/curves/bn254/point.d.ts +54 -0
  163. package/dest/curves/bn254/point.d.ts.map +1 -0
  164. package/dest/curves/bn254/point.js +143 -0
  165. package/dest/curves/grumpkin/index.d.ts +10 -0
  166. package/dest/curves/grumpkin/index.d.ts.map +1 -0
  167. package/dest/curves/grumpkin/index.js +3 -0
  168. package/dest/{fields → curves/grumpkin}/point.d.ts +15 -17
  169. package/dest/curves/grumpkin/point.d.ts.map +1 -0
  170. package/dest/{fields → curves/grumpkin}/point.js +27 -10
  171. package/dest/decorators/index.d.ts +1 -1
  172. package/dest/decorators/memoize.d.ts +1 -1
  173. package/dest/decorators/memoize.d.ts.map +1 -1
  174. package/dest/error/index.d.ts +4 -4
  175. package/dest/error/index.d.ts.map +1 -1
  176. package/dest/eth-address/index.d.ts +18 -9
  177. package/dest/eth-address/index.d.ts.map +1 -1
  178. package/dest/eth-address/index.js +31 -2
  179. package/dest/eth-signature/eth_signature.d.ts +17 -18
  180. package/dest/eth-signature/eth_signature.d.ts.map +1 -1
  181. package/dest/eth-signature/eth_signature.js +31 -17
  182. package/dest/eth-signature/index.d.ts +1 -1
  183. package/dest/fs/index.d.ts +2 -1
  184. package/dest/fs/index.d.ts.map +1 -1
  185. package/dest/fs/index.js +1 -0
  186. package/dest/fs/run_in_dir.d.ts +1 -1
  187. package/dest/fs/try_rm_dir.d.ts +3 -0
  188. package/dest/fs/try_rm_dir.d.ts.map +1 -0
  189. package/dest/fs/try_rm_dir.js +16 -0
  190. package/dest/iterable/all.d.ts +1 -1
  191. package/dest/iterable/filter.d.ts +1 -1
  192. package/dest/iterable/filter.js +1 -1
  193. package/dest/iterable/index.d.ts +1 -1
  194. package/dest/iterable/isAsyncIt.d.ts +1 -1
  195. package/dest/iterable/map.d.ts +1 -1
  196. package/dest/iterable/map.js +1 -1
  197. package/dest/iterable/peek.d.ts +1 -1
  198. package/dest/iterable/sort.d.ts +1 -1
  199. package/dest/iterable/take.d.ts +1 -1
  200. package/dest/iterable/toArray.d.ts +1 -1
  201. package/dest/iterator/filter.d.ts +3 -0
  202. package/dest/iterator/filter.d.ts.map +1 -0
  203. package/dest/iterator/filter.js +7 -0
  204. package/dest/iterator/index.d.ts +2 -0
  205. package/dest/iterator/index.d.ts.map +1 -0
  206. package/dest/iterator/index.js +1 -0
  207. package/dest/jest/env.js +48 -0
  208. package/dest/jest/setupAfterEnv.js +3 -0
  209. package/dest/json-rpc/client/fetch.d.ts +3 -3
  210. package/dest/json-rpc/client/fetch.d.ts.map +1 -1
  211. package/dest/json-rpc/client/fetch.js +16 -30
  212. package/dest/json-rpc/client/index.d.ts +1 -1
  213. package/dest/json-rpc/client/safe_json_rpc_client.d.ts +10 -4
  214. package/dest/json-rpc/client/safe_json_rpc_client.d.ts.map +1 -1
  215. package/dest/json-rpc/client/safe_json_rpc_client.js +173 -13
  216. package/dest/json-rpc/client/undici.d.ts +1 -1
  217. package/dest/json-rpc/client/undici.d.ts.map +1 -1
  218. package/dest/json-rpc/client/undici.js +6 -7
  219. package/dest/json-rpc/convert.d.ts +3 -10
  220. package/dest/json-rpc/convert.d.ts.map +1 -1
  221. package/dest/json-rpc/convert.js +1 -9
  222. package/dest/json-rpc/errors.d.ts +4 -0
  223. package/dest/json-rpc/errors.d.ts.map +1 -0
  224. package/dest/json-rpc/errors.js +6 -0
  225. package/dest/json-rpc/fixtures/class_a.d.ts +4 -2
  226. package/dest/json-rpc/fixtures/class_a.d.ts.map +1 -1
  227. package/dest/json-rpc/fixtures/class_b.d.ts +4 -2
  228. package/dest/json-rpc/fixtures/class_b.d.ts.map +1 -1
  229. package/dest/json-rpc/fixtures/test_state.d.ts +1 -1
  230. package/dest/json-rpc/fixtures/test_state.d.ts.map +1 -1
  231. package/dest/json-rpc/index.d.ts +3 -2
  232. package/dest/json-rpc/index.d.ts.map +1 -1
  233. package/dest/json-rpc/index.js +2 -1
  234. package/dest/json-rpc/js_utils.d.ts +1 -1
  235. package/dest/json-rpc/js_utils.d.ts.map +1 -1
  236. package/dest/json-rpc/server/index.d.ts +1 -1
  237. package/dest/json-rpc/server/safe_json_rpc_server.d.ts +22 -23
  238. package/dest/json-rpc/server/safe_json_rpc_server.d.ts.map +1 -1
  239. package/dest/json-rpc/server/safe_json_rpc_server.js +161 -56
  240. package/dest/json-rpc/test/index.d.ts +1 -1
  241. package/dest/json-rpc/test/integration.d.ts +2 -3
  242. package/dest/json-rpc/test/integration.d.ts.map +1 -1
  243. package/dest/log/console.d.ts +1 -1
  244. package/dest/log/console.d.ts.map +1 -1
  245. package/dest/log/gcloud-logger-config.d.ts +1 -2
  246. package/dest/log/gcloud-logger-config.d.ts.map +1 -1
  247. package/dest/log/gcloud-logger-config.js +1 -9
  248. package/dest/log/index.d.ts +5 -5
  249. package/dest/log/index.d.ts.map +1 -1
  250. package/dest/log/index.js +4 -4
  251. package/dest/log/libp2p_logger.d.ts +1 -1
  252. package/dest/log/libp2p_logger.js +13 -2
  253. package/dest/log/log-filters.d.ts +1 -1
  254. package/dest/log/log-levels.d.ts +1 -1
  255. package/dest/log/log_fn.d.ts +2 -2
  256. package/dest/log/log_fn.d.ts.map +1 -1
  257. package/dest/log/noir_debug_log_util.d.ts +14 -0
  258. package/dest/log/noir_debug_log_util.d.ts.map +1 -0
  259. package/dest/log/noir_debug_log_util.js +14 -0
  260. package/dest/log/pino-logger.d.ts +4 -4
  261. package/dest/log/pino-logger.d.ts.map +1 -1
  262. package/dest/log/pino-logger.js +29 -3
  263. package/dest/message/index.d.ts +1 -1
  264. package/dest/message/index.d.ts.map +1 -1
  265. package/dest/mutex/index.d.ts +1 -1
  266. package/dest/mutex/index.d.ts.map +1 -1
  267. package/dest/mutex/mutex_database.d.ts +1 -1
  268. package/dest/mutex/mutex_database.d.ts.map +1 -1
  269. package/dest/noir/index.d.ts +1 -1
  270. package/dest/noir/noir_package_config.d.ts +9 -9
  271. package/dest/number/index.d.ts +3 -0
  272. package/dest/number/index.d.ts.map +1 -0
  273. package/dest/number/index.js +12 -0
  274. package/dest/profiler/index.d.ts +2 -0
  275. package/dest/profiler/index.d.ts.map +1 -0
  276. package/dest/profiler/index.js +1 -0
  277. package/dest/profiler/profiler.d.ts +8 -0
  278. package/dest/profiler/profiler.d.ts.map +1 -0
  279. package/dest/profiler/profiler.js +97 -0
  280. package/dest/promise/index.d.ts +1 -1
  281. package/dest/promise/running-promise.d.ts +2 -2
  282. package/dest/promise/running-promise.d.ts.map +1 -1
  283. package/dest/promise/running-promise.js +2 -2
  284. package/dest/promise/utils.d.ts +1 -1
  285. package/dest/queue/base_memory_queue.d.ts +1 -1
  286. package/dest/queue/base_memory_queue.d.ts.map +1 -1
  287. package/dest/queue/batch_queue.d.ts +2 -2
  288. package/dest/queue/batch_queue.d.ts.map +1 -1
  289. package/dest/queue/batch_queue.js +1 -1
  290. package/dest/queue/bounded_serial_queue.d.ts +1 -1
  291. package/dest/queue/bounded_serial_queue.d.ts.map +1 -1
  292. package/dest/queue/fifo_memory_queue.d.ts +1 -1
  293. package/dest/queue/fifo_memory_queue.d.ts.map +1 -1
  294. package/dest/queue/index.d.ts +1 -1
  295. package/dest/queue/priority_memory_queue.d.ts +1 -1
  296. package/dest/queue/priority_memory_queue.d.ts.map +1 -1
  297. package/dest/queue/priority_queue.d.ts +1 -1
  298. package/dest/queue/priority_queue.d.ts.map +1 -1
  299. package/dest/queue/semaphore.d.ts +1 -1
  300. package/dest/queue/semaphore.d.ts.map +1 -1
  301. package/dest/queue/serial_queue.d.ts +3 -3
  302. package/dest/queue/serial_queue.d.ts.map +1 -1
  303. package/dest/queue/serial_queue.js +7 -5
  304. package/dest/retry/index.d.ts +4 -3
  305. package/dest/retry/index.d.ts.map +1 -1
  306. package/dest/retry/index.js +2 -2
  307. package/dest/running-promise/index.d.ts +1 -1
  308. package/dest/schemas/api.d.ts +1 -1
  309. package/dest/schemas/api.d.ts.map +1 -1
  310. package/dest/schemas/index.d.ts +1 -1
  311. package/dest/schemas/parse.d.ts +1 -1
  312. package/dest/schemas/parse.js +1 -1
  313. package/dest/schemas/schemas.d.ts +21 -20
  314. package/dest/schemas/schemas.d.ts.map +1 -1
  315. package/dest/schemas/schemas.js +29 -11
  316. package/dest/schemas/types.d.ts +31 -1
  317. package/dest/schemas/types.d.ts.map +1 -1
  318. package/dest/schemas/types.js +25 -1
  319. package/dest/schemas/utils.d.ts +4 -6
  320. package/dest/schemas/utils.d.ts.map +1 -1
  321. package/dest/schemas/utils.js +15 -5
  322. package/dest/serialize/buffer_reader.d.ts +28 -3
  323. package/dest/serialize/buffer_reader.d.ts.map +1 -1
  324. package/dest/serialize/buffer_reader.js +44 -2
  325. package/dest/serialize/field_reader.d.ts +12 -3
  326. package/dest/serialize/field_reader.d.ts.map +1 -1
  327. package/dest/serialize/field_reader.js +19 -2
  328. package/dest/serialize/free_funcs.d.ts +25 -23
  329. package/dest/serialize/free_funcs.d.ts.map +1 -1
  330. package/dest/serialize/free_funcs.js +22 -28
  331. package/dest/serialize/index.d.ts +1 -1
  332. package/dest/serialize/serialize.d.ts +6 -7
  333. package/dest/serialize/serialize.d.ts.map +1 -1
  334. package/dest/serialize/serialize.js +1 -1
  335. package/dest/serialize/type_registry.d.ts +1 -1
  336. package/dest/serialize/type_registry.d.ts.map +1 -1
  337. package/dest/serialize/types.d.ts +1 -1
  338. package/dest/sleep/index.d.ts +3 -1
  339. package/dest/sleep/index.d.ts.map +1 -1
  340. package/dest/sleep/index.js +4 -0
  341. package/dest/string/index.d.ts +8 -3
  342. package/dest/string/index.d.ts.map +1 -1
  343. package/dest/string/index.js +27 -1
  344. package/dest/testing/files/index.d.ts +2 -3
  345. package/dest/testing/files/index.d.ts.map +1 -1
  346. package/dest/testing/files/index.js +3 -3
  347. package/dest/testing/formatting.d.ts +4 -0
  348. package/dest/testing/formatting.d.ts.map +1 -0
  349. package/dest/testing/formatting.js +3 -0
  350. package/dest/testing/index.d.ts +2 -1
  351. package/dest/testing/index.d.ts.map +1 -1
  352. package/dest/testing/index.js +1 -0
  353. package/dest/testing/port_allocator.d.ts +1 -1
  354. package/dest/testing/snapshot_serializer.d.ts +1 -1
  355. package/dest/testing/test_data.d.ts +1 -1
  356. package/dest/timer/date.d.ts +4 -2
  357. package/dest/timer/date.d.ts.map +1 -1
  358. package/dest/timer/date.js +8 -3
  359. package/dest/timer/elapsed.d.ts +1 -1
  360. package/dest/timer/index.d.ts +2 -2
  361. package/dest/timer/index.d.ts.map +1 -1
  362. package/dest/timer/index.js +1 -1
  363. package/dest/timer/timeout.d.ts +19 -6
  364. package/dest/timer/timeout.d.ts.map +1 -1
  365. package/dest/timer/timeout.js +43 -22
  366. package/dest/timer/timer.d.ts +1 -1
  367. package/dest/timer/timer.d.ts.map +1 -1
  368. package/dest/transport/dispatch/create_dispatch_fn.d.ts +1 -1
  369. package/dest/transport/dispatch/create_dispatch_fn.d.ts.map +1 -1
  370. package/dest/transport/dispatch/create_dispatch_proxy.d.ts +1 -1
  371. package/dest/transport/dispatch/messages.d.ts +1 -1
  372. package/dest/transport/index.d.ts +1 -2
  373. package/dest/transport/index.d.ts.map +1 -1
  374. package/dest/transport/index.js +0 -1
  375. package/dest/transport/interface/connector.d.ts +1 -1
  376. package/dest/transport/interface/connector.d.ts.map +1 -1
  377. package/dest/transport/interface/listener.d.ts +1 -2
  378. package/dest/transport/interface/listener.d.ts.map +1 -1
  379. package/dest/transport/interface/socket.d.ts +1 -1
  380. package/dest/transport/interface/socket.d.ts.map +1 -1
  381. package/dest/transport/interface/transferable.d.ts +1 -1
  382. package/dest/transport/node/index.d.ts +1 -1
  383. package/dest/transport/node/node_connector.d.ts +1 -2
  384. package/dest/transport/node/node_connector.d.ts.map +1 -1
  385. package/dest/transport/node/node_connector_socket.d.ts +1 -2
  386. package/dest/transport/node/node_connector_socket.d.ts.map +1 -1
  387. package/dest/transport/node/node_listener.d.ts +1 -2
  388. package/dest/transport/node/node_listener.d.ts.map +1 -1
  389. package/dest/transport/node/node_listener_socket.d.ts +1 -2
  390. package/dest/transport/node/node_listener_socket.d.ts.map +1 -1
  391. package/dest/transport/transport_client.d.ts +1 -2
  392. package/dest/transport/transport_client.d.ts.map +1 -1
  393. package/dest/transport/transport_server.d.ts +1 -10
  394. package/dest/transport/transport_server.d.ts.map +1 -1
  395. package/dest/trees/balanced_merkle_tree.d.ts +22 -0
  396. package/dest/trees/balanced_merkle_tree.d.ts.map +1 -0
  397. package/dest/trees/balanced_merkle_tree.js +66 -0
  398. package/dest/trees/hasher.d.ts +5 -7
  399. package/dest/trees/hasher.d.ts.map +1 -1
  400. package/dest/trees/index.d.ts +3 -1
  401. package/dest/trees/index.d.ts.map +1 -1
  402. package/dest/trees/index.js +2 -0
  403. package/dest/trees/indexed_merkle_tree.d.ts +1 -3
  404. package/dest/trees/indexed_merkle_tree.d.ts.map +1 -1
  405. package/dest/trees/indexed_merkle_tree.js +1 -1
  406. package/dest/trees/indexed_merkle_tree_calculator.d.ts +2 -4
  407. package/dest/trees/indexed_merkle_tree_calculator.d.ts.map +1 -1
  408. package/dest/trees/indexed_tree_leaf.d.ts +1 -3
  409. package/dest/trees/indexed_tree_leaf.d.ts.map +1 -1
  410. package/dest/trees/membership_witness.d.ts +6 -11
  411. package/dest/trees/membership_witness.d.ts.map +1 -1
  412. package/dest/trees/membership_witness.js +14 -1
  413. package/dest/trees/merkle_tree.d.ts +1 -3
  414. package/dest/trees/merkle_tree.d.ts.map +1 -1
  415. package/dest/trees/merkle_tree_calculator.d.ts +2 -4
  416. package/dest/trees/merkle_tree_calculator.d.ts.map +1 -1
  417. package/dest/trees/merkle_tree_calculator.js +1 -1
  418. package/dest/trees/sibling_path.d.ts +6 -42
  419. package/dest/trees/sibling_path.d.ts.map +1 -1
  420. package/dest/trees/sibling_path.js +2 -2
  421. package/dest/trees/unbalanced_merkle_tree.d.ts +25 -10
  422. package/dest/trees/unbalanced_merkle_tree.d.ts.map +1 -1
  423. package/dest/trees/unbalanced_merkle_tree.js +78 -50
  424. package/dest/trees/unbalanced_merkle_tree_calculator.d.ts +48 -0
  425. package/dest/trees/unbalanced_merkle_tree_calculator.d.ts.map +1 -0
  426. package/dest/trees/unbalanced_merkle_tree_calculator.js +154 -0
  427. package/dest/trees/unbalanced_tree_store.d.ts +2 -1
  428. package/dest/trees/unbalanced_tree_store.d.ts.map +1 -1
  429. package/dest/trees/unbalanced_tree_store.js +6 -0
  430. package/dest/types/index.d.ts +28 -3
  431. package/dest/types/index.d.ts.map +1 -1
  432. package/dest/types/index.js +3 -0
  433. package/dest/url/index.d.ts +1 -1
  434. package/dest/url/index.d.ts.map +1 -1
  435. package/dest/url/index.js +1 -1
  436. package/dest/validation/index.d.ts +1 -1
  437. package/package.json +59 -45
  438. package/src/array/array.ts +13 -16
  439. package/src/array/index.ts +1 -0
  440. package/src/array/sorted_array.ts +133 -0
  441. package/src/async-pool/index.ts +1 -0
  442. package/src/bigint/index.ts +20 -0
  443. package/src/branded-types/block_number.ts +112 -0
  444. package/src/branded-types/checkpoint_number.ts +115 -0
  445. package/src/branded-types/epoch.ts +88 -0
  446. package/src/branded-types/index.ts +6 -0
  447. package/src/branded-types/slot.ts +88 -0
  448. package/src/branded-types/types.ts +2 -0
  449. package/src/buffer/buffer16.ts +133 -0
  450. package/src/buffer/buffer32.ts +10 -8
  451. package/src/buffer/index.ts +1 -0
  452. package/src/collection/array.ts +66 -4
  453. package/src/collection/object.ts +37 -0
  454. package/src/config/env_var.ts +177 -58
  455. package/src/config/index.ts +209 -10
  456. package/src/config/network_config.ts +18 -0
  457. package/src/config/network_name.ts +28 -0
  458. package/src/config/parse-env.ts +4 -0
  459. package/src/config/secret_value.ts +49 -0
  460. package/src/crypto/aes128/index.ts +19 -10
  461. package/src/crypto/bls/bn254_keystore.ts +287 -0
  462. package/src/crypto/bls/index.ts +77 -0
  463. package/src/crypto/bn254/index.ts +64 -0
  464. package/src/crypto/ecdsa/index.ts +41 -23
  465. package/src/crypto/ecdsa/signature.ts +2 -2
  466. package/src/crypto/grumpkin/index.ts +38 -46
  467. package/src/crypto/keys/index.ts +6 -6
  468. package/src/crypto/pedersen/pedersen.wasm.ts +23 -19
  469. package/src/crypto/poseidon/index.ts +33 -25
  470. package/src/crypto/random/index.ts +2 -40
  471. package/src/crypto/random/randomness_singleton.ts +2 -4
  472. package/src/crypto/schnorr/index.ts +22 -18
  473. package/src/crypto/schnorr/signature.ts +2 -2
  474. package/src/crypto/secp256k1/index.ts +15 -11
  475. package/src/crypto/secp256k1-signer/utils.ts +120 -7
  476. package/src/crypto/sha256/index.ts +48 -1
  477. package/src/crypto/sha512/index.ts +1 -1
  478. package/src/crypto/signature/index.ts +1 -1
  479. package/src/crypto/sync/index.ts +1 -1
  480. package/src/crypto/sync/pedersen/index.ts +17 -16
  481. package/src/crypto/sync/poseidon/index.ts +28 -23
  482. package/src/curves/bls12/field.ts +463 -0
  483. package/src/curves/bls12/index.ts +2 -0
  484. package/src/curves/bls12/point.ts +450 -0
  485. package/src/{fields/fields.ts → curves/bn254/field.ts} +84 -63
  486. package/src/curves/bn254/index.ts +2 -0
  487. package/src/curves/bn254/point.ts +170 -0
  488. package/src/curves/grumpkin/index.ts +11 -0
  489. package/src/{fields → curves/grumpkin}/point.ts +27 -10
  490. package/src/eth-address/index.ts +35 -3
  491. package/src/eth-signature/eth_signature.ts +44 -22
  492. package/src/fs/index.ts +1 -0
  493. package/src/fs/try_rm_dir.ts +15 -0
  494. package/src/iterable/filter.ts +1 -1
  495. package/src/iterable/map.ts +1 -1
  496. package/src/iterator/filter.ts +11 -0
  497. package/src/iterator/index.ts +1 -0
  498. package/src/jest/env.mjs +52 -0
  499. package/src/jest/setupAfterEnv.mjs +3 -0
  500. package/src/json-rpc/client/fetch.ts +14 -33
  501. package/src/json-rpc/client/safe_json_rpc_client.ts +226 -13
  502. package/src/json-rpc/client/undici.ts +8 -15
  503. package/src/json-rpc/convert.ts +3 -12
  504. package/src/json-rpc/errors.ts +6 -0
  505. package/src/json-rpc/fixtures/class_a.ts +4 -1
  506. package/src/json-rpc/fixtures/class_b.ts +4 -1
  507. package/src/json-rpc/index.ts +2 -1
  508. package/src/json-rpc/server/safe_json_rpc_server.ts +141 -48
  509. package/src/json-rpc/test/integration.ts +1 -1
  510. package/src/log/console.ts +4 -1
  511. package/src/log/gcloud-logger-config.ts +3 -7
  512. package/src/log/index.ts +4 -4
  513. package/src/log/libp2p_logger.ts +21 -2
  514. package/src/log/log_fn.ts +1 -1
  515. package/src/log/noir_debug_log_util.ts +21 -0
  516. package/src/log/pino-logger.ts +35 -3
  517. package/src/message/index.ts +5 -1
  518. package/src/mutex/mutex_database.ts +2 -3
  519. package/src/number/index.ts +14 -0
  520. package/src/profiler/index.ts +1 -0
  521. package/src/profiler/profiler.ts +125 -0
  522. package/src/promise/running-promise.ts +2 -2
  523. package/src/queue/batch_queue.ts +1 -1
  524. package/src/queue/bounded_serial_queue.ts +4 -1
  525. package/src/queue/serial_queue.ts +5 -5
  526. package/src/retry/index.ts +10 -5
  527. package/src/schemas/api.ts +4 -4
  528. package/src/schemas/parse.ts +1 -1
  529. package/src/schemas/schemas.ts +42 -13
  530. package/src/schemas/types.ts +33 -0
  531. package/src/schemas/utils.ts +21 -8
  532. package/src/serialize/buffer_reader.ts +60 -3
  533. package/src/serialize/field_reader.ts +28 -4
  534. package/src/serialize/free_funcs.ts +26 -32
  535. package/src/serialize/serialize.ts +3 -1
  536. package/src/sleep/index.ts +6 -0
  537. package/src/string/index.ts +36 -1
  538. package/src/testing/files/index.ts +7 -3
  539. package/src/testing/formatting.ts +3 -0
  540. package/src/testing/index.ts +1 -0
  541. package/src/timer/date.ts +13 -3
  542. package/src/timer/index.ts +1 -1
  543. package/src/timer/timeout.ts +54 -19
  544. package/src/transport/index.ts +0 -1
  545. package/src/transport/interface/connector.ts +0 -1
  546. package/src/transport/interface/listener.ts +2 -3
  547. package/src/transport/interface/socket.ts +2 -3
  548. package/src/transport/transport_client.ts +3 -4
  549. package/src/transport/transport_server.ts +4 -1
  550. package/src/trees/balanced_merkle_tree.ts +84 -0
  551. package/src/trees/hasher.ts +4 -4
  552. package/src/trees/index.ts +2 -0
  553. package/src/trees/indexed_merkle_tree.ts +6 -2
  554. package/src/trees/indexed_merkle_tree_calculator.ts +2 -2
  555. package/src/trees/membership_witness.ts +14 -1
  556. package/src/trees/merkle_tree.ts +4 -1
  557. package/src/trees/merkle_tree_calculator.ts +10 -5
  558. package/src/trees/sibling_path.ts +2 -2
  559. package/src/trees/unbalanced_merkle_tree.ts +112 -42
  560. package/src/trees/unbalanced_merkle_tree_calculator.ts +177 -0
  561. package/src/trees/unbalanced_tree_store.ts +5 -1
  562. package/src/types/index.ts +30 -4
  563. package/src/url/index.ts +0 -1
  564. package/dest/crypto/index.d.ts +0 -15
  565. package/dest/crypto/index.d.ts.map +0 -1
  566. package/dest/crypto/index.js +0 -14
  567. package/dest/crypto/pedersen/pedersen.elliptic.d.ts +0 -13
  568. package/dest/crypto/pedersen/pedersen.elliptic.d.ts.map +0 -1
  569. package/dest/crypto/pedersen/pedersen.elliptic.js +0 -582
  570. package/dest/fields/coordinate.d.ts +0 -68
  571. package/dest/fields/coordinate.d.ts.map +0 -1
  572. package/dest/fields/coordinate.js +0 -96
  573. package/dest/fields/fields.d.ts +0 -176
  574. package/dest/fields/fields.d.ts.map +0 -1
  575. package/dest/fields/index.d.ts +0 -4
  576. package/dest/fields/index.d.ts.map +0 -1
  577. package/dest/fields/index.js +0 -3
  578. package/dest/fields/point.d.ts.map +0 -1
  579. package/dest/index.d.ts +0 -31
  580. package/dest/index.d.ts.map +0 -1
  581. package/dest/index.js +0 -31
  582. package/dest/json-rpc/server/telemetry.d.ts +0 -2
  583. package/dest/json-rpc/server/telemetry.d.ts.map +0 -1
  584. package/dest/json-rpc/server/telemetry.js +0 -0
  585. package/dest/log/debug.d.ts +0 -56
  586. package/dest/log/debug.d.ts.map +0 -1
  587. package/dest/log/debug.js +0 -75
  588. package/dest/log/log_history.d.ts +0 -31
  589. package/dest/log/log_history.d.ts.map +0 -1
  590. package/dest/log/log_history.js +0 -38
  591. package/dest/transport/browser/index.d.ts +0 -5
  592. package/dest/transport/browser/index.d.ts.map +0 -1
  593. package/dest/transport/browser/index.js +0 -4
  594. package/dest/transport/browser/message_port_socket.d.ts +0 -37
  595. package/dest/transport/browser/message_port_socket.d.ts.map +0 -1
  596. package/dest/transport/browser/message_port_socket.js +0 -42
  597. package/dest/transport/browser/shared_worker_connector.d.ts +0 -19
  598. package/dest/transport/browser/shared_worker_connector.d.ts.map +0 -1
  599. package/dest/transport/browser/shared_worker_connector.js +0 -19
  600. package/dest/transport/browser/shared_worker_listener.d.ts +0 -38
  601. package/dest/transport/browser/shared_worker_listener.d.ts.map +0 -1
  602. package/dest/transport/browser/shared_worker_listener.js +0 -33
  603. package/dest/transport/browser/worker_connector.d.ts +0 -26
  604. package/dest/transport/browser/worker_connector.d.ts.map +0 -1
  605. package/dest/transport/browser/worker_connector.js +0 -30
  606. package/dest/transport/browser/worker_listener.d.ts +0 -39
  607. package/dest/transport/browser/worker_listener.d.ts.map +0 -1
  608. package/dest/transport/browser/worker_listener.js +0 -35
  609. package/dest/wasm/empty_wasi_sdk.d.ts +0 -130
  610. package/dest/wasm/empty_wasi_sdk.d.ts.map +0 -1
  611. package/dest/wasm/empty_wasi_sdk.js +0 -148
  612. package/dest/wasm/index.d.ts +0 -2
  613. package/dest/wasm/index.d.ts.map +0 -1
  614. package/dest/wasm/index.js +0 -1
  615. package/dest/wasm/wasm_module.d.ts +0 -136
  616. package/dest/wasm/wasm_module.d.ts.map +0 -1
  617. package/dest/wasm/wasm_module.js +0 -196
  618. package/dest/worker/browser/index.d.ts +0 -3
  619. package/dest/worker/browser/index.d.ts.map +0 -1
  620. package/dest/worker/browser/index.js +0 -2
  621. package/dest/worker/browser/start_web_module.d.ts +0 -7
  622. package/dest/worker/browser/start_web_module.d.ts.map +0 -1
  623. package/dest/worker/browser/start_web_module.js +0 -27
  624. package/dest/worker/browser/web_data_store.d.ts +0 -24
  625. package/dest/worker/browser/web_data_store.d.ts.map +0 -1
  626. package/dest/worker/browser/web_data_store.js +0 -29
  627. package/dest/worker/browser/web_worker.d.ts +0 -10
  628. package/dest/worker/browser/web_worker.d.ts.map +0 -1
  629. package/dest/worker/browser/web_worker.js +0 -25
  630. package/dest/worker/data_store.d.ts +0 -21
  631. package/dest/worker/data_store.d.ts.map +0 -1
  632. package/dest/worker/data_store.js +0 -3
  633. package/dest/worker/index.d.ts +0 -3
  634. package/dest/worker/index.d.ts.map +0 -1
  635. package/dest/worker/index.js +0 -1
  636. package/dest/worker/node/index.d.ts +0 -3
  637. package/dest/worker/node/index.d.ts.map +0 -1
  638. package/dest/worker/node/index.js +0 -2
  639. package/dest/worker/node/node_data_store.d.ts +0 -13
  640. package/dest/worker/node/node_data_store.d.ts.map +0 -1
  641. package/dest/worker/node/node_data_store.js +0 -20
  642. package/dest/worker/node/node_worker.d.ts +0 -6
  643. package/dest/worker/node/node_worker.d.ts.map +0 -1
  644. package/dest/worker/node/node_worker.js +0 -22
  645. package/dest/worker/node/start_node_module.d.ts +0 -7
  646. package/dest/worker/node/start_node_module.d.ts.map +0 -1
  647. package/dest/worker/node/start_node_module.js +0 -31
  648. package/dest/worker/wasm_worker.d.ts +0 -9
  649. package/dest/worker/wasm_worker.d.ts.map +0 -1
  650. package/dest/worker/wasm_worker.js +0 -3
  651. package/dest/worker/worker_pool.d.ts +0 -40
  652. package/dest/worker/worker_pool.d.ts.map +0 -1
  653. package/dest/worker/worker_pool.js +0 -51
  654. package/src/crypto/index.ts +0 -14
  655. package/src/crypto/pedersen/pedersen.elliptic.ts +0 -584
  656. package/src/fields/coordinate.ts +0 -104
  657. package/src/fields/index.ts +0 -3
  658. package/src/index.ts +0 -31
  659. package/src/json-rpc/server/telemetry.ts +0 -0
  660. package/src/log/debug.ts +0 -104
  661. package/src/log/log_history.ts +0 -44
  662. package/src/transport/browser/index.ts +0 -4
  663. package/src/transport/browser/message_port_socket.ts +0 -48
  664. package/src/transport/browser/shared_worker_connector.ts +0 -21
  665. package/src/transport/browser/shared_worker_listener.ts +0 -53
  666. package/src/transport/browser/worker_connector.ts +0 -30
  667. package/src/transport/browser/worker_listener.ts +0 -54
  668. package/src/wasm/README.md +0 -6
  669. package/src/wasm/empty_wasi_sdk.ts +0 -166
  670. package/src/wasm/fixtures/gcd.wasm +0 -0
  671. package/src/wasm/fixtures/gcd.wat +0 -27
  672. package/src/wasm/index.ts +0 -1
  673. package/src/wasm/wasm_module.ts +0 -260
  674. package/src/worker/browser/index.ts +0 -2
  675. package/src/worker/browser/start_web_module.ts +0 -24
  676. package/src/worker/browser/web_data_store.ts +0 -38
  677. package/src/worker/browser/web_worker.ts +0 -25
  678. package/src/worker/data_store.ts +0 -19
  679. package/src/worker/index.ts +0 -2
  680. package/src/worker/node/index.ts +0 -2
  681. package/src/worker/node/node_data_store.ts +0 -27
  682. package/src/worker/node/node_worker.ts +0 -23
  683. package/src/worker/node/start_node_module.ts +0 -30
  684. package/src/worker/wasm_worker.ts +0 -7
  685. package/src/worker/worker_pool.ts +0 -73
@@ -0,0 +1,154 @@
1
+ import { shaMerkleHash } from './balanced_merkle_tree.js';
2
+ import { SiblingPath } from './sibling_path.js';
3
+ import { UnbalancedTreeStore } from './unbalanced_tree_store.js';
4
+ /**
5
+ * An ephemeral unbalanced Merkle tree implementation.
6
+ * Follows the rollup implementation which greedily hashes pairs of nodes up the tree.
7
+ * Remaining rightmost nodes are shifted up until they can be paired.
8
+ * The values that match the `valueToCompress` are skipped and the sibling of the compressed leaf are shifted up until
9
+ * they can be paired.
10
+ * If there is only one leaf, the root is the leaf.
11
+ */ export class UnbalancedMerkleTreeCalculator {
12
+ leaves;
13
+ valueToCompress;
14
+ emptyRoot;
15
+ hasher;
16
+ store;
17
+ leafLocations;
18
+ constructor(leaves, valueToCompress, emptyRoot, hasher){
19
+ this.leaves = leaves;
20
+ this.valueToCompress = valueToCompress;
21
+ this.emptyRoot = emptyRoot;
22
+ this.hasher = hasher;
23
+ this.leafLocations = [];
24
+ this.store = new UnbalancedTreeStore(leaves.length);
25
+ this.buildTree();
26
+ }
27
+ static create(leaves, valueToCompress = Buffer.alloc(0), emptyRoot = Buffer.alloc(32), hasher = shaMerkleHash) {
28
+ return new UnbalancedMerkleTreeCalculator(leaves, valueToCompress, emptyRoot, hasher);
29
+ }
30
+ /**
31
+ * Returns the root of the tree.
32
+ * @returns The root of the tree.
33
+ */ getRoot() {
34
+ return this.store.getRoot().value;
35
+ }
36
+ /**
37
+ * Returns a sibling path for the element.
38
+ * @param value - The value of the element.
39
+ * @returns A sibling path for the element.
40
+ * Note: The sibling path is an array of sibling hashes, with the lowest hash (leaf hash) first, and the highest hash last.
41
+ */ getSiblingPath(value) {
42
+ const leafIndex = this.leaves.findIndex((leaf)=>leaf.equals(value));
43
+ if (leafIndex === -1) {
44
+ throw Error(`Leaf value ${value.toString('hex')} not found in tree.`);
45
+ }
46
+ return this.getSiblingPathByLeafIndex(leafIndex);
47
+ }
48
+ /**
49
+ * Returns a sibling path for the leaf at the given index.
50
+ * @param leafIndex - The index of the leaf.
51
+ * @returns A sibling path for the leaf.
52
+ */ getSiblingPathByLeafIndex(leafIndex) {
53
+ if (leafIndex >= this.leaves.length) {
54
+ throw Error(`Leaf index ${leafIndex} out of bounds. Tree has ${this.leaves.length} leaves.`);
55
+ }
56
+ const leaf = this.leaves[leafIndex];
57
+ if (leaf.equals(this.valueToCompress)) {
58
+ throw Error(`Leaf at index ${leafIndex} has been compressed.`);
59
+ }
60
+ const path = [];
61
+ let location = this.leafLocations[leafIndex];
62
+ while(location.level > 0){
63
+ const sibling = this.store.getSibling(location);
64
+ path.push(sibling.value);
65
+ location = this.store.getParentLocation(location);
66
+ }
67
+ return new SiblingPath(path.length, path);
68
+ }
69
+ getLeafLocation(leafIndex) {
70
+ return this.leafLocations[leafIndex];
71
+ }
72
+ /**
73
+ * Adds leaves and nodes to the store. Updates the leafLocations.
74
+ * @param leaves - The leaves of the tree.
75
+ */ buildTree() {
76
+ this.leafLocations = this.leaves.map((value, i)=>this.store.setLeaf(i, {
77
+ value,
78
+ leafIndex: i
79
+ }));
80
+ // Start with the leaves that are not compressed.
81
+ let toProcess = this.leafLocations.filter((_, i)=>!this.leaves[i].equals(this.valueToCompress));
82
+ if (!toProcess.length) {
83
+ // All leaves are compressed. Set empty root to the root.
84
+ this.store.setNode({
85
+ level: 0,
86
+ index: 0
87
+ }, {
88
+ value: this.emptyRoot
89
+ });
90
+ return;
91
+ }
92
+ const level = toProcess[0].level;
93
+ for(let i = level; i > 0; i--){
94
+ const toProcessNext = [];
95
+ for (const location of toProcess){
96
+ if (location.level !== i) {
97
+ toProcessNext.push(location);
98
+ continue;
99
+ }
100
+ const parentLocation = this.store.getParentLocation(location);
101
+ if (this.store.getNode(parentLocation)) {
102
+ continue;
103
+ }
104
+ const sibling = this.store.getSibling(location);
105
+ // If sibling is undefined, all its children are compressed.
106
+ const shouldShiftUp = !sibling || sibling.value.equals(this.valueToCompress);
107
+ if (shouldShiftUp) {
108
+ // The node becomes the parent if the sibling is a compressed leaf.
109
+ this.shiftNodeUp(location, parentLocation);
110
+ } else {
111
+ // Hash the value with the (right) sibling and update the parent node.
112
+ const node = this.store.getNode(location);
113
+ const parentValue = this.hasher(node.value, sibling.value);
114
+ this.store.setNode(parentLocation, {
115
+ value: parentValue
116
+ });
117
+ }
118
+ // Add the parent location to be processed next.
119
+ toProcessNext.push(parentLocation);
120
+ }
121
+ toProcess = toProcessNext;
122
+ }
123
+ }
124
+ shiftNodeUp(from, to) {
125
+ // Collect all nodes that need to shift.
126
+ const nodesToShift = this.collectNodesToShift(from, to);
127
+ // Move all nodes to their new locations.
128
+ for (const { node, newLocation } of nodesToShift){
129
+ this.store.setNode(newLocation, node);
130
+ if (node.leafIndex !== undefined) {
131
+ this.leafLocations[node.leafIndex] = newLocation;
132
+ }
133
+ }
134
+ }
135
+ collectNodesToShift(from, to) {
136
+ const node = this.store.getNode(from);
137
+ if (!node) {
138
+ return [];
139
+ }
140
+ let result = [
141
+ {
142
+ node,
143
+ newLocation: to
144
+ }
145
+ ];
146
+ // If not a leaf, collect its children.
147
+ if (node.leafIndex === undefined) {
148
+ const [leftChild, rightChild] = this.store.getChildLocations(from);
149
+ const [leftChildNew, rightChildNew] = this.store.getChildLocations(to);
150
+ result = result.concat(this.collectNodesToShift(leftChild, leftChildNew)).concat(this.collectNodesToShift(rightChild, rightChildNew));
151
+ }
152
+ return result;
153
+ }
154
+ }
@@ -12,8 +12,9 @@ export declare class UnbalancedTreeStore<T> {
12
12
  getChildLocations({ level, index }: TreeNodeLocation): [TreeNodeLocation, TreeNodeLocation];
13
13
  getLeaf(leafIndex: number): T | undefined;
14
14
  getNode(location: TreeNodeLocation): T | undefined;
15
+ getRoot(): T | undefined;
15
16
  getParent(location: TreeNodeLocation): T | undefined;
16
17
  getSibling(location: TreeNodeLocation): T | undefined;
17
18
  getChildren(location: TreeNodeLocation): [T | undefined, T | undefined];
18
19
  }
19
- //# sourceMappingURL=unbalanced_tree_store.d.ts.map
20
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidW5iYWxhbmNlZF90cmVlX3N0b3JlLmQudHMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMvdHJlZXMvdW5iYWxhbmNlZF90cmVlX3N0b3JlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUVBLE1BQU0sV0FBVyxnQkFBZ0I7SUFDL0IsS0FBSyxFQUFFLE1BQU0sQ0FBQztJQUNkLEtBQUssRUFBRSxNQUFNLENBQUM7Q0FDZjtBQU9ELHFCQUFhLG1CQUFtQixDQUFDLENBQUM7O0lBSWhDLFlBQVksU0FBUyxFQUFFLE1BQU0sRUFFNUI7SUFFRCxPQUFPLENBQUMsU0FBUyxFQUFFLE1BQU0sRUFBRSxLQUFLLEVBQUUsQ0FBQyxHQUFHLGdCQUFnQixDQWVyRDtJQUVELE9BQU8sQ0FBQyxFQUFFLEtBQUssRUFBRSxLQUFLLEVBQUUsRUFBRSxnQkFBZ0IsRUFBRSxLQUFLLEVBQUUsQ0FBQyxRQVNuRDtJQUVELGlCQUFpQixDQUFDLEVBQUUsS0FBSyxFQUFFLEtBQUssRUFBRSxFQUFFLGdCQUFnQixHQUFHLGdCQUFnQixDQU10RTtJQUVELGtCQUFrQixDQUFDLEVBQUUsS0FBSyxFQUFFLEtBQUssRUFBRSxFQUFFLGdCQUFnQixHQUFHLGdCQUFnQixDQU12RTtJQUVELGlCQUFpQixDQUFDLEVBQUUsS0FBSyxFQUFFLEtBQUssRUFBRSxFQUFFLGdCQUFnQixHQUFHLENBQUMsZ0JBQWdCLEVBQUUsZ0JBQWdCLENBQUMsQ0FJMUY7SUFFRCxPQUFPLENBQUMsU0FBUyxFQUFFLE1BQU0sR0FBRyxDQUFDLEdBQUcsU0FBUyxDQU94QztJQUVELE9BQU8sQ0FBQyxRQUFRLEVBQUUsZ0JBQWdCLEdBQUcsQ0FBQyxHQUFHLFNBQVMsQ0FFakQ7SUFFRCxPQUFPLElBQUksQ0FBQyxHQUFHLFNBQVMsQ0FFdkI7SUFFRCxTQUFTLENBQUMsUUFBUSxFQUFFLGdCQUFnQixHQUFHLENBQUMsR0FBRyxTQUFTLENBR25EO0lBRUQsVUFBVSxDQUFDLFFBQVEsRUFBRSxnQkFBZ0IsR0FBRyxDQUFDLEdBQUcsU0FBUyxDQUdwRDtJQUVELFdBQVcsQ0FBQyxRQUFRLEVBQUUsZ0JBQWdCLEdBQUcsQ0FBQyxDQUFDLEdBQUcsU0FBUyxFQUFFLENBQUMsR0FBRyxTQUFTLENBQUMsQ0FHdEU7Q0FLRiJ9
@@ -1 +1 @@
1
- {"version":3,"file":"unbalanced_tree_store.d.ts","sourceRoot":"","sources":["../../src/trees/unbalanced_tree_store.ts"],"names":[],"mappings":"AAEA,MAAM,WAAW,gBAAgB;IAC/B,KAAK,EAAE,MAAM,CAAC;IACd,KAAK,EAAE,MAAM,CAAC;CACf;AAOD,qBAAa,mBAAmB,CAAC,CAAC;;gBAIpB,SAAS,EAAE,MAAM;IAI7B,OAAO,CAAC,SAAS,EAAE,MAAM,EAAE,KAAK,EAAE,CAAC,GAAG,gBAAgB;IAiBtD,OAAO,CAAC,EAAE,KAAK,EAAE,KAAK,EAAE,EAAE,gBAAgB,EAAE,KAAK,EAAE,CAAC;IAWpD,iBAAiB,CAAC,EAAE,KAAK,EAAE,KAAK,EAAE,EAAE,gBAAgB,GAAG,gBAAgB;IAQvE,kBAAkB,CAAC,EAAE,KAAK,EAAE,KAAK,EAAE,EAAE,gBAAgB,GAAG,gBAAgB;IAQxE,iBAAiB,CAAC,EAAE,KAAK,EAAE,KAAK,EAAE,EAAE,gBAAgB,GAAG,CAAC,gBAAgB,EAAE,gBAAgB,CAAC;IAM3F,OAAO,CAAC,SAAS,EAAE,MAAM;IASzB,OAAO,CAAC,QAAQ,EAAE,gBAAgB,GAAG,CAAC,GAAG,SAAS;IAIlD,SAAS,CAAC,QAAQ,EAAE,gBAAgB,GAAG,CAAC,GAAG,SAAS;IAKpD,UAAU,CAAC,QAAQ,EAAE,gBAAgB,GAAG,CAAC,GAAG,SAAS;IAKrD,WAAW,CAAC,QAAQ,EAAE,gBAAgB,GAAG,CAAC,CAAC,GAAG,SAAS,EAAE,CAAC,GAAG,SAAS,CAAC;CAQxE"}
1
+ {"version":3,"file":"unbalanced_tree_store.d.ts","sourceRoot":"","sources":["../../src/trees/unbalanced_tree_store.ts"],"names":[],"mappings":"AAEA,MAAM,WAAW,gBAAgB;IAC/B,KAAK,EAAE,MAAM,CAAC;IACd,KAAK,EAAE,MAAM,CAAC;CACf;AAOD,qBAAa,mBAAmB,CAAC,CAAC;;IAIhC,YAAY,SAAS,EAAE,MAAM,EAE5B;IAED,OAAO,CAAC,SAAS,EAAE,MAAM,EAAE,KAAK,EAAE,CAAC,GAAG,gBAAgB,CAerD;IAED,OAAO,CAAC,EAAE,KAAK,EAAE,KAAK,EAAE,EAAE,gBAAgB,EAAE,KAAK,EAAE,CAAC,QASnD;IAED,iBAAiB,CAAC,EAAE,KAAK,EAAE,KAAK,EAAE,EAAE,gBAAgB,GAAG,gBAAgB,CAMtE;IAED,kBAAkB,CAAC,EAAE,KAAK,EAAE,KAAK,EAAE,EAAE,gBAAgB,GAAG,gBAAgB,CAMvE;IAED,iBAAiB,CAAC,EAAE,KAAK,EAAE,KAAK,EAAE,EAAE,gBAAgB,GAAG,CAAC,gBAAgB,EAAE,gBAAgB,CAAC,CAI1F;IAED,OAAO,CAAC,SAAS,EAAE,MAAM,GAAG,CAAC,GAAG,SAAS,CAOxC;IAED,OAAO,CAAC,QAAQ,EAAE,gBAAgB,GAAG,CAAC,GAAG,SAAS,CAEjD;IAED,OAAO,IAAI,CAAC,GAAG,SAAS,CAEvB;IAED,SAAS,CAAC,QAAQ,EAAE,gBAAgB,GAAG,CAAC,GAAG,SAAS,CAGnD;IAED,UAAU,CAAC,QAAQ,EAAE,gBAAgB,GAAG,CAAC,GAAG,SAAS,CAGpD;IAED,WAAW,CAAC,QAAQ,EAAE,gBAAgB,GAAG,CAAC,CAAC,GAAG,SAAS,EAAE,CAAC,GAAG,SAAS,CAAC,CAGtE;CAKF"}
@@ -73,6 +73,12 @@ export class UnbalancedTreeStore {
73
73
  getNode(location) {
74
74
  return this.#nodeMapping.get(this.#getKey(location))?.value;
75
75
  }
76
+ getRoot() {
77
+ return this.getNode({
78
+ level: 0,
79
+ index: 0
80
+ });
81
+ }
76
82
  getParent(location) {
77
83
  const parentLocation = this.getParentLocation(location);
78
84
  return this.getNode(parentLocation);
@@ -14,6 +14,31 @@ export type Writeable<T> = {
14
14
  };
15
15
  /** Removes readonly modifiers for an object. */
16
16
  export declare function unfreeze<T>(obj: T): Writeable<T>;
17
- /** Maybe exists, maybe not. */
18
- export type Maybe<T extends object> = T | unknown;
19
- //# sourceMappingURL=index.d.ts.map
17
+ /** Is defined type guard */
18
+ export declare function isDefined<T>(value: T | undefined): value is T;
19
+ /** Resolves a record-like type. Lifted from viem. */
20
+ export type Prettify<T> = {
21
+ [K in keyof T]: T[K];
22
+ } & {};
23
+ /**
24
+ * Type-safe Event Emitter type
25
+ * @example
26
+ * export type ArchiverEmitter = TypedEventEmitter<{
27
+ * [L2BlockSourceEvents.L2PruneDetected]: (args: L2BlockSourceEvent) => void;
28
+ * [L2BlockSourceEvents.L2BlockProven]: (args: L2BlockSourceEvent) => void;
29
+ * }>;
30
+ * class Archiver extends (EventEmitter as new () => ArchiverEmitter) {
31
+ * // ...
32
+ * }
33
+ */
34
+ export interface TypedEventEmitter<TEventMap extends {
35
+ [key in keyof TEventMap]: (...args: any[]) => void;
36
+ }> {
37
+ once<K extends keyof TEventMap>(event: K, listener: TEventMap[K]): this;
38
+ on<K extends keyof TEventMap>(event: K, listener: TEventMap[K]): this;
39
+ off<K extends keyof TEventMap>(event: K, listener: TEventMap[K]): this;
40
+ emit<K extends keyof TEventMap>(event: K, ...args: Parameters<TEventMap[K]>): boolean;
41
+ removeListener<K extends keyof TEventMap>(event: K, listener: TEventMap[K]): this;
42
+ removeAllListeners<K extends keyof TEventMap>(event: K): this;
43
+ }
44
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguZC50cyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy90eXBlcy9pbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxnQ0FBZ0M7QUFDaEMsTUFBTSxNQUFNLFFBQVEsQ0FBQyxDQUFDLElBQUk7S0FDdkIsQ0FBQyxJQUFJLE1BQU0sQ0FBQyxJQUFJLENBQUMsQ0FBQyxDQUFDLENBQUMsU0FBUyxRQUFRLEdBQUcsS0FBSyxHQUFHLENBQUMsR0FBRyxDQUFDLENBQUMsQ0FBQyxDQUFDO0NBQzFELENBQUM7QUFFRixrQ0FBa0M7QUFDbEMsTUFBTSxNQUFNLFdBQVcsQ0FBQyxDQUFDLElBQUk7S0FDMUIsQ0FBQyxJQUFJLE1BQU0sQ0FBQyxJQUFJLENBQUMsQ0FBQyxDQUFDLENBQUMsU0FBUyxRQUFRLEdBQUcsQ0FBQyxHQUFHLEtBQUssR0FBRyxDQUFDLENBQUMsQ0FBQyxDQUFDO0NBQzFELENBQUM7QUFFRix1REFBdUQ7QUFDdkQsTUFBTSxNQUFNLFNBQVMsQ0FBQyxDQUFDLEVBQUUsQ0FBQyxTQUFTLE1BQU0sQ0FBQyxJQUFJLElBQUksQ0FBQyxDQUFDLEVBQUUsQ0FBQyxDQUFDLEdBQUcsT0FBTyxDQUFDLElBQUksQ0FBQyxDQUFDLEVBQUUsQ0FBQyxDQUFDLENBQUMsQ0FBQztBQUUvRSw2Q0FBNkM7QUFDN0MsTUFBTSxNQUFNLFNBQVMsQ0FBQyxDQUFDLElBQUk7SUFBRSxDQUFDLFVBQVUsQ0FBQyxJQUFJLE1BQU0sQ0FBQyxHQUFHLENBQUMsQ0FBQyxDQUFDLENBQUM7Q0FBRSxDQUFDO0FBRTlELGdEQUFnRDtBQUNoRCx3QkFBZ0IsUUFBUSxDQUFDLENBQUMsRUFBRSxHQUFHLEVBQUUsQ0FBQyxHQUFHLFNBQVMsQ0FBQyxDQUFDLENBQUMsQ0FFaEQ7QUFFRCw0QkFBNEI7QUFDNUIsd0JBQWdCLFNBQVMsQ0FBQyxDQUFDLEVBQUUsS0FBSyxFQUFFLENBQUMsR0FBRyxTQUFTLEdBQUcsS0FBSyxJQUFJLENBQUMsQ0FFN0Q7QUFFRCxxREFBcUQ7QUFDckQsTUFBTSxNQUFNLFFBQVEsQ0FBQyxDQUFDLElBQUk7S0FDdkIsQ0FBQyxJQUFJLE1BQU0sQ0FBQyxHQUFHLENBQUMsQ0FBQyxDQUFDLENBQUM7Q0FDckIsR0FBRyxFQUFFLENBQUM7QUFFUDs7Ozs7Ozs7OztHQVVHO0FBQ0gsTUFBTSxXQUFXLGlCQUFpQixDQUFDLFNBQVMsU0FBUztLQUFHLEdBQUcsSUFBSSxNQUFNLFNBQVMsR0FBRyxDQUFDLEdBQUcsSUFBSSxFQUFFLEdBQUcsRUFBRSxLQUFLLElBQUk7Q0FBRTtJQUN6RyxJQUFJLENBQUMsQ0FBQyxTQUFTLE1BQU0sU0FBUyxFQUFFLEtBQUssRUFBRSxDQUFDLEVBQUUsUUFBUSxFQUFFLFNBQVMsQ0FBQyxDQUFDLENBQUMsR0FBRyxJQUFJLENBQUM7SUFDeEUsRUFBRSxDQUFDLENBQUMsU0FBUyxNQUFNLFNBQVMsRUFBRSxLQUFLLEVBQUUsQ0FBQyxFQUFFLFFBQVEsRUFBRSxTQUFTLENBQUMsQ0FBQyxDQUFDLEdBQUcsSUFBSSxDQUFDO0lBQ3RFLEdBQUcsQ0FBQyxDQUFDLFNBQVMsTUFBTSxTQUFTLEVBQUUsS0FBSyxFQUFFLENBQUMsRUFBRSxRQUFRLEVBQUUsU0FBUyxDQUFDLENBQUMsQ0FBQyxHQUFHLElBQUksQ0FBQztJQUN2RSxJQUFJLENBQUMsQ0FBQyxTQUFTLE1BQU0sU0FBUyxFQUFFLEtBQUssRUFBRSxDQUFDLEVBQUUsR0FBRyxJQUFJLEVBQUUsVUFBVSxDQUFDLFNBQVMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxHQUFHLE9BQU8sQ0FBQztJQUN0RixjQUFjLENBQUMsQ0FBQyxTQUFTLE1BQU0sU0FBUyxFQUFFLEtBQUssRUFBRSxDQUFDLEVBQUUsUUFBUSxFQUFFLFNBQVMsQ0FBQyxDQUFDLENBQUMsR0FBRyxJQUFJLENBQUM7SUFDbEYsa0JBQWtCLENBQUMsQ0FBQyxTQUFTLE1BQU0sU0FBUyxFQUFFLEtBQUssRUFBRSxDQUFDLEdBQUcsSUFBSSxDQUFDO0NBRS9EIn0=
@@ -1 +1 @@
1
- {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/types/index.ts"],"names":[],"mappings":"AAAA,gCAAgC;AAChC,MAAM,MAAM,QAAQ,CAAC,CAAC,IAAI;KAEvB,CAAC,IAAI,MAAM,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,SAAS,QAAQ,GAAG,KAAK,GAAG,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC;CAC1D,CAAC;AAEF,kCAAkC;AAClC,MAAM,MAAM,WAAW,CAAC,CAAC,IAAI;KAE1B,CAAC,IAAI,MAAM,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,SAAS,QAAQ,GAAG,CAAC,GAAG,KAAK,GAAG,CAAC,CAAC,CAAC,CAAC;CAC1D,CAAC;AAEF,uDAAuD;AACvD,MAAM,MAAM,SAAS,CAAC,CAAC,EAAE,CAAC,SAAS,MAAM,CAAC,IAAI,IAAI,CAAC,CAAC,EAAE,CAAC,CAAC,GAAG,OAAO,CAAC,IAAI,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;AAE/E,6CAA6C;AAC7C,MAAM,MAAM,SAAS,CAAC,CAAC,IAAI;IAAE,CAAC,UAAU,CAAC,IAAI,MAAM,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC;CAAE,CAAC;AAE9D,gDAAgD;AAChD,wBAAgB,QAAQ,CAAC,CAAC,EAAE,GAAG,EAAE,CAAC,GAAG,SAAS,CAAC,CAAC,CAAC,CAEhD;AAED,+BAA+B;AAC/B,MAAM,MAAM,KAAK,CAAC,CAAC,SAAS,MAAM,IAAI,CAAC,GAAG,OAAO,CAAC"}
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/types/index.ts"],"names":[],"mappings":"AAAA,gCAAgC;AAChC,MAAM,MAAM,QAAQ,CAAC,CAAC,IAAI;KACvB,CAAC,IAAI,MAAM,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,SAAS,QAAQ,GAAG,KAAK,GAAG,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC;CAC1D,CAAC;AAEF,kCAAkC;AAClC,MAAM,MAAM,WAAW,CAAC,CAAC,IAAI;KAC1B,CAAC,IAAI,MAAM,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,SAAS,QAAQ,GAAG,CAAC,GAAG,KAAK,GAAG,CAAC,CAAC,CAAC,CAAC;CAC1D,CAAC;AAEF,uDAAuD;AACvD,MAAM,MAAM,SAAS,CAAC,CAAC,EAAE,CAAC,SAAS,MAAM,CAAC,IAAI,IAAI,CAAC,CAAC,EAAE,CAAC,CAAC,GAAG,OAAO,CAAC,IAAI,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;AAE/E,6CAA6C;AAC7C,MAAM,MAAM,SAAS,CAAC,CAAC,IAAI;IAAE,CAAC,UAAU,CAAC,IAAI,MAAM,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC;CAAE,CAAC;AAE9D,gDAAgD;AAChD,wBAAgB,QAAQ,CAAC,CAAC,EAAE,GAAG,EAAE,CAAC,GAAG,SAAS,CAAC,CAAC,CAAC,CAEhD;AAED,4BAA4B;AAC5B,wBAAgB,SAAS,CAAC,CAAC,EAAE,KAAK,EAAE,CAAC,GAAG,SAAS,GAAG,KAAK,IAAI,CAAC,CAE7D;AAED,qDAAqD;AACrD,MAAM,MAAM,QAAQ,CAAC,CAAC,IAAI;KACvB,CAAC,IAAI,MAAM,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC;CACrB,GAAG,EAAE,CAAC;AAEP;;;;;;;;;;GAUG;AACH,MAAM,WAAW,iBAAiB,CAAC,SAAS,SAAS;KAAG,GAAG,IAAI,MAAM,SAAS,GAAG,CAAC,GAAG,IAAI,EAAE,GAAG,EAAE,KAAK,IAAI;CAAE;IACzG,IAAI,CAAC,CAAC,SAAS,MAAM,SAAS,EAAE,KAAK,EAAE,CAAC,EAAE,QAAQ,EAAE,SAAS,CAAC,CAAC,CAAC,GAAG,IAAI,CAAC;IACxE,EAAE,CAAC,CAAC,SAAS,MAAM,SAAS,EAAE,KAAK,EAAE,CAAC,EAAE,QAAQ,EAAE,SAAS,CAAC,CAAC,CAAC,GAAG,IAAI,CAAC;IACtE,GAAG,CAAC,CAAC,SAAS,MAAM,SAAS,EAAE,KAAK,EAAE,CAAC,EAAE,QAAQ,EAAE,SAAS,CAAC,CAAC,CAAC,GAAG,IAAI,CAAC;IACvE,IAAI,CAAC,CAAC,SAAS,MAAM,SAAS,EAAE,KAAK,EAAE,CAAC,EAAE,GAAG,IAAI,EAAE,UAAU,CAAC,SAAS,CAAC,CAAC,CAAC,CAAC,GAAG,OAAO,CAAC;IACtF,cAAc,CAAC,CAAC,SAAS,MAAM,SAAS,EAAE,KAAK,EAAE,CAAC,EAAE,QAAQ,EAAE,SAAS,CAAC,CAAC,CAAC,GAAG,IAAI,CAAC;IAClF,kBAAkB,CAAC,CAAC,SAAS,MAAM,SAAS,EAAE,KAAK,EAAE,CAAC,GAAG,IAAI,CAAC;CAE/D"}
@@ -1,3 +1,6 @@
1
1
  /** Strips methods of a type. */ /** Removes readonly modifiers for an object. */ export function unfreeze(obj) {
2
2
  return obj;
3
3
  }
4
+ /** Is defined type guard */ export function isDefined(value) {
5
+ return value !== undefined;
6
+ }
@@ -6,4 +6,4 @@
6
6
  * @api public
7
7
  */
8
8
  export declare function fileURLToPath(uri: string): string;
9
- //# sourceMappingURL=index.d.ts.map
9
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguZC50cyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy91cmwvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBbUJBOzs7Ozs7R0FNRztBQUVILHdCQUFnQixhQUFhLENBQUMsR0FBRyxFQUFFLE1BQU0sR0FBRyxNQUFNLENBNENqRCJ9
@@ -1 +1 @@
1
- {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/url/index.ts"],"names":[],"mappings":"AAoBA;;;;;;GAMG;AAEH,wBAAgB,aAAa,CAAC,GAAG,EAAE,MAAM,GAAG,MAAM,CA4CjD"}
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/url/index.ts"],"names":[],"mappings":"AAmBA;;;;;;GAMG;AAEH,wBAAgB,aAAa,CAAC,GAAG,EAAE,MAAM,GAAG,MAAM,CA4CjD"}
package/dest/url/index.js CHANGED
@@ -1,4 +1,4 @@
1
- /* eslint-disable */ // Copyright (c) 2014 Nathan Rajlich <nathan@tootallnate.net>
1
+ // Copyright (c) 2014 Nathan Rajlich <nathan@tootallnate.net>
2
2
  // Permission is hereby granted, free of charge, to any person obtaining
3
3
  // a copy of this software and associated documentation files (the
4
4
  // 'Software'), to deal in the Software without restriction, including
@@ -6,4 +6,4 @@ export declare function required<T>(value: T | undefined, errMsg?: string): T;
6
6
  * @param err - Error message to throw if x isn't met.
7
7
  */
8
8
  export declare function assert(x: any, err: string): asserts x;
9
- //# sourceMappingURL=index.d.ts.map
9
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguZC50cyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy92YWxpZGF0aW9uL2luZGV4LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLHlFQUF5RTtBQUN6RSx3QkFBZ0IsUUFBUSxDQUFDLENBQUMsRUFBRSxLQUFLLEVBQUUsQ0FBQyxHQUFHLFNBQVMsRUFBRSxNQUFNLENBQUMsRUFBRSxNQUFNLEdBQUcsQ0FBQyxDQUtwRTtBQUVEOzs7O0dBSUc7QUFDSCx3QkFBZ0IsTUFBTSxDQUFDLENBQUMsRUFBRSxHQUFHLEVBQUUsR0FBRyxFQUFFLE1BQU0sR0FBRyxPQUFPLENBQUMsQ0FBQyxDQUlyRCJ9
package/package.json CHANGED
@@ -1,20 +1,41 @@
1
1
  {
2
2
  "name": "@aztec/foundation",
3
- "version": "0.0.0-test.1",
3
+ "version": "0.0.1-commit.1142ef1",
4
4
  "type": "module",
5
5
  "main": "./dest/index.js",
6
6
  "types": "./dest/index.d.ts",
7
7
  "exports": {
8
- "./eslint": "./.eslintrc.cjs",
9
- "./eslint.docs": "./.eslintrc.docs.cjs",
8
+ "./eslint": "./eslint.config.js",
9
+ "./eslint.docs": "./eslint.config.docs.js",
10
10
  "./prettier": "./.prettierrc.json",
11
11
  "./abi": "./dest/abi/index.js",
12
12
  "./async-map": "./dest/async-map/index.js",
13
13
  "./async-pool": "./dest/async-pool/index.js",
14
+ "./bigint": "./dest/bigint/index.js",
15
+ "./branded-types": "./dest/branded-types/index.js",
14
16
  "./collection": "./dest/collection/index.js",
15
17
  "./config": "./dest/config/index.js",
16
- "./crypto": "./dest/crypto/index.js",
18
+ "./crypto/aes128": "./dest/crypto/aes128/index.js",
19
+ "./crypto/bls": "./dest/crypto/bls/index.js",
20
+ "./crypto/bls/bn254_keystore": "./dest/crypto/bls/bn254_keystore.js",
21
+ "./crypto/bn254": "./dest/crypto/bn254/index.js",
22
+ "./crypto/ecdsa": "./dest/crypto/ecdsa/index.js",
23
+ "./crypto/grumpkin": "./dest/crypto/grumpkin/index.js",
24
+ "./crypto/keccak": "./dest/crypto/keccak/index.js",
25
+ "./crypto/keys": "./dest/crypto/keys/index.js",
26
+ "./crypto/pedersen": "./dest/crypto/pedersen/index.js",
27
+ "./crypto/poseidon": "./dest/crypto/poseidon/index.js",
28
+ "./crypto/random": "./dest/crypto/random/index.js",
29
+ "./crypto/schnorr": "./dest/crypto/schnorr/index.js",
30
+ "./crypto/secp256k1": "./dest/crypto/secp256k1/index.js",
31
+ "./crypto/secp256k1-signer": "./dest/crypto/secp256k1-signer/index.js",
32
+ "./crypto/sha256": "./dest/crypto/sha256/index.js",
33
+ "./crypto/sha512": "./dest/crypto/sha512/index.js",
34
+ "./crypto/signature": "./dest/crypto/signature/index.js",
17
35
  "./crypto/sync": "./dest/crypto/sync/index.js",
36
+ "./curves/bn254": "./dest/curves/bn254/index.js",
37
+ "./curves/grumpkin": "./dest/curves/grumpkin/index.js",
38
+ "./curves/bls12": "./dest/curves/bls12/index.js",
18
39
  "./decorators": "./dest/decorators/index.js",
19
40
  "./error": "./dest/error/index.js",
20
41
  "./eth-address": "./dest/eth-address/index.js",
@@ -28,9 +49,9 @@
28
49
  "./json-rpc/undici": "./dest/json-rpc/client/undici.js",
29
50
  "./json-rpc/test": "./dest/json-rpc/test/index.js",
30
51
  "./iterable": "./dest/iterable/index.js",
52
+ "./iterator": "./dest/iterator/index.js",
31
53
  "./log": "./dest/log/index.js",
32
54
  "./mutex": "./dest/mutex/index.js",
33
- "./fields": "./dest/fields/index.js",
34
55
  "./retry": "./dest/retry/index.js",
35
56
  "./running-promise": "./dest/running-promise/index.js",
36
57
  "./serialize": "./dest/serialize/index.js",
@@ -38,8 +59,6 @@
38
59
  "./timer": "./dest/timer/index.js",
39
60
  "./transport": "./dest/transport/index.js",
40
61
  "./trees": "./dest/trees/index.js",
41
- "./wasm": "./dest/wasm/index.js",
42
- "./worker": "./dest/worker/index.js",
43
62
  "./bigint-buffer": "./dest/bigint-buffer/index.js",
44
63
  "./types": "./dest/types/index.js",
45
64
  "./schemas": "./dest/schemas/index.js",
@@ -48,19 +67,19 @@
48
67
  "./noir": "./dest/noir/index.js",
49
68
  "./testing": "./dest/testing/index.js",
50
69
  "./testing/files": "./dest/testing/files/index.js",
70
+ "./profiler": "./dest/profiler/index.js",
51
71
  "./array": "./dest/array/index.js",
52
72
  "./validation": "./dest/validation/index.js",
53
73
  "./promise": "./dest/promise/index.js",
54
74
  "./string": "./dest/string/index.js",
55
- "./message": "./dest/message/index.js"
75
+ "./message": "./dest/message/index.js",
76
+ "./number": "./dest/number/index.js"
56
77
  },
57
78
  "scripts": {
58
- "build": "yarn clean && tsc -b",
59
- "build:dev": "tsc -b --watch",
79
+ "build": "yarn clean && ../scripts/tsc.sh",
80
+ "build:dev": "../scripts/tsc.sh --watch",
60
81
  "clean": "rm -rf ./dest .tsbuildinfo",
61
82
  "generate": "true",
62
- "formatting": "run -T prettier --check ./src && run -T eslint ./src",
63
- "formatting:fix": "run -T eslint --fix ./src && run -T prettier -w ./src",
64
83
  "test": "NODE_NO_WARNINGS=1 node --experimental-vm-modules ../node_modules/.bin/jest --passWithNoTests --maxWorkers=${JEST_MAX_WORKERS:-8}"
65
84
  },
66
85
  "inherits": [
@@ -96,74 +115,69 @@
96
115
  ],
97
116
  "testTimeout": 120000,
98
117
  "setupFilesAfterEnv": [
99
- "../../foundation/src/jest/setup.mjs"
118
+ "../../foundation/src/jest/setupAfterEnv.mjs"
100
119
  ],
101
120
  "setupFiles": [
102
121
  "../../foundation/src/jest/setup.mjs"
103
- ]
122
+ ],
123
+ "testEnvironment": "../../foundation/src/jest/env.mjs"
104
124
  },
105
125
  "dependencies": {
106
- "@aztec/bb.js": "0.0.0-test.1",
126
+ "@aztec/bb.js": "0.0.1-commit.1142ef1",
107
127
  "@koa/cors": "^5.0.0",
108
- "@noble/curves": "^1.2.0",
128
+ "@noble/curves": "=1.7.0",
129
+ "@noble/hashes": "^1.6.1",
130
+ "@scure/bip39": "^2.0.1",
109
131
  "bn.js": "^5.2.1",
110
- "c-kzg": "4.0.0-alpha.1",
111
132
  "colorette": "^2.0.20",
112
- "debug": "^4.3.4",
113
133
  "detect-node": "^2.1.0",
114
- "elliptic": "^6.5.4",
115
134
  "hash.js": "^1.1.7",
116
- "koa": "^2.14.2",
135
+ "koa": "^2.16.1",
117
136
  "koa-bodyparser": "^4.4.0",
118
137
  "koa-compress": "^5.1.0",
119
- "koa-router": "^12.0.0",
138
+ "koa-router": "^13.1.1",
120
139
  "leveldown": "^6.1.1",
121
- "levelup": "^5.1.1",
122
140
  "lodash.chunk": "^4.2.0",
123
141
  "lodash.clonedeepwith": "^4.5.0",
124
- "memdown": "^6.1.1",
125
142
  "pako": "^2.1.0",
126
143
  "pino": "^9.5.0",
127
144
  "pino-pretty": "^13.0.0",
128
145
  "sha3": "^2.1.4",
129
- "undici": "^7.3.0",
146
+ "undici": "^5.28.5",
130
147
  "zod": "^3.23.8"
131
148
  },
132
149
  "devDependencies": {
133
- "@jest/globals": "^29.5.0",
150
+ "@jest/globals": "^30.0.0",
134
151
  "@libp2p/interface": "1.3.1",
135
- "@types/bn.js": "^5.1.3",
136
- "@types/debug": "^4.1.7",
137
152
  "@types/detect-node": "^2.0.0",
138
- "@types/elliptic": "^6.4.16",
139
- "@types/jest": "^29.5.0",
140
- "@types/koa": "^2.13.5",
153
+ "@types/jest": "^30.0.0",
154
+ "@types/koa": "^2.15.0",
141
155
  "@types/koa-bodyparser": "^4.3.10",
142
156
  "@types/koa-compress": "^4.0.3",
143
157
  "@types/koa-router": "^7.4.4",
144
158
  "@types/koa__cors": "^4.0.0",
145
159
  "@types/leveldown": "^4.0.3",
146
- "@types/levelup": "^5.1.2",
147
160
  "@types/lodash.chunk": "^4.2.9",
148
161
  "@types/lodash.clonedeepwith": "^4.5.7",
149
- "@types/memdown": "^3.0.1",
150
- "@types/node": "^18.7.23",
162
+ "@types/node": "^22.15.17",
151
163
  "@types/pako": "^2.0.0",
152
164
  "@types/supertest": "^2.0.12",
153
- "@typescript-eslint/eslint-plugin": "^6.2.1",
154
- "@typescript-eslint/parser": "^6.2.1",
165
+ "@typescript/native-preview": "7.0.0-dev.20251126.1",
155
166
  "comlink": "^4.4.1",
156
- "eslint": "^8.21.0",
157
- "eslint-config-prettier": "^8.5.0",
158
- "eslint-plugin-jsdoc": "^40.1.0",
159
- "eslint-plugin-no-only-tests": "^3.1.0",
160
- "eslint-plugin-tsdoc": "^0.2.17",
161
- "jest": "^29.5.0",
162
- "prettier": "^2.7.1",
167
+ "eslint": "^9.26.0",
168
+ "eslint-config-prettier": "^10.1.5",
169
+ "eslint-plugin-import": "^2.31.0",
170
+ "eslint-plugin-jsdoc": "^50.6.14",
171
+ "eslint-plugin-no-only-tests": "^3.3.0",
172
+ "eslint-plugin-tsdoc": "^0.4.0",
173
+ "globals": "^16.1.0",
174
+ "jest": "^30.0.0",
175
+ "prettier": "^3.5.3",
163
176
  "supertest": "^6.3.3",
164
177
  "ts-node": "^10.9.1",
165
- "typescript": "^5.0.4",
166
- "viem": "2.22.8"
178
+ "typescript": "^5.3.3",
179
+ "typescript-eslint": "^8.32.1",
180
+ "viem": "npm:@aztec/viem@2.38.2"
167
181
  },
168
182
  "files": [
169
183
  "dest",
@@ -171,6 +185,6 @@
171
185
  "!*.test.*"
172
186
  ],
173
187
  "engines": {
174
- "node": ">=18"
188
+ "node": ">=20.10"
175
189
  }
176
190
  }
@@ -42,22 +42,6 @@ export async function makeTupleAsync<T, N extends number>(length: N, fn: (i: num
42
42
  )) as Tuple<T, N>;
43
43
  }
44
44
 
45
- /**
46
- * Create an array over an integer range, filled with a function 'fn'. However, the latter half of the array are set to zeros.
47
- * see `makeTuple` above.
48
- * @param n - The number of integers.
49
- * @param fn - The generator function.
50
- * @returns The array of numbers.
51
- */
52
- export function makeHalfFullTuple<T, N extends number>(
53
- length: N,
54
- fn: (i: number) => T,
55
- offset = 0,
56
- makeEmpty: () => T,
57
- ) {
58
- return Array.from({ length }, (_: any, i: number) => (i < length / 2 ? fn(i + offset) : makeEmpty())) as Tuple<T, N>;
59
- }
60
-
61
45
  /**
62
46
  * Assert a member of an object is a certain length.
63
47
  * @param obj - An object.
@@ -148,3 +132,16 @@ export function assertRightPadded<T>(arr: T[], isEmpty: (item: T) => boolean) {
148
132
  }
149
133
  }
150
134
  }
135
+
136
+ /**
137
+ * Shuffles an array in-place using the Fisher-Yates algorith,
138
+ * @param arr - The array to shuffle
139
+ */
140
+ export function shuffle<T>(arr: T[]): void {
141
+ for (let i = arr.length - 1; i > 0; i--) {
142
+ const j = (Math.random() * (i + 1)) | 0;
143
+ const temp = arr[i];
144
+ arr[i] = arr[j];
145
+ arr[j] = temp;
146
+ }
147
+ }
@@ -1 +1,2 @@
1
1
  export * from './array.js';
2
+ export * from './sorted_array.js';
@@ -0,0 +1,133 @@
1
+ type Cmp<T> = (a: T, b: T) => -1 | 0 | 1;
2
+
3
+ export function dedupeSortedArray<T>(arr: T[], cmp: Cmp<T>): void {
4
+ for (let i = 0; i < arr.length; i++) {
5
+ let j = i + 1;
6
+ for (; j < arr.length; j++) {
7
+ const res = cmp(arr[i], arr[j]);
8
+ if (res === 0) {
9
+ continue;
10
+ } else if (res < 0) {
11
+ break;
12
+ } else {
13
+ throw new Error('Array not sorted');
14
+ }
15
+ }
16
+
17
+ if (j - i > 1) {
18
+ arr.splice(i + 1, j - i - 1);
19
+ }
20
+ }
21
+ }
22
+
23
+ export function insertIntoSortedArray<T>(arr: T[], item: T, cmp: Cmp<T>, allowDuplicates = true): boolean {
24
+ let start = 0;
25
+ let end = arr.length;
26
+
27
+ while (start < end) {
28
+ const mid = start + (((end - start) / 2) | 0);
29
+ const comparison = cmp(arr[mid], item);
30
+
31
+ if (comparison < 0) {
32
+ start = mid + 1;
33
+ } else {
34
+ end = mid;
35
+ }
36
+ }
37
+
38
+ if (!allowDuplicates) {
39
+ // Check element at insertion point
40
+ if (start < arr.length && cmp(arr[start], item) === 0) {
41
+ return false;
42
+ }
43
+
44
+ // Check element before insertion point (in case we landed after duplicates)
45
+ if (start > 0 && cmp(arr[start - 1], item) === 0) {
46
+ return false;
47
+ }
48
+ }
49
+
50
+ arr.splice(start, 0, item);
51
+ return true;
52
+ }
53
+
54
+ export function findIndexInSortedArray<T, N>(values: T[], needle: N, cmp: (a: T, b: N) => number): number {
55
+ let start = 0;
56
+ let end = values.length - 1;
57
+
58
+ while (start <= end) {
59
+ const mid = start + (((end - start) / 2) | 0);
60
+ const comparison = cmp(values[mid], needle);
61
+
62
+ if (comparison === 0) {
63
+ return mid;
64
+ }
65
+
66
+ if (comparison > 0) {
67
+ end = mid - 1;
68
+ } else {
69
+ start = mid + 1;
70
+ }
71
+ }
72
+
73
+ return -1;
74
+ }
75
+
76
+ export function findInSortedArray<T, N>(values: T[], needle: N, cmp: (a: T, b: N) => number): T | undefined {
77
+ const idx = findIndexInSortedArray(values, needle, cmp);
78
+ return idx > -1 ? values[idx] : undefined;
79
+ }
80
+
81
+ export function removeAnyOf<T, N>(arr: T[], vals: N[], cmp: (a: T, b: N) => -1 | 0 | 1): void {
82
+ let writeIdx = 0;
83
+ let readIdx = 0;
84
+ let valIdx = 0;
85
+
86
+ while (readIdx < arr.length && valIdx < vals.length) {
87
+ const comparison = cmp(arr[readIdx], vals[valIdx]);
88
+
89
+ if (comparison < 0) {
90
+ arr[writeIdx++] = arr[readIdx++];
91
+ } else if (comparison > 0) {
92
+ valIdx++;
93
+ } else {
94
+ readIdx++;
95
+ }
96
+ }
97
+
98
+ while (readIdx < arr.length) {
99
+ arr[writeIdx++] = arr[readIdx++];
100
+ }
101
+
102
+ arr.length = writeIdx;
103
+ }
104
+
105
+ export function removeFromSortedArray<T, N>(arr: T[], val: N, cmp: (a: T, b: N) => -1 | 0 | 1) {
106
+ const idx = findIndexInSortedArray(arr, val, cmp);
107
+ if (idx > -1) {
108
+ arr.splice(idx, 1);
109
+ }
110
+ }
111
+
112
+ export function merge<T>(arr: T[], toInsert: T[], cmp: (a: T, b: T) => -1 | 0 | 1): void {
113
+ const result = new Array<T>(arr.length + toInsert.length);
114
+ let i = 0,
115
+ j = 0,
116
+ k = 0;
117
+
118
+ while (i < arr.length && j < toInsert.length) {
119
+ result[k++] = cmp(arr[i], toInsert[j]) <= 0 ? arr[i++] : toInsert[j++];
120
+ }
121
+
122
+ while (i < arr.length) {
123
+ result[k++] = arr[i++];
124
+ }
125
+ while (j < toInsert.length) {
126
+ result[k++] = toInsert[j++];
127
+ }
128
+
129
+ for (i = 0; i < result.length; i++) {
130
+ arr[i] = result[i];
131
+ }
132
+ arr.length = result.length;
133
+ }