@aztec/simulator 0.74.0 → 0.75.0-commit.c03ba01a2a4122e43e90d5133ba017e54b90e9d2

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 (304) hide show
  1. package/dest/acvm/acvm.js +18 -21
  2. package/dest/acvm/acvm_types.js +3 -2
  3. package/dest/acvm/deserialize.js +9 -13
  4. package/dest/acvm/index.js +0 -1
  5. package/dest/acvm/oracle/index.js +0 -1
  6. package/dest/acvm/oracle/oracle.js +42 -23
  7. package/dest/acvm/oracle/typed_oracle.js +36 -38
  8. package/dest/acvm/serialize.js +7 -14
  9. package/dest/avm/avm_context.js +24 -27
  10. package/dest/avm/avm_contract_call_result.js +12 -7
  11. package/dest/avm/avm_execution_environment.js +10 -7
  12. package/dest/avm/avm_gas.js +93 -56
  13. package/dest/avm/avm_machine_state.js +60 -61
  14. package/dest/avm/avm_memory_types.js +166 -255
  15. package/dest/avm/avm_simulator.js +68 -47
  16. package/dest/avm/avm_tree.js +282 -276
  17. package/dest/avm/bytecode_utils.js +8 -6
  18. package/dest/avm/errors.js +46 -63
  19. package/dest/avm/fixtures/avm_simulation_tester.js +18 -17
  20. package/dest/avm/fixtures/base_avm_simulation_tester.js +21 -16
  21. package/dest/avm/fixtures/index.js +27 -26
  22. package/dest/avm/fixtures/simple_contract_data_source.js +9 -13
  23. package/dest/avm/index.js +0 -1
  24. package/dest/avm/journal/index.js +0 -1
  25. package/dest/avm/journal/journal.js +147 -200
  26. package/dest/avm/journal/nullifiers.js +43 -46
  27. package/dest/avm/journal/public_storage.js +73 -87
  28. package/dest/avm/opcodes/accrued_substate.js +140 -110
  29. package/dest/avm/opcodes/addressing_mode.js +29 -31
  30. package/dest/avm/opcodes/arithmetic.js +17 -15
  31. package/dest/avm/opcodes/bitwise.js +40 -26
  32. package/dest/avm/opcodes/comparators.js +12 -10
  33. package/dest/avm/opcodes/contract.js +31 -29
  34. package/dest/avm/opcodes/control_flow.js +47 -43
  35. package/dest/avm/opcodes/conversion.js +30 -26
  36. package/dest/avm/opcodes/ec_add.js +35 -34
  37. package/dest/avm/opcodes/environment_getters.js +33 -33
  38. package/dest/avm/opcodes/external_calls.js +83 -74
  39. package/dest/avm/opcodes/hashing.js +69 -61
  40. package/dest/avm/opcodes/index.js +0 -1
  41. package/dest/avm/opcodes/instruction.js +31 -40
  42. package/dest/avm/opcodes/instruction_impl.js +12 -15
  43. package/dest/avm/opcodes/memory.js +177 -156
  44. package/dest/avm/opcodes/misc.js +27 -25
  45. package/dest/avm/opcodes/multi_scalar_mul.js +43 -41
  46. package/dest/avm/opcodes/storage.js +28 -25
  47. package/dest/avm/serialization/buffer_cursor.js +4 -4
  48. package/dest/avm/serialization/bytecode_serialization.js +292 -89
  49. package/dest/avm/serialization/instruction_serialization.js +67 -28
  50. package/dest/avm/test_utils.js +6 -9
  51. package/dest/client/client_execution_context.js +197 -219
  52. package/dest/client/db_oracle.js +4 -7
  53. package/dest/client/execution_note_cache.js +80 -81
  54. package/dest/client/index.js +0 -1
  55. package/dest/client/pick_notes.js +27 -30
  56. package/dest/client/private_execution.js +13 -14
  57. package/dest/client/simulator.js +44 -48
  58. package/dest/client/unconstrained_execution.js +8 -11
  59. package/dest/client/view_data_oracle.js +130 -139
  60. package/dest/common/debug_fn_name.js +1 -4
  61. package/dest/common/errors.js +30 -39
  62. package/dest/common/hashed_values_cache.js +16 -20
  63. package/dest/common/index.js +0 -1
  64. package/dest/common/message_load_oracle_inputs.js +7 -7
  65. package/dest/common/simulation_provider.js +3 -6
  66. package/dest/common.js +0 -1
  67. package/dest/providers/acvm_native.js +46 -32
  68. package/dest/providers/acvm_wasm.js +18 -10
  69. package/dest/providers/acvm_wasm_with_blobs.js +2 -5
  70. package/dest/providers/factory.js +5 -5
  71. package/dest/providers/index.js +0 -1
  72. package/dest/public/bytecode_errors.js +1 -2
  73. package/dest/public/db_interfaces.js +1 -2
  74. package/dest/public/execution.js +2 -4
  75. package/dest/public/executor_metrics.js +16 -12
  76. package/dest/public/fee_payment.js +2 -5
  77. package/dest/public/fixtures/index.js +0 -1
  78. package/dest/public/fixtures/public_tx_simulation_tester.js +13 -17
  79. package/dest/public/fixtures/utils.js +11 -14
  80. package/dest/public/index.js +0 -1
  81. package/dest/public/public_db_sources.js +79 -87
  82. package/dest/public/public_processor.js +310 -306
  83. package/dest/public/public_processor_metrics.js +46 -27
  84. package/dest/public/public_tx_context.js +97 -118
  85. package/dest/public/public_tx_simulator.js +299 -314
  86. package/dest/public/side_effect_errors.js +1 -2
  87. package/dest/public/side_effect_trace.js +44 -71
  88. package/dest/public/side_effect_trace_interface.js +1 -2
  89. package/dest/public/unique_class_ids.js +22 -27
  90. package/dest/public/utils.js +16 -11
  91. package/dest/server.js +0 -1
  92. package/dest/stats/index.js +0 -1
  93. package/dest/stats/stats.js +1 -2
  94. package/dest/test/utils.js +5 -4
  95. package/package.json +11 -11
  96. package/src/acvm/oracle/typed_oracle.ts +34 -34
  97. package/src/avm/avm_machine_state.ts +18 -14
  98. package/src/avm/avm_memory_types.ts +43 -183
  99. package/src/avm/avm_simulator.ts +37 -11
  100. package/src/avm/opcodes/accrued_substate.ts +7 -21
  101. package/src/avm/opcodes/addressing_mode.ts +9 -2
  102. package/src/avm/opcodes/arithmetic.ts +1 -3
  103. package/src/avm/opcodes/bitwise.ts +2 -6
  104. package/src/avm/opcodes/comparators.ts +1 -3
  105. package/src/avm/opcodes/contract.ts +1 -3
  106. package/src/avm/opcodes/control_flow.ts +1 -9
  107. package/src/avm/opcodes/conversion.ts +1 -3
  108. package/src/avm/opcodes/ec_add.ts +1 -3
  109. package/src/avm/opcodes/environment_getters.ts +1 -3
  110. package/src/avm/opcodes/external_calls.ts +3 -6
  111. package/src/avm/opcodes/hashing.ts +3 -9
  112. package/src/avm/opcodes/memory.ts +6 -20
  113. package/src/avm/opcodes/misc.ts +1 -3
  114. package/src/avm/opcodes/multi_scalar_mul.ts +1 -7
  115. package/src/avm/opcodes/storage.ts +2 -6
  116. package/src/client/index.ts +2 -2
  117. package/dest/acvm/acvm.d.ts +0 -35
  118. package/dest/acvm/acvm.d.ts.map +0 -1
  119. package/dest/acvm/acvm_types.d.ts +0 -10
  120. package/dest/acvm/acvm_types.d.ts.map +0 -1
  121. package/dest/acvm/deserialize.d.ts +0 -36
  122. package/dest/acvm/deserialize.d.ts.map +0 -1
  123. package/dest/acvm/index.d.ts +0 -6
  124. package/dest/acvm/index.d.ts.map +0 -1
  125. package/dest/acvm/oracle/index.d.ts +0 -14
  126. package/dest/acvm/oracle/index.d.ts.map +0 -1
  127. package/dest/acvm/oracle/oracle.d.ts +0 -49
  128. package/dest/acvm/oracle/oracle.d.ts.map +0 -1
  129. package/dest/acvm/oracle/typed_oracle.d.ts +0 -75
  130. package/dest/acvm/oracle/typed_oracle.d.ts.map +0 -1
  131. package/dest/acvm/serialize.d.ts +0 -20
  132. package/dest/acvm/serialize.d.ts.map +0 -1
  133. package/dest/avm/avm_context.d.ts +0 -39
  134. package/dest/avm/avm_context.d.ts.map +0 -1
  135. package/dest/avm/avm_contract_call_result.d.ts +0 -30
  136. package/dest/avm/avm_contract_call_result.d.ts.map +0 -1
  137. package/dest/avm/avm_execution_environment.d.ts +0 -21
  138. package/dest/avm/avm_execution_environment.d.ts.map +0 -1
  139. package/dest/avm/avm_gas.d.ts +0 -60
  140. package/dest/avm/avm_gas.d.ts.map +0 -1
  141. package/dest/avm/avm_machine_state.d.ts +0 -93
  142. package/dest/avm/avm_machine_state.d.ts.map +0 -1
  143. package/dest/avm/avm_memory_types.d.ts +0 -310
  144. package/dest/avm/avm_memory_types.d.ts.map +0 -1
  145. package/dest/avm/avm_simulator.d.ts +0 -37
  146. package/dest/avm/avm_simulator.d.ts.map +0 -1
  147. package/dest/avm/avm_tree.d.ts +0 -281
  148. package/dest/avm/avm_tree.d.ts.map +0 -1
  149. package/dest/avm/bytecode_utils.d.ts +0 -5
  150. package/dest/avm/bytecode_utils.d.ts.map +0 -1
  151. package/dest/avm/errors.d.ts +0 -121
  152. package/dest/avm/errors.d.ts.map +0 -1
  153. package/dest/avm/fixtures/avm_simulation_tester.d.ts +0 -21
  154. package/dest/avm/fixtures/avm_simulation_tester.d.ts.map +0 -1
  155. package/dest/avm/fixtures/base_avm_simulation_tester.d.ts +0 -35
  156. package/dest/avm/fixtures/base_avm_simulation_tester.d.ts.map +0 -1
  157. package/dest/avm/fixtures/index.d.ts +0 -67
  158. package/dest/avm/fixtures/index.d.ts.map +0 -1
  159. package/dest/avm/fixtures/simple_contract_data_source.d.ts +0 -31
  160. package/dest/avm/fixtures/simple_contract_data_source.d.ts.map +0 -1
  161. package/dest/avm/index.d.ts +0 -4
  162. package/dest/avm/index.d.ts.map +0 -1
  163. package/dest/avm/journal/index.d.ts +0 -2
  164. package/dest/avm/journal/index.d.ts.map +0 -1
  165. package/dest/avm/journal/journal.d.ts +0 -176
  166. package/dest/avm/journal/journal.d.ts.map +0 -1
  167. package/dest/avm/journal/nullifiers.d.ts +0 -62
  168. package/dest/avm/journal/nullifiers.d.ts.map +0 -1
  169. package/dest/avm/journal/public_storage.d.ts +0 -66
  170. package/dest/avm/journal/public_storage.d.ts.map +0 -1
  171. package/dest/avm/opcodes/accrued_substate.d.ts +0 -75
  172. package/dest/avm/opcodes/accrued_substate.d.ts.map +0 -1
  173. package/dest/avm/opcodes/addressing_mode.d.ts +0 -27
  174. package/dest/avm/opcodes/addressing_mode.d.ts.map +0 -1
  175. package/dest/avm/opcodes/arithmetic.d.ts +0 -37
  176. package/dest/avm/opcodes/arithmetic.d.ts.map +0 -1
  177. package/dest/avm/opcodes/bitwise.d.ts +0 -50
  178. package/dest/avm/opcodes/bitwise.d.ts.map +0 -1
  179. package/dest/avm/opcodes/comparators.d.ts +0 -25
  180. package/dest/avm/opcodes/comparators.d.ts.map +0 -1
  181. package/dest/avm/opcodes/contract.d.ts +0 -21
  182. package/dest/avm/opcodes/contract.d.ts.map +0 -1
  183. package/dest/avm/opcodes/control_flow.d.ts +0 -41
  184. package/dest/avm/opcodes/control_flow.d.ts.map +0 -1
  185. package/dest/avm/opcodes/conversion.d.ts +0 -17
  186. package/dest/avm/opcodes/conversion.d.ts.map +0 -1
  187. package/dest/avm/opcodes/ec_add.d.ts +0 -19
  188. package/dest/avm/opcodes/ec_add.d.ts.map +0 -1
  189. package/dest/avm/opcodes/environment_getters.d.ts +0 -28
  190. package/dest/avm/opcodes/environment_getters.d.ts.map +0 -1
  191. package/dest/avm/opcodes/external_calls.d.ts +0 -50
  192. package/dest/avm/opcodes/external_calls.d.ts.map +0 -1
  193. package/dest/avm/opcodes/hashing.d.ts +0 -36
  194. package/dest/avm/opcodes/hashing.d.ts.map +0 -1
  195. package/dest/avm/opcodes/index.d.ts +0 -16
  196. package/dest/avm/opcodes/index.d.ts.map +0 -1
  197. package/dest/avm/opcodes/instruction.d.ts +0 -70
  198. package/dest/avm/opcodes/instruction.d.ts.map +0 -1
  199. package/dest/avm/opcodes/instruction_impl.d.ts +0 -19
  200. package/dest/avm/opcodes/instruction_impl.d.ts.map +0 -1
  201. package/dest/avm/opcodes/memory.d.ts +0 -74
  202. package/dest/avm/opcodes/memory.d.ts.map +0 -1
  203. package/dest/avm/opcodes/misc.d.ts +0 -17
  204. package/dest/avm/opcodes/misc.d.ts.map +0 -1
  205. package/dest/avm/opcodes/multi_scalar_mul.d.ts +0 -16
  206. package/dest/avm/opcodes/multi_scalar_mul.d.ts.map +0 -1
  207. package/dest/avm/opcodes/storage.d.ts +0 -24
  208. package/dest/avm/opcodes/storage.d.ts.map +0 -1
  209. package/dest/avm/serialization/buffer_cursor.d.ts +0 -28
  210. package/dest/avm/serialization/buffer_cursor.d.ts.map +0 -1
  211. package/dest/avm/serialization/bytecode_serialization.d.ts +0 -21
  212. package/dest/avm/serialization/bytecode_serialization.d.ts.map +0 -1
  213. package/dest/avm/serialization/instruction_serialization.d.ts +0 -105
  214. package/dest/avm/serialization/instruction_serialization.d.ts.map +0 -1
  215. package/dest/avm/test_utils.d.ts +0 -16
  216. package/dest/avm/test_utils.d.ts.map +0 -1
  217. package/dest/client/client_execution_context.d.ts +0 -214
  218. package/dest/client/client_execution_context.d.ts.map +0 -1
  219. package/dest/client/db_oracle.d.ts +0 -229
  220. package/dest/client/db_oracle.d.ts.map +0 -1
  221. package/dest/client/execution_note_cache.d.ts +0 -93
  222. package/dest/client/execution_note_cache.d.ts.map +0 -1
  223. package/dest/client/index.d.ts +0 -15
  224. package/dest/client/index.d.ts.map +0 -1
  225. package/dest/client/pick_notes.d.ts +0 -85
  226. package/dest/client/pick_notes.d.ts.map +0 -1
  227. package/dest/client/private_execution.d.ts +0 -19
  228. package/dest/client/private_execution.d.ts.map +0 -1
  229. package/dest/client/simulator.d.ts +0 -60
  230. package/dest/client/simulator.d.ts.map +0 -1
  231. package/dest/client/unconstrained_execution.d.ts +0 -10
  232. package/dest/client/unconstrained_execution.d.ts.map +0 -1
  233. package/dest/client/view_data_oracle.d.ts +0 -159
  234. package/dest/client/view_data_oracle.d.ts.map +0 -1
  235. package/dest/common/debug_fn_name.d.ts +0 -4
  236. package/dest/common/debug_fn_name.d.ts.map +0 -1
  237. package/dest/common/errors.d.ts +0 -54
  238. package/dest/common/errors.d.ts.map +0 -1
  239. package/dest/common/hashed_values_cache.d.ts +0 -28
  240. package/dest/common/hashed_values_cache.d.ts.map +0 -1
  241. package/dest/common/index.d.ts +0 -3
  242. package/dest/common/index.d.ts.map +0 -1
  243. package/dest/common/message_load_oracle_inputs.d.ts +0 -15
  244. package/dest/common/message_load_oracle_inputs.d.ts.map +0 -1
  245. package/dest/common/simulation_provider.d.ts +0 -19
  246. package/dest/common/simulation_provider.d.ts.map +0 -1
  247. package/dest/common.d.ts +0 -2
  248. package/dest/common.d.ts.map +0 -1
  249. package/dest/providers/acvm_native.d.ts +0 -40
  250. package/dest/providers/acvm_native.d.ts.map +0 -1
  251. package/dest/providers/acvm_wasm.d.ts +0 -15
  252. package/dest/providers/acvm_wasm.d.ts.map +0 -1
  253. package/dest/providers/acvm_wasm_with_blobs.d.ts +0 -19
  254. package/dest/providers/acvm_wasm_with_blobs.d.ts.map +0 -1
  255. package/dest/providers/factory.d.ts +0 -12
  256. package/dest/providers/factory.d.ts.map +0 -1
  257. package/dest/providers/index.d.ts +0 -5
  258. package/dest/providers/index.d.ts.map +0 -1
  259. package/dest/public/bytecode_errors.d.ts +0 -4
  260. package/dest/public/bytecode_errors.d.ts.map +0 -1
  261. package/dest/public/db_interfaces.d.ts +0 -105
  262. package/dest/public/db_interfaces.d.ts.map +0 -1
  263. package/dest/public/execution.d.ts +0 -102
  264. package/dest/public/execution.d.ts.map +0 -1
  265. package/dest/public/executor_metrics.d.ts +0 -13
  266. package/dest/public/executor_metrics.d.ts.map +0 -1
  267. package/dest/public/fee_payment.d.ts +0 -11
  268. package/dest/public/fee_payment.d.ts.map +0 -1
  269. package/dest/public/fixtures/index.d.ts +0 -3
  270. package/dest/public/fixtures/index.d.ts.map +0 -1
  271. package/dest/public/fixtures/public_tx_simulation_tester.d.ts +0 -21
  272. package/dest/public/fixtures/public_tx_simulation_tester.d.ts.map +0 -1
  273. package/dest/public/fixtures/utils.d.ts +0 -17
  274. package/dest/public/fixtures/utils.d.ts.map +0 -1
  275. package/dest/public/index.d.ts +0 -9
  276. package/dest/public/index.d.ts.map +0 -1
  277. package/dest/public/public_db_sources.d.ts +0 -81
  278. package/dest/public/public_db_sources.d.ts.map +0 -1
  279. package/dest/public/public_processor.d.ts +0 -72
  280. package/dest/public/public_processor.d.ts.map +0 -1
  281. package/dest/public/public_processor_metrics.d.ts +0 -27
  282. package/dest/public/public_processor_metrics.d.ts.map +0 -1
  283. package/dest/public/public_tx_context.d.ts +0 -131
  284. package/dest/public/public_tx_context.d.ts.map +0 -1
  285. package/dest/public/public_tx_simulator.d.ts +0 -99
  286. package/dest/public/public_tx_simulator.d.ts.map +0 -1
  287. package/dest/public/side_effect_errors.d.ts +0 -4
  288. package/dest/public/side_effect_errors.d.ts.map +0 -1
  289. package/dest/public/side_effect_trace.d.ts +0 -126
  290. package/dest/public/side_effect_trace.d.ts.map +0 -1
  291. package/dest/public/side_effect_trace_interface.d.ts +0 -32
  292. package/dest/public/side_effect_trace_interface.d.ts.map +0 -1
  293. package/dest/public/unique_class_ids.d.ts +0 -37
  294. package/dest/public/unique_class_ids.d.ts.map +0 -1
  295. package/dest/public/utils.d.ts +0 -5
  296. package/dest/public/utils.d.ts.map +0 -1
  297. package/dest/server.d.ts +0 -6
  298. package/dest/server.d.ts.map +0 -1
  299. package/dest/stats/index.d.ts +0 -2
  300. package/dest/stats/index.d.ts.map +0 -1
  301. package/dest/stats/stats.d.ts +0 -4
  302. package/dest/stats/stats.d.ts.map +0 -1
  303. package/dest/test/utils.d.ts +0 -12
  304. package/dest/test/utils.d.ts.map +0 -1
@@ -7,18 +7,15 @@ import { pickNotes } from './pick_notes.js';
7
7
  /**
8
8
  * The execution context for a client view tx simulation.
9
9
  * It only reads data from data sources. Nothing will be updated or created during this simulation.
10
- */
11
- export class ViewDataOracle extends TypedOracle {
12
- constructor(contractAddress,
13
- /** List of transient auth witnesses to be used during this simulation */
14
- authWitnesses, db, aztecNode, log = createLogger('simulator:client_view_context'), scopes) {
15
- super();
16
- this.contractAddress = contractAddress;
17
- this.authWitnesses = authWitnesses;
18
- this.db = db;
19
- this.aztecNode = aztecNode;
20
- this.log = log;
21
- this.scopes = scopes;
10
+ */ export class ViewDataOracle extends TypedOracle {
11
+ contractAddress;
12
+ authWitnesses;
13
+ db;
14
+ aztecNode;
15
+ log;
16
+ scopes;
17
+ constructor(contractAddress, /** List of transient auth witnesses to be used during this simulation */ authWitnesses, db, aztecNode, log = createLogger('simulator:client_view_context'), scopes){
18
+ super(), this.contractAddress = contractAddress, this.authWitnesses = authWitnesses, this.db = db, this.aztecNode = aztecNode, this.log = log, this.scopes = scopes;
22
19
  }
23
20
  getBlockNumber() {
24
21
  return this.aztecNode.getBlockNumber();
@@ -27,66 +24,60 @@ export class ViewDataOracle extends TypedOracle {
27
24
  return Promise.resolve(this.contractAddress);
28
25
  }
29
26
  getChainId() {
30
- return Promise.resolve(this.aztecNode.getChainId().then(id => new Fr(id)));
27
+ return Promise.resolve(this.aztecNode.getChainId().then((id)=>new Fr(id)));
31
28
  }
32
29
  getVersion() {
33
- return Promise.resolve(this.aztecNode.getVersion().then(v => new Fr(v)));
30
+ return Promise.resolve(this.aztecNode.getVersion().then((v)=>new Fr(v)));
34
31
  }
35
32
  /**
36
- * Retrieve keys associated with a specific master public key and app address.
37
- * @param pkMHash - The master public key hash.
38
- * @returns A Promise that resolves to nullifier keys.
39
- * @throws If the keys are not registered in the key store.
40
- */
41
- getKeyValidationRequest(pkMHash) {
33
+ * Retrieve keys associated with a specific master public key and app address.
34
+ * @param pkMHash - The master public key hash.
35
+ * @returns A Promise that resolves to nullifier keys.
36
+ * @throws If the keys are not registered in the key store.
37
+ */ getKeyValidationRequest(pkMHash) {
42
38
  return this.db.getKeyValidationRequest(pkMHash, this.contractAddress);
43
39
  }
44
40
  /**
45
- * Fetches the index and sibling path of a leaf at a given block from a given tree.
46
- * @param blockNumber - The block number at which to get the membership witness.
47
- * @param treeId - Id of the tree to get the sibling path from.
48
- * @param leafValue - The leaf value
49
- * @returns The index and sibling path concatenated [index, sibling_path]
50
- */
51
- getMembershipWitness(blockNumber, treeId, leafValue) {
41
+ * Fetches the index and sibling path of a leaf at a given block from a given tree.
42
+ * @param blockNumber - The block number at which to get the membership witness.
43
+ * @param treeId - Id of the tree to get the sibling path from.
44
+ * @param leafValue - The leaf value
45
+ * @returns The index and sibling path concatenated [index, sibling_path]
46
+ */ getMembershipWitness(blockNumber, treeId, leafValue) {
52
47
  return this.db.getMembershipWitness(blockNumber, treeId, leafValue);
53
48
  }
54
49
  /**
55
- * Returns a nullifier membership witness for a given nullifier at a given block.
56
- * @param blockNumber - The block number at which to get the index.
57
- * @param nullifier - Nullifier we try to find witness for.
58
- * @returns The nullifier membership witness (if found).
59
- */
60
- async getNullifierMembershipWitness(blockNumber, nullifier) {
50
+ * Returns a nullifier membership witness for a given nullifier at a given block.
51
+ * @param blockNumber - The block number at which to get the index.
52
+ * @param nullifier - Nullifier we try to find witness for.
53
+ * @returns The nullifier membership witness (if found).
54
+ */ async getNullifierMembershipWitness(blockNumber, nullifier) {
61
55
  return await this.db.getNullifierMembershipWitness(blockNumber, nullifier);
62
56
  }
63
57
  /**
64
- * Returns a low nullifier membership witness for a given nullifier at a given block.
65
- * @param blockNumber - The block number at which to get the index.
66
- * @param nullifier - Nullifier we try to find the low nullifier witness for.
67
- * @returns The low nullifier membership witness (if found).
68
- * @remarks Low nullifier witness can be used to perform a nullifier non-inclusion proof by leveraging the "linked
69
- * list structure" of leaves and proving that a lower nullifier is pointing to a bigger next value than the nullifier
70
- * we are trying to prove non-inclusion for.
71
- */
72
- async getLowNullifierMembershipWitness(blockNumber, nullifier) {
58
+ * Returns a low nullifier membership witness for a given nullifier at a given block.
59
+ * @param blockNumber - The block number at which to get the index.
60
+ * @param nullifier - Nullifier we try to find the low nullifier witness for.
61
+ * @returns The low nullifier membership witness (if found).
62
+ * @remarks Low nullifier witness can be used to perform a nullifier non-inclusion proof by leveraging the "linked
63
+ * list structure" of leaves and proving that a lower nullifier is pointing to a bigger next value than the nullifier
64
+ * we are trying to prove non-inclusion for.
65
+ */ async getLowNullifierMembershipWitness(blockNumber, nullifier) {
73
66
  return await this.db.getLowNullifierMembershipWitness(blockNumber, nullifier);
74
67
  }
75
68
  /**
76
- * Returns a public data tree witness for a given leaf slot at a given block.
77
- * @param blockNumber - The block number at which to get the index.
78
- * @param leafSlot - The slot of the public data tree to get the witness for.
79
- * @returns - The witness
80
- */
81
- async getPublicDataTreeWitness(blockNumber, leafSlot) {
69
+ * Returns a public data tree witness for a given leaf slot at a given block.
70
+ * @param blockNumber - The block number at which to get the index.
71
+ * @param leafSlot - The slot of the public data tree to get the witness for.
72
+ * @returns - The witness
73
+ */ async getPublicDataTreeWitness(blockNumber, leafSlot) {
82
74
  return await this.db.getPublicDataTreeWitness(blockNumber, leafSlot);
83
75
  }
84
76
  /**
85
- * Fetches a block header of a given block.
86
- * @param blockNumber - The number of a block of which to get the block header.
87
- * @returns Block extracted from a block with block number `blockNumber`.
88
- */
89
- async getBlockHeader(blockNumber) {
77
+ * Fetches a block header of a given block.
78
+ * @param blockNumber - The number of a block of which to get the block header.
79
+ * @returns Block extracted from a block with block number `blockNumber`.
80
+ */ async getBlockHeader(blockNumber) {
90
81
  const block = await this.db.getBlock(blockNumber);
91
82
  if (!block) {
92
83
  return undefined;
@@ -94,107 +85,107 @@ export class ViewDataOracle extends TypedOracle {
94
85
  return block.header;
95
86
  }
96
87
  /**
97
- * Retrieve the complete address associated to a given address.
98
- * @param account - The account address.
99
- * @returns A complete address associated with the input address.
100
- * @throws An error if the account is not registered in the database.
101
- */
102
- getCompleteAddress(account) {
88
+ * Retrieve the complete address associated to a given address.
89
+ * @param account - The account address.
90
+ * @returns A complete address associated with the input address.
91
+ * @throws An error if the account is not registered in the database.
92
+ */ getCompleteAddress(account) {
103
93
  return this.db.getCompleteAddress(account);
104
94
  }
105
95
  /**
106
- * Returns a contract instance associated with an address or throws if not found.
107
- * @param address - Address.
108
- * @returns A contract instance.
109
- */
110
- getContractInstance(address) {
96
+ * Returns a contract instance associated with an address or throws if not found.
97
+ * @param address - Address.
98
+ * @returns A contract instance.
99
+ */ getContractInstance(address) {
111
100
  return this.db.getContractInstance(address);
112
101
  }
113
102
  /**
114
- * Returns an auth witness for the given message hash. Checks on the list of transient witnesses
115
- * for this transaction first, and falls back to the local database if not found.
116
- * @param messageHash - Hash of the message to authenticate.
117
- * @returns Authentication witness for the requested message hash.
118
- */
119
- getAuthWitness(messageHash) {
120
- return Promise.resolve(this.authWitnesses.find(w => w.requestHash.equals(messageHash))?.witness ?? this.db.getAuthWitness(messageHash));
103
+ * Returns an auth witness for the given message hash. Checks on the list of transient witnesses
104
+ * for this transaction first, and falls back to the local database if not found.
105
+ * @param messageHash - Hash of the message to authenticate.
106
+ * @returns Authentication witness for the requested message hash.
107
+ */ getAuthWitness(messageHash) {
108
+ return Promise.resolve(this.authWitnesses.find((w)=>w.requestHash.equals(messageHash))?.witness ?? this.db.getAuthWitness(messageHash));
121
109
  }
122
110
  /**
123
- * Pops a capsule from the capsule dispenser
124
- * @returns The capsule values
125
- * @remarks A capsule is a "blob" of data that is passed to the contract through an oracle.
126
- */
127
- popCapsule() {
111
+ * Pops a capsule from the capsule dispenser
112
+ * @returns The capsule values
113
+ * @remarks A capsule is a "blob" of data that is passed to the contract through an oracle.
114
+ */ popCapsule() {
128
115
  return this.db.popCapsule();
129
116
  }
130
117
  /**
131
- * Gets some notes for a contract address and storage slot.
132
- * Returns a flattened array containing filtered notes.
133
- *
134
- * @remarks
135
- * Check for pending notes with matching slot.
136
- * Real notes coming from DB will have a leafIndex which
137
- * represents their index in the note hash tree.
138
- *
139
- * @param storageSlot - The storage slot.
140
- * @param numSelects - The number of valid selects in selectBy and selectValues.
141
- * @param selectBy - An array of indices of the fields to selects.
142
- * @param selectValues - The values to match.
143
- * @param selectComparators - The comparators to use to match values.
144
- * @param sortBy - An array of indices of the fields to sort.
145
- * @param sortOrder - The order of the corresponding index in sortBy. (1: DESC, 2: ASC, 0: Do nothing)
146
- * @param limit - The number of notes to retrieve per query.
147
- * @param offset - The starting index for pagination.
148
- * @param status - The status of notes to fetch.
149
- * @returns Array of note data.
150
- */
151
- async getNotes(storageSlot, numSelects, selectByIndexes, selectByOffsets, selectByLengths, selectValues, selectComparators, sortByIndexes, sortByOffsets, sortByLengths, sortOrder, limit, offset, status) {
118
+ * Gets some notes for a contract address and storage slot.
119
+ * Returns a flattened array containing filtered notes.
120
+ *
121
+ * @remarks
122
+ * Check for pending notes with matching slot.
123
+ * Real notes coming from DB will have a leafIndex which
124
+ * represents their index in the note hash tree.
125
+ *
126
+ * @param storageSlot - The storage slot.
127
+ * @param numSelects - The number of valid selects in selectBy and selectValues.
128
+ * @param selectBy - An array of indices of the fields to selects.
129
+ * @param selectValues - The values to match.
130
+ * @param selectComparators - The comparators to use to match values.
131
+ * @param sortBy - An array of indices of the fields to sort.
132
+ * @param sortOrder - The order of the corresponding index in sortBy. (1: DESC, 2: ASC, 0: Do nothing)
133
+ * @param limit - The number of notes to retrieve per query.
134
+ * @param offset - The starting index for pagination.
135
+ * @param status - The status of notes to fetch.
136
+ * @returns Array of note data.
137
+ */ async getNotes(storageSlot, numSelects, selectByIndexes, selectByOffsets, selectByLengths, selectValues, selectComparators, sortByIndexes, sortByOffsets, sortByLengths, sortOrder, limit, offset, status) {
152
138
  const dbNotes = await this.db.getNotes(this.contractAddress, storageSlot, status, this.scopes);
153
139
  return pickNotes(dbNotes, {
154
- selects: selectByIndexes.slice(0, numSelects).map((index, i) => ({
155
- selector: { index, offset: selectByOffsets[i], length: selectByLengths[i] },
156
- value: selectValues[i],
157
- comparator: selectComparators[i],
158
- })),
159
- sorts: sortByIndexes.map((index, i) => ({
160
- selector: { index, offset: sortByOffsets[i], length: sortByLengths[i] },
161
- order: sortOrder[i],
162
- })),
140
+ selects: selectByIndexes.slice(0, numSelects).map((index, i)=>({
141
+ selector: {
142
+ index,
143
+ offset: selectByOffsets[i],
144
+ length: selectByLengths[i]
145
+ },
146
+ value: selectValues[i],
147
+ comparator: selectComparators[i]
148
+ })),
149
+ sorts: sortByIndexes.map((index, i)=>({
150
+ selector: {
151
+ index,
152
+ offset: sortByOffsets[i],
153
+ length: sortByLengths[i]
154
+ },
155
+ order: sortOrder[i]
156
+ })),
163
157
  limit,
164
- offset,
158
+ offset
165
159
  });
166
160
  }
167
161
  /**
168
- * Check if a nullifier exists in the nullifier tree.
169
- * @param innerNullifier - The inner nullifier.
170
- * @returns A boolean indicating whether the nullifier exists in the tree or not.
171
- */
172
- async checkNullifierExists(innerNullifier) {
162
+ * Check if a nullifier exists in the nullifier tree.
163
+ * @param innerNullifier - The inner nullifier.
164
+ * @returns A boolean indicating whether the nullifier exists in the tree or not.
165
+ */ async checkNullifierExists(innerNullifier) {
173
166
  const nullifier = await siloNullifier(this.contractAddress, innerNullifier);
174
167
  const index = await this.db.getNullifierIndex(nullifier);
175
168
  return index !== undefined;
176
169
  }
177
170
  /**
178
- * Fetches a message from the db, given its key.
179
- * @param contractAddress - Address of a contract by which the message was emitted.
180
- * @param messageHash - Hash of the message.
181
- * @param secret - Secret used to compute a nullifier.
182
- * @dev Contract address and secret are only used to compute the nullifier to get non-nullified messages
183
- * @returns The l1 to l2 membership witness (index of message in the tree and sibling path).
184
- */
185
- async getL1ToL2MembershipWitness(contractAddress, messageHash, secret) {
171
+ * Fetches a message from the db, given its key.
172
+ * @param contractAddress - Address of a contract by which the message was emitted.
173
+ * @param messageHash - Hash of the message.
174
+ * @param secret - Secret used to compute a nullifier.
175
+ * @dev Contract address and secret are only used to compute the nullifier to get non-nullified messages
176
+ * @returns The l1 to l2 membership witness (index of message in the tree and sibling path).
177
+ */ async getL1ToL2MembershipWitness(contractAddress, messageHash, secret) {
186
178
  return await this.db.getL1ToL2MembershipWitness(contractAddress, messageHash, secret);
187
179
  }
188
180
  /**
189
- * Read the public storage data.
190
- * @param contractAddress - The address to read storage from.
191
- * @param startStorageSlot - The starting storage slot.
192
- * @param blockNumber - The block number to read storage at.
193
- * @param numberOfElements - Number of elements to read from the starting storage slot.
194
- */
195
- async storageRead(contractAddress, startStorageSlot, blockNumber, numberOfElements) {
181
+ * Read the public storage data.
182
+ * @param contractAddress - The address to read storage from.
183
+ * @param startStorageSlot - The starting storage slot.
184
+ * @param blockNumber - The block number to read storage at.
185
+ * @param numberOfElements - Number of elements to read from the starting storage slot.
186
+ */ async storageRead(contractAddress, startStorageSlot, blockNumber, numberOfElements) {
196
187
  const values = [];
197
- for (let i = 0n; i < numberOfElements; i++) {
188
+ for(let i = 0n; i < numberOfElements; i++){
198
189
  const storageSlot = new Fr(startStorageSlot.value + i);
199
190
  const value = await this.aztecNode.getPublicStorageAt(contractAddress, storageSlot, blockNumber);
200
191
  this.log.debug(`Oracle storage read: slot=${storageSlot.toString()} address-${contractAddress.toString()} value=${value}`);
@@ -207,22 +198,23 @@ export class ViewDataOracle extends TypedOracle {
207
198
  if (message.startsWith('Context.note_hashes, after pushing new note hash:')) {
208
199
  return;
209
200
  }
210
- this.log.verbose(`${applyStringFormatting(message, fields)}`, { module: `${this.log.module}:debug_log` });
201
+ this.log.verbose(`${applyStringFormatting(message, fields)}`, {
202
+ module: `${this.log.module}:debug_log`
203
+ });
211
204
  }
212
205
  /**
213
- * Returns the tagging secret for a given sender and recipient pair, siloed to the current contract address.
214
- * Includes the next index to be used used for tagging with this secret.
215
- * For this to work, the ivsk_m of the sender must be known.
216
- * @param sender - The address sending the note
217
- * @param recipient - The address receiving the note
218
- * @returns A tagging secret that can be used to tag notes.
219
- */
220
- async getIndexedTaggingSecretAsSender(sender, recipient) {
206
+ * Returns the tagging secret for a given sender and recipient pair, siloed to the current contract address.
207
+ * Includes the next index to be used used for tagging with this secret.
208
+ * For this to work, the ivsk_m of the sender must be known.
209
+ * @param sender - The address sending the note
210
+ * @param recipient - The address receiving the note
211
+ * @returns A tagging secret that can be used to tag notes.
212
+ */ async getIndexedTaggingSecretAsSender(sender, recipient) {
221
213
  return await this.db.getIndexedTaggingSecretAsSender(this.contractAddress, sender, recipient);
222
214
  }
223
215
  async syncNotes() {
224
216
  const taggedLogsByRecipient = await this.db.syncTaggedLogs(this.contractAddress, await this.aztecNode.getBlockNumber(), this.scopes);
225
- for (const [recipient, taggedLogs] of taggedLogsByRecipient.entries()) {
217
+ for (const [recipient, taggedLogs] of taggedLogsByRecipient.entries()){
226
218
  await this.db.processTaggedLogs(taggedLogs, AztecAddress.fromString(recipient));
227
219
  }
228
220
  await this.db.removeNullifiedNotes(this.contractAddress);
@@ -263,4 +255,3 @@ export class ViewDataOracle extends TypedOracle {
263
255
  return this.db.dbCopy(this.contractAddress, srcSlot, dstSlot, numEntries);
264
256
  }
265
257
  }
266
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidmlld19kYXRhX29yYWNsZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9jbGllbnQvdmlld19kYXRhX29yYWNsZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFlQSxPQUFPLEVBQUUsYUFBYSxFQUFFLE1BQU0seUJBQXlCLENBQUM7QUFDeEQsT0FBTyxFQUFFLFlBQVksRUFBRSxNQUFNLGlDQUFpQyxDQUFDO0FBQy9ELE9BQU8sRUFBRSxFQUFFLEVBQUUsTUFBTSwwQkFBMEIsQ0FBQztBQUM5QyxPQUFPLEVBQUUscUJBQXFCLEVBQUUsWUFBWSxFQUFFLE1BQU0sdUJBQXVCLENBQUM7QUFFNUUsT0FBTyxFQUFpQixXQUFXLEVBQUUsTUFBTSxrQkFBa0IsQ0FBQztBQUU5RCxPQUFPLEVBQUUsU0FBUyxFQUFFLE1BQU0saUJBQWlCLENBQUM7QUFFNUM7OztHQUdHO0FBQ0gsTUFBTSxPQUFPLGNBQWUsU0FBUSxXQUFXO0lBQzdDLFlBQ3FCLGVBQTZCO0lBQ2hELHlFQUF5RTtJQUN0RCxhQUE0QixFQUM1QixFQUFZLEVBQ1osU0FBb0IsRUFDN0IsTUFBTSxZQUFZLENBQUMsK0JBQStCLENBQUMsRUFDMUMsTUFBdUI7UUFFMUMsS0FBSyxFQUFFLENBQUM7UUFSVyxvQkFBZSxHQUFmLGVBQWUsQ0FBYztRQUU3QixrQkFBYSxHQUFiLGFBQWEsQ0FBZTtRQUM1QixPQUFFLEdBQUYsRUFBRSxDQUFVO1FBQ1osY0FBUyxHQUFULFNBQVMsQ0FBVztRQUM3QixRQUFHLEdBQUgsR0FBRyxDQUFnRDtRQUMxQyxXQUFNLEdBQU4sTUFBTSxDQUFpQjtJQUc1QyxDQUFDO0lBRWUsY0FBYztRQUM1QixPQUFPLElBQUksQ0FBQyxTQUFTLENBQUMsY0FBYyxFQUFFLENBQUM7SUFDekMsQ0FBQztJQUVlLGtCQUFrQjtRQUNoQyxPQUFPLE9BQU8sQ0FBQyxPQUFPLENBQUMsSUFBSSxDQUFDLGVBQWUsQ0FBQyxDQUFDO0lBQy9DLENBQUM7SUFFZSxVQUFV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
@@ -1,9 +1,6 @@
1
1
  import { FunctionSelector } from '@aztec/circuits.js';
2
2
  export async function getPublicFunctionDebugName(db, contractAddress, calldata) {
3
3
  // Public function is dispatched and therefore the target function is passed in the first argument.
4
- const targetFunction = calldata[0] !== undefined
5
- ? await db.getDebugFunctionName(contractAddress, FunctionSelector.fromField(calldata[0]))
6
- : `<calldata[0] undefined> (Contract Address: ${contractAddress})`;
4
+ const targetFunction = calldata[0] !== undefined ? await db.getDebugFunctionName(contractAddress, FunctionSelector.fromField(calldata[0])) : `<calldata[0] undefined> (Contract Address: ${contractAddress})`;
7
5
  return `${targetFunction}`;
8
6
  }
9
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZGVidWdfZm5fbmFtZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9jb21tb24vZGVidWdfZm5fbmFtZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQThCLGdCQUFnQixFQUFFLE1BQU0sb0JBQW9CLENBQUM7QUFJbEYsTUFBTSxDQUFDLEtBQUssVUFBVSwwQkFBMEIsQ0FDOUMsRUFBZ0IsRUFDaEIsZUFBNkIsRUFDN0IsUUFBYztJQUVkLG1HQUFtRztJQUNuRyxNQUFNLGNBQWMsR0FDbEIsUUFBUSxDQUFDLENBQUMsQ0FBQyxLQUFLLFNBQVM7UUFDdkIsQ0FBQyxDQUFDLE1BQU0sRUFBRSxDQUFDLG9CQUFvQixDQUFDLGVBQWUsRUFBRSxnQkFBZ0IsQ0FBQyxTQUFTLENBQUMsUUFBUSxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUM7UUFDekYsQ0FBQyxDQUFDLDhDQUE4QyxlQUFlLEdBQUcsQ0FBQztJQUN2RSxPQUFPLEdBQUcsY0FBYyxFQUFFLENBQUM7QUFDN0IsQ0FBQyJ9
@@ -1,4 +1,4 @@
1
- import { SimulationError, } from '@aztec/circuit-types';
1
+ import { SimulationError } from '@aztec/circuit-types';
2
2
  import { jsonStringify } from '@aztec/foundation/json-rpc';
3
3
  import { abiDecodeError } from '@noir-lang/noirc_abi';
4
4
  /**
@@ -8,35 +8,28 @@ import { abiDecodeError } from '@noir-lang/noirc_abi';
8
8
  * @param noirCallStack - the internal call stack of the function that failed (within the failing Aztec function)
9
9
  * @param options - additional error options (an optional "cause" entry allows for a recursive error stack where
10
10
  * an error's cause may be an ExecutionError itself)
11
- */
12
- export class ExecutionError extends Error {
13
- constructor(message,
14
- /**
11
+ */ export class ExecutionError extends Error {
12
+ failingFunction;
13
+ noirCallStack;
14
+ constructor(message, /**
15
15
  * The function that failed.
16
- */
17
- failingFunction,
18
- /**
16
+ */ failingFunction, /**
19
17
  * The noir call stack of the function that failed.
20
- */
21
- noirCallStack, options) {
22
- super(message, options);
23
- this.failingFunction = failingFunction;
24
- this.noirCallStack = noirCallStack;
18
+ */ noirCallStack, options){
19
+ super(message, options), this.failingFunction = failingFunction, this.noirCallStack = noirCallStack;
25
20
  }
26
21
  }
27
22
  /**
28
23
  * Traverses the cause chain of an error.
29
24
  * @param error - The error to start from.
30
25
  * @param callback - A callback on every error, including the first one.
31
- */
32
- export function traverseCauseChain(error, callback) {
26
+ */ export function traverseCauseChain(error, callback) {
33
27
  let currentError = error;
34
- while (currentError) {
28
+ while(currentError){
35
29
  callback(currentError);
36
30
  if (currentError.cause && currentError.cause instanceof Error) {
37
31
  currentError = currentError.cause;
38
- }
39
- else {
32
+ } else {
40
33
  currentError = undefined;
41
34
  }
42
35
  }
@@ -45,12 +38,11 @@ export function traverseCauseChain(error, callback) {
45
38
  * Creates a simulation error from an error chain generated during the execution of a function.
46
39
  * @param error - The error thrown during execution.
47
40
  * @returns - A simulation error.
48
- */
49
- export function createSimulationError(error, revertData) {
41
+ */ export function createSimulationError(error, revertData) {
50
42
  let rootCause = error;
51
43
  let noirCallStack = undefined;
52
44
  const aztecCallStack = [];
53
- traverseCauseChain(error, cause => {
45
+ traverseCauseChain(error, (cause)=>{
54
46
  rootCause = cause;
55
47
  if (cause instanceof ExecutionError) {
56
48
  aztecCallStack.push(cause.failingFunction);
@@ -59,14 +51,15 @@ export function createSimulationError(error, revertData) {
59
51
  }
60
52
  }
61
53
  });
62
- return new SimulationError(rootCause.message, aztecCallStack, revertData, noirCallStack, { cause: rootCause });
54
+ return new SimulationError(rootCause.message, aztecCallStack, revertData, noirCallStack, {
55
+ cause: rootCause
56
+ });
63
57
  }
64
58
  /**
65
59
  * Extracts a brillig location from an opcode location.
66
60
  * @param opcodeLocation - The opcode location to extract from. It should be in the format `acirLocation.brilligLocation` or `acirLocation`.
67
61
  * @returns The brillig location if the opcode location contains one.
68
- */
69
- function extractBrilligLocation(opcodeLocation) {
62
+ */ function extractBrilligLocation(opcodeLocation) {
70
63
  const splitted = opcodeLocation.split('.');
71
64
  if (splitted.length === 2) {
72
65
  return splitted[1];
@@ -76,8 +69,7 @@ function extractBrilligLocation(opcodeLocation) {
76
69
  /**
77
70
  * Extracts the call stack from the location of a failing opcode and the debug metadata.
78
71
  * One opcode can point to multiple calls due to inlining.
79
- */
80
- function getSourceCodeLocationsFromOpcodeLocation(opcodeLocation, debug, brilligFunctionId) {
72
+ */ function getSourceCodeLocationsFromOpcodeLocation(opcodeLocation, debug, brilligFunctionId) {
81
73
  const { debugSymbols, files } = debug;
82
74
  let callStack = debugSymbols.locations[opcodeLocation] || [];
83
75
  if (callStack.length === 0) {
@@ -86,7 +78,7 @@ function getSourceCodeLocationsFromOpcodeLocation(opcodeLocation, debug, brillig
86
78
  callStack = debugSymbols.brillig_locations[brilligFunctionId][brilligLocation] || [];
87
79
  }
88
80
  }
89
- return callStack.map(call => {
81
+ return callStack.map((call)=>{
90
82
  const { file: fileId, span } = call;
91
83
  const { path, source } = files[fileId];
92
84
  const locationText = source.substring(span.start, span.end);
@@ -100,7 +92,7 @@ function getSourceCodeLocationsFromOpcodeLocation(opcodeLocation, debug, brillig
100
92
  line,
101
93
  column,
102
94
  fileSource: source,
103
- locationText,
95
+ locationText
104
96
  };
105
97
  });
106
98
  }
@@ -109,17 +101,18 @@ function getSourceCodeLocationsFromOpcodeLocation(opcodeLocation, debug, brillig
109
101
  * @param opcodeLocations - The opcode locations that caused the error.
110
102
  * @param debug - The debug metadata of the function.
111
103
  * @returns The source code locations.
112
- */
113
- export function resolveOpcodeLocations(opcodeLocations, debug, brilligFunctionId) {
114
- return opcodeLocations.flatMap(opcodeLocation => getSourceCodeLocationsFromOpcodeLocation(opcodeLocation, debug, brilligFunctionId));
104
+ */ export function resolveOpcodeLocations(opcodeLocations, debug, brilligFunctionId) {
105
+ return opcodeLocations.flatMap((opcodeLocation)=>getSourceCodeLocationsFromOpcodeLocation(opcodeLocation, debug, brilligFunctionId));
115
106
  }
116
107
  export function resolveAssertionMessage(errorPayload, abi) {
117
- const decoded = abiDecodeError({ parameters: [], error_types: abi.errorTypes, return_type: null }, // eslint-disable-line camelcase
118
- errorPayload);
108
+ const decoded = abiDecodeError({
109
+ parameters: [],
110
+ error_types: abi.errorTypes,
111
+ return_type: null
112
+ }, errorPayload);
119
113
  if (typeof decoded === 'string') {
120
114
  return decoded;
121
- }
122
- else {
115
+ } else {
123
116
  return jsonStringify(decoded);
124
117
  }
125
118
  }
@@ -130,15 +123,13 @@ export function resolveAssertionMessageFromRevertData(revertData, abi) {
130
123
  const [errorSelector, ...errorData] = revertData;
131
124
  return resolveAssertionMessage({
132
125
  selector: errorSelector.toBigInt().toString(),
133
- data: errorData.map(f => f.toString()),
126
+ data: errorData.map((f)=>f.toString())
134
127
  }, abi);
135
128
  }
136
129
  export function resolveAssertionMessageFromError(err, abi) {
137
130
  if (typeof err === 'object' && err !== null && 'rawAssertionPayload' in err && err.rawAssertionPayload) {
138
131
  return `Assertion failed: ${resolveAssertionMessage(err.rawAssertionPayload, abi)}`;
139
- }
140
- else {
132
+ } else {
141
133
  return err.message;
142
134
  }
143
135
  }
144
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZXJyb3JzLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vc3JjL2NvbW1vbi9lcnJvcnMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUdMLGVBQWUsR0FFaEIsTUFBTSxzQkFBc0IsQ0FBQztBQUc5QixPQUFPLEVBQUUsYUFBYSxFQUFFLE1BQU0sNEJBQTRCLENBQUM7QUFHM0QsT0FBTyxFQUFFLGNBQWMsRUFBRSxNQUFNLHNCQUFzQixDQUFDO0FBRXREOzs7Ozs7O0dBT0c7QUFDSCxNQUFNLE9BQU8sY0FBZSxTQUFRLEtBQUs7SUFDdkMsWUFDRSxPQUFlO0lBQ2Y7O09BRUc7SUFDSSxlQUFnQztJQUN2Qzs7T0FFRztJQUNJLGFBQTZCLEVBQ3BDLE9BQXNCO1FBRXRCLEtBQUssQ0FBQyxPQUFPLEVBQUUsT0FBTyxDQUFDLENBQUM7UUFQakIsb0JBQWUsR0FBZixlQUFlLENBQWlCO1FBSWhDLGtCQUFhLEdBQWIsYUFBYSxDQUFnQjtJQUl0QyxDQUFDO0NBQ0Y7QUFFRDs7OztHQUlHO0FBQ0gsTUFBTSxVQUFVLGtCQUFrQixDQUFDLEtBQVksRUFBRSxRQUFnQztJQUMvRSxJQUFJLFlBQVksR0FBc0IsS0FBSyxDQUFDO0lBQzVDLE9BQU8sWUFBWSxFQUFFLENBQUM7UUFDcEIsUUFBUSxDQUFDLFlBQVksQ0FBQyxDQUFDO1FBQ3ZCLElBQUksWUFBWSxDQUFDLEtBQUssSUFBSSxZQUFZLENBQUMsS0FBSyxZQUFZLEtBQUssRUFBRSxDQUFDO1lBQzlELFlBQVksR0FBRyxZQUFZLENBQUMsS0FBSyxDQUFDO1FBQ3BDLENBQUM7YUFBTSxDQUFDO1lBQ04sWUFBWSxHQUFHLFNBQVMsQ0FBQztRQUMzQixDQUFDO0lBQ0gsQ0FBQztBQUNILENBQUM7QUFFRDs7OztHQUlHO0FBQ0gsTUFBTSxVQUFVLHFCQUFxQixDQUFDLEtBQVksRUFBRSxVQUFpQjtJQUNuRSxJQUFJLFNBQVMsR0FBRyxLQUFLLENBQUM7SUFDdEIsSUFBSSxhQUFh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
@@ -2,28 +2,26 @@ import { HashedValues } from '@aztec/circuit-types';
2
2
  import { Fr } from '@aztec/circuits.js';
3
3
  /**
4
4
  * A cache for hashed values (arguments, returns) during transaction execution.
5
- */
6
- export class HashedValuesCache {
7
- constructor(initialArguments = []) {
5
+ */ export class HashedValuesCache {
6
+ cache;
7
+ constructor(initialArguments = []){
8
8
  this.cache = new Map();
9
- for (const initialArg of initialArguments) {
9
+ for (const initialArg of initialArguments){
10
10
  this.cache.set(initialArg.hash.toBigInt(), initialArg.values);
11
11
  }
12
12
  }
13
13
  /**
14
- * Creates a new hashed values cache.
15
- * @param initialArguments - The initial arguments to add to the cache.
16
- * @returns The new hashed values cache.
17
- */
18
- static create(initialArguments = []) {
14
+ * Creates a new hashed values cache.
15
+ * @param initialArguments - The initial arguments to add to the cache.
16
+ * @returns The new hashed values cache.
17
+ */ static create(initialArguments = []) {
19
18
  return new HashedValuesCache(initialArguments);
20
19
  }
21
20
  /**
22
- * Gets preimage of a hash.
23
- * @param hash - The hash to get the preimage of.
24
- * @returns The preimage.
25
- */
26
- getPreimage(hash) {
21
+ * Gets preimage of a hash.
22
+ * @param hash - The hash to get the preimage of.
23
+ * @returns The preimage.
24
+ */ getPreimage(hash) {
27
25
  if (hash.equals(Fr.ZERO)) {
28
26
  return [];
29
27
  }
@@ -34,11 +32,10 @@ export class HashedValuesCache {
34
32
  return hashedValues;
35
33
  }
36
34
  /**
37
- * Stores values in cache and returns its hash.
38
- * @param values - The values to store.
39
- * @returns The hash of the values.
40
- */
41
- async store(values) {
35
+ * Stores values in cache and returns its hash.
36
+ * @param values - The values to store.
37
+ * @returns The hash of the values.
38
+ */ async store(values) {
42
39
  if (values.length === 0) {
43
40
  return Fr.ZERO;
44
41
  }
@@ -47,4 +44,3 @@ export class HashedValuesCache {
47
44
  return hashedValues.hash;
48
45
  }
49
46
  }
50
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaGFzaGVkX3ZhbHVlc19jYWNoZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9jb21tb24vaGFzaGVkX3ZhbHVlc19jYWNoZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsWUFBWSxFQUFFLE1BQU0sc0JBQXNCLENBQUM7QUFDcEQsT0FBTyxFQUFFLEVBQUUsRUFBRSxNQUFNLG9CQUFvQixDQUFDO0FBRXhDOztHQUVHO0FBQ0gsTUFBTSxPQUFPLGlCQUFpQjtJQUc1QixZQUFZLG1CQUFtQyxFQUFFO1FBQy9DLElBQUksQ0FBQyxLQUFLLEdBQUcsSUFBSSxHQUFHLEVBQUUsQ0FBQztRQUN2QixLQUFLLE1BQU0sVUFBVSxJQUFJLGdCQUFnQixFQUFFLENBQUM7WUFDMUMsSUFBSSxDQUFDLEtBQUssQ0FBQyxHQUFHLENBQUMsVUFBVSxDQUFDLElBQUksQ0FBQyxRQUFRLEVBQUUsRUFBRSxVQUFVLENBQUMsTUFBTSxDQUFDLENBQUM7UUFDaEUsQ0FBQztJQUNILENBQUM7SUFFRDs7OztPQUlHO0lBQ0ksTUFBTSxDQUFDLE1BQU0sQ0FBQyxtQkFBbUMsRUFBRTtRQUN4RCxPQUFPLElBQUksaUJBQWlCLENBQUMsZ0JBQWdCLENBQUMsQ0FBQztJQUNqRCxDQUFDO0lBRUQ7Ozs7T0FJRztJQUNJLFdBQVcsQ0FBQyxJQUFRO1FBQ3pCLElBQUksSUFBSSxDQUFDLE1BQU0sQ0FBQyxFQUFFLENBQUMsSUFBSSxDQUFDLEVBQUUsQ0FBQztZQUN6QixPQUFPLEVBQUUsQ0FBQztRQUNaLENBQUM7UUFDRCxNQUFNLFlBQVksR0FBRyxJQUFJLENBQUMsS0FBSyxDQUFDLEdBQUcsQ0FBQyxJQUFJLENBQUMsUUFBUSxFQUFFLENBQUMsQ0FBQztRQUNyRCxJQUFJLENBQUMsWUFBWSxFQUFFLENBQUM7WUFDbEIsTUFBTSxJQUFJLEtBQUssQ0FBQyxxQkFBcUIsSUFBSSxDQUFDLFFBQVEsRUFBRSxxQkFBcUIsQ0FBQyxDQUFDO1FBQzdFLENBQUM7UUFDRCxPQUFPLFlBQVksQ0FBQztJQUN0QixDQUFDO0lBRUQ7Ozs7T0FJRztJQUNJLEtBQUssQ0FBQyxLQUFLLENBQUMsTUFBWTtRQUM3QixJQUFJLE1BQU0sQ0FBQyxNQUFNLEtBQUssQ0FBQyxFQUFFLENBQUM7WUFDeEIsT0FBTyxFQUFFLENBQUMsSUFBSSxDQUFDO1FBQ2pCLENBQUM7UUFDRCxNQUFNLFlBQVksR0FBRyxNQUFNLFlBQVksQ0FBQyxVQUFVLENBQUMsTUFBTSxDQUFDLENBQUM7UUFDM0QsSUFBSSxDQUFDLEtBQUssQ0FBQyxHQUFHLENBQUMsWUFBWSxDQUFDLElBQUksQ0FBQyxRQUFRLEVBQUUsRUFBRSxZQUFZLENBQUMsTUFBTSxDQUFDLENBQUM7UUFDbEUsT0FBTyxZQUFZLENBQUMsSUFBSSxDQUFDO0lBQzNCLENBQUM7Q0FDRiJ9
@@ -1,3 +1,2 @@
1
1
  export * from './hashed_values_cache.js';
2
2
  export * from './errors.js';
3
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMvY29tbW9uL2luZGV4LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLGNBQWMsMEJBQTBCLENBQUM7QUFDekMsY0FBYyxhQUFhLENBQUMifQ==