@aztec/simulator 0.0.1-commit.d3ec352c → 0.0.1-commit.e3c1de76

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 (312) hide show
  1. package/README.md +2 -0
  2. package/dest/common/errors.d.ts +8 -2
  3. package/dest/common/errors.d.ts.map +1 -1
  4. package/dest/private/acvm/acvm.d.ts +4 -2
  5. package/dest/private/acvm/acvm.d.ts.map +1 -1
  6. package/dest/private/acvm/acvm.js +4 -3
  7. package/dest/private/acvm/deserialize.d.ts +2 -2
  8. package/dest/private/acvm/deserialize.d.ts.map +1 -1
  9. package/dest/private/acvm/deserialize.js +1 -1
  10. package/dest/private/acvm/serialize.d.ts +2 -2
  11. package/dest/private/acvm/serialize.d.ts.map +1 -1
  12. package/dest/private/acvm/serialize.js +1 -1
  13. package/dest/private/acvm_native.d.ts +5 -3
  14. package/dest/private/acvm_native.d.ts.map +1 -1
  15. package/dest/private/acvm_native.js +8 -6
  16. package/dest/private/acvm_wasm.d.ts +4 -3
  17. package/dest/private/acvm_wasm.d.ts.map +1 -1
  18. package/dest/private/acvm_wasm.js +4 -4
  19. package/dest/private/circuit_recording/circuit_recorder.d.ts +4 -3
  20. package/dest/private/circuit_recording/circuit_recorder.d.ts.map +1 -1
  21. package/dest/private/circuit_recording/circuit_recorder.js +21 -18
  22. package/dest/private/circuit_recording/file_circuit_recorder.d.ts +3 -2
  23. package/dest/private/circuit_recording/file_circuit_recorder.d.ts.map +1 -1
  24. package/dest/private/circuit_recording/file_circuit_recorder.js +2 -2
  25. package/dest/private/circuit_recording/memory_circuit_recorder.d.ts +7 -2
  26. package/dest/private/circuit_recording/memory_circuit_recorder.d.ts.map +1 -1
  27. package/dest/private/circuit_recording/memory_circuit_recorder.js +4 -4
  28. package/dest/private/factory.d.ts +3 -3
  29. package/dest/private/factory.d.ts.map +1 -1
  30. package/dest/private/factory.js +7 -4
  31. package/dest/public/avm/avm_context.d.ts +3 -3
  32. package/dest/public/avm/avm_context.d.ts.map +1 -1
  33. package/dest/public/avm/avm_contract_call_result.d.ts +6 -6
  34. package/dest/public/avm/avm_contract_call_result.d.ts.map +1 -1
  35. package/dest/public/avm/avm_contract_call_result.js +3 -3
  36. package/dest/public/avm/avm_execution_environment.d.ts +7 -6
  37. package/dest/public/avm/avm_execution_environment.d.ts.map +1 -1
  38. package/dest/public/avm/avm_execution_environment.js +1 -1
  39. package/dest/public/avm/avm_gas.d.ts +1 -1
  40. package/dest/public/avm/avm_gas.d.ts.map +1 -1
  41. package/dest/public/avm/avm_machine_state.d.ts +7 -6
  42. package/dest/public/avm/avm_machine_state.d.ts.map +1 -1
  43. package/dest/public/avm/avm_machine_state.js +3 -2
  44. package/dest/public/avm/avm_memory_types.d.ts +2 -2
  45. package/dest/public/avm/avm_memory_types.d.ts.map +1 -1
  46. package/dest/public/avm/avm_memory_types.js +4 -1
  47. package/dest/public/avm/avm_simulator.d.ts +4 -3
  48. package/dest/public/avm/avm_simulator.d.ts.map +1 -1
  49. package/dest/public/avm/avm_simulator.js +6 -5
  50. package/dest/public/avm/calldata.d.ts +51 -0
  51. package/dest/public/avm/calldata.d.ts.map +1 -0
  52. package/dest/public/avm/calldata.js +63 -0
  53. package/dest/public/avm/errors.d.ts +2 -2
  54. package/dest/public/avm/errors.d.ts.map +1 -1
  55. package/dest/public/avm/fixtures/avm_simulation_tester.d.ts +1 -1
  56. package/dest/public/avm/fixtures/avm_simulation_tester.d.ts.map +1 -1
  57. package/dest/public/avm/fixtures/avm_simulation_tester.js +4 -3
  58. package/dest/public/avm/fixtures/base_avm_simulation_tester.d.ts +2 -2
  59. package/dest/public/avm/fixtures/base_avm_simulation_tester.d.ts.map +1 -1
  60. package/dest/public/avm/fixtures/base_avm_simulation_tester.js +1 -1
  61. package/dest/public/avm/fixtures/initializers.d.ts +2 -2
  62. package/dest/public/avm/fixtures/initializers.d.ts.map +1 -1
  63. package/dest/public/avm/fixtures/initializers.js +3 -2
  64. package/dest/public/avm/fixtures/utils.d.ts +2 -2
  65. package/dest/public/avm/fixtures/utils.d.ts.map +1 -1
  66. package/dest/public/avm/fixtures/utils.js +1 -1
  67. package/dest/public/avm/opcodes/accrued_substate.d.ts +16 -17
  68. package/dest/public/avm/opcodes/accrued_substate.d.ts.map +1 -1
  69. package/dest/public/avm/opcodes/accrued_substate.js +39 -39
  70. package/dest/public/avm/opcodes/arithmetic.d.ts +10 -8
  71. package/dest/public/avm/opcodes/arithmetic.d.ts.map +1 -1
  72. package/dest/public/avm/opcodes/arithmetic.js +12 -2
  73. package/dest/public/avm/opcodes/bitwise.d.ts +7 -7
  74. package/dest/public/avm/opcodes/bitwise.d.ts.map +1 -1
  75. package/dest/public/avm/opcodes/bitwise.js +5 -5
  76. package/dest/public/avm/opcodes/comparators.d.ts +4 -4
  77. package/dest/public/avm/opcodes/comparators.d.ts.map +1 -1
  78. package/dest/public/avm/opcodes/comparators.js +1 -1
  79. package/dest/public/avm/opcodes/contract.d.ts +3 -3
  80. package/dest/public/avm/opcodes/contract.d.ts.map +1 -1
  81. package/dest/public/avm/opcodes/contract.js +8 -8
  82. package/dest/public/avm/opcodes/control_flow.d.ts +3 -3
  83. package/dest/public/avm/opcodes/control_flow.d.ts.map +1 -1
  84. package/dest/public/avm/opcodes/control_flow.js +4 -4
  85. package/dest/public/avm/opcodes/conversion.d.ts +3 -3
  86. package/dest/public/avm/opcodes/conversion.d.ts.map +1 -1
  87. package/dest/public/avm/opcodes/conversion.js +4 -4
  88. package/dest/public/avm/opcodes/ec_add.d.ts +4 -4
  89. package/dest/public/avm/opcodes/ec_add.d.ts.map +1 -1
  90. package/dest/public/avm/opcodes/ec_add.js +17 -8
  91. package/dest/public/avm/opcodes/environment_getters.d.ts +5 -5
  92. package/dest/public/avm/opcodes/environment_getters.d.ts.map +1 -1
  93. package/dest/public/avm/opcodes/environment_getters.js +6 -6
  94. package/dest/public/avm/opcodes/external_calls.d.ts +9 -9
  95. package/dest/public/avm/opcodes/external_calls.d.ts.map +1 -1
  96. package/dest/public/avm/opcodes/external_calls.js +23 -22
  97. package/dest/public/avm/opcodes/hashing.d.ts +8 -8
  98. package/dest/public/avm/opcodes/hashing.d.ts.map +1 -1
  99. package/dest/public/avm/opcodes/hashing.js +21 -16
  100. package/dest/public/avm/opcodes/instruction_impl.d.ts +4 -4
  101. package/dest/public/avm/opcodes/instruction_impl.d.ts.map +1 -1
  102. package/dest/public/avm/opcodes/instruction_impl.js +4 -4
  103. package/dest/public/avm/opcodes/memory.d.ts +14 -14
  104. package/dest/public/avm/opcodes/memory.d.ts.map +1 -1
  105. package/dest/public/avm/opcodes/memory.js +26 -26
  106. package/dest/public/avm/opcodes/misc.d.ts +3 -3
  107. package/dest/public/avm/opcodes/misc.d.ts.map +1 -1
  108. package/dest/public/avm/opcodes/misc.js +4 -4
  109. package/dest/public/avm/opcodes/storage.d.ts +16 -15
  110. package/dest/public/avm/opcodes/storage.d.ts.map +1 -1
  111. package/dest/public/avm/opcodes/storage.js +34 -24
  112. package/dest/public/avm/revert_reason.d.ts +2 -2
  113. package/dest/public/avm/revert_reason.d.ts.map +1 -1
  114. package/dest/public/avm/serialization/instruction_serialization.js +1 -1
  115. package/dest/public/avm/test_utils.d.ts +2 -2
  116. package/dest/public/avm/test_utils.d.ts.map +1 -1
  117. package/dest/public/avm/test_utils.js +1 -1
  118. package/dest/public/contracts_db_checkpoint.d.ts +2 -2
  119. package/dest/public/contracts_db_checkpoint.d.ts.map +1 -1
  120. package/dest/public/db_interfaces.d.ts +2 -2
  121. package/dest/public/db_interfaces.d.ts.map +1 -1
  122. package/dest/public/debug_fn_name.d.ts +4 -4
  123. package/dest/public/debug_fn_name.d.ts.map +1 -1
  124. package/dest/public/debug_fn_name.js +14 -5
  125. package/dest/public/executor_metrics.d.ts +1 -1
  126. package/dest/public/executor_metrics.d.ts.map +1 -1
  127. package/dest/public/executor_metrics.js +12 -33
  128. package/dest/public/fixtures/amm_test.js +2 -2
  129. package/dest/public/fixtures/bulk_test.d.ts +3 -3
  130. package/dest/public/fixtures/bulk_test.d.ts.map +1 -1
  131. package/dest/public/fixtures/bulk_test.js +5 -69
  132. package/dest/public/fixtures/custom_bytecode_tester.d.ts +28 -6
  133. package/dest/public/fixtures/custom_bytecode_tester.d.ts.map +1 -1
  134. package/dest/public/fixtures/custom_bytecode_tester.js +36 -12
  135. package/dest/public/fixtures/custom_bytecode_tests.d.ts +11 -8
  136. package/dest/public/fixtures/custom_bytecode_tests.d.ts.map +1 -1
  137. package/dest/public/fixtures/custom_bytecode_tests.js +83 -18
  138. package/dest/public/fixtures/index.d.ts +4 -2
  139. package/dest/public/fixtures/index.d.ts.map +1 -1
  140. package/dest/public/fixtures/index.js +3 -1
  141. package/dest/public/fixtures/minimal_public_tx.d.ts +2 -7
  142. package/dest/public/fixtures/minimal_public_tx.d.ts.map +1 -1
  143. package/dest/public/fixtures/minimal_public_tx.js +4 -14
  144. package/dest/public/fixtures/opcode_spammer.d.ts +122 -0
  145. package/dest/public/fixtures/opcode_spammer.d.ts.map +1 -0
  146. package/dest/public/fixtures/opcode_spammer.js +1653 -0
  147. package/dest/public/fixtures/public_tx_simulation_tester.d.ts +15 -2
  148. package/dest/public/fixtures/public_tx_simulation_tester.d.ts.map +1 -1
  149. package/dest/public/fixtures/public_tx_simulation_tester.js +36 -8
  150. package/dest/public/fixtures/simple_contract_data_source.d.ts +2 -2
  151. package/dest/public/fixtures/simple_contract_data_source.d.ts.map +1 -1
  152. package/dest/public/fixtures/token_test.js +1 -1
  153. package/dest/public/fixtures/utils.d.ts +2 -2
  154. package/dest/public/fixtures/utils.d.ts.map +1 -1
  155. package/dest/public/fixtures/utils.js +4 -3
  156. package/dest/public/fuzzing/avm_fuzzer_simulator.d.ts +60 -0
  157. package/dest/public/fuzzing/avm_fuzzer_simulator.d.ts.map +1 -0
  158. package/dest/public/fuzzing/avm_fuzzer_simulator.js +171 -0
  159. package/dest/public/fuzzing/avm_simulator_bin.d.ts +2 -0
  160. package/dest/public/fuzzing/avm_simulator_bin.d.ts.map +1 -0
  161. package/dest/public/fuzzing/avm_simulator_bin.js +118 -0
  162. package/dest/public/hinting_db_sources.d.ts +3 -2
  163. package/dest/public/hinting_db_sources.d.ts.map +1 -1
  164. package/dest/public/hinting_db_sources.js +7 -2
  165. package/dest/public/index.d.ts +2 -2
  166. package/dest/public/index.d.ts.map +1 -1
  167. package/dest/public/index.js +1 -1
  168. package/dest/public/public_db_sources.d.ts +5 -4
  169. package/dest/public/public_db_sources.d.ts.map +1 -1
  170. package/dest/public/public_db_sources.js +5 -5
  171. package/dest/public/public_processor/guarded_merkle_tree.d.ts +2 -1
  172. package/dest/public/public_processor/guarded_merkle_tree.d.ts.map +1 -1
  173. package/dest/public/public_processor/guarded_merkle_tree.js +5 -0
  174. package/dest/public/public_processor/public_processor.d.ts +6 -4
  175. package/dest/public/public_processor/public_processor.d.ts.map +1 -1
  176. package/dest/public/public_processor/public_processor.js +433 -37
  177. package/dest/public/public_processor/public_processor_metrics.d.ts +2 -2
  178. package/dest/public/public_processor/public_processor_metrics.d.ts.map +1 -1
  179. package/dest/public/public_processor/public_processor_metrics.js +28 -45
  180. package/dest/public/public_tx_simulator/contract_provider_for_cpp.d.ts +3 -14
  181. package/dest/public/public_tx_simulator/contract_provider_for_cpp.d.ts.map +1 -1
  182. package/dest/public/public_tx_simulator/contract_provider_for_cpp.js +20 -55
  183. package/dest/public/public_tx_simulator/cpp_public_tx_simulator.d.ts +20 -5
  184. package/dest/public/public_tx_simulator/cpp_public_tx_simulator.d.ts.map +1 -1
  185. package/dest/public/public_tx_simulator/cpp_public_tx_simulator.js +50 -11
  186. package/dest/public/public_tx_simulator/cpp_public_tx_simulator_with_hinted_dbs.d.ts +4 -4
  187. package/dest/public/public_tx_simulator/cpp_public_tx_simulator_with_hinted_dbs.d.ts.map +1 -1
  188. package/dest/public/public_tx_simulator/cpp_public_tx_simulator_with_hinted_dbs.js +5 -5
  189. package/dest/public/public_tx_simulator/cpp_vs_ts_public_tx_simulator.d.ts +4 -4
  190. package/dest/public/public_tx_simulator/cpp_vs_ts_public_tx_simulator.d.ts.map +1 -1
  191. package/dest/public/public_tx_simulator/cpp_vs_ts_public_tx_simulator.js +12 -11
  192. package/dest/public/public_tx_simulator/dumping_cpp_public_tx_simulator.d.ts +23 -0
  193. package/dest/public/public_tx_simulator/dumping_cpp_public_tx_simulator.d.ts.map +1 -0
  194. package/dest/public/public_tx_simulator/dumping_cpp_public_tx_simulator.js +52 -0
  195. package/dest/public/public_tx_simulator/factories.d.ts +14 -0
  196. package/dest/public/public_tx_simulator/factories.d.ts.map +1 -0
  197. package/dest/public/public_tx_simulator/factories.js +28 -0
  198. package/dest/public/public_tx_simulator/index.d.ts +3 -1
  199. package/dest/public/public_tx_simulator/index.d.ts.map +1 -1
  200. package/dest/public/public_tx_simulator/index.js +2 -0
  201. package/dest/public/public_tx_simulator/measured_public_tx_simulator.d.ts +3 -3
  202. package/dest/public/public_tx_simulator/measured_public_tx_simulator.d.ts.map +1 -1
  203. package/dest/public/public_tx_simulator/public_tx_context.d.ts +5 -4
  204. package/dest/public/public_tx_simulator/public_tx_context.d.ts.map +1 -1
  205. package/dest/public/public_tx_simulator/public_tx_context.js +9 -9
  206. package/dest/public/public_tx_simulator/public_tx_simulator.d.ts +7 -5
  207. package/dest/public/public_tx_simulator/public_tx_simulator.d.ts.map +1 -1
  208. package/dest/public/public_tx_simulator/public_tx_simulator.js +17 -10
  209. package/dest/public/public_tx_simulator/public_tx_simulator_interface.d.ts +24 -1
  210. package/dest/public/public_tx_simulator/public_tx_simulator_interface.d.ts.map +1 -1
  211. package/dest/public/public_tx_simulator/telemetry_public_tx_simulator.d.ts +2 -2
  212. package/dest/public/public_tx_simulator/telemetry_public_tx_simulator.d.ts.map +1 -1
  213. package/dest/public/public_tx_simulator/telemetry_public_tx_simulator.js +395 -19
  214. package/dest/public/side_effect_trace.d.ts +6 -5
  215. package/dest/public/side_effect_trace.d.ts.map +1 -1
  216. package/dest/public/side_effect_trace.js +4 -4
  217. package/dest/public/side_effect_trace_interface.d.ts +2 -2
  218. package/dest/public/side_effect_trace_interface.d.ts.map +1 -1
  219. package/dest/public/state_manager/nullifiers.d.ts +2 -2
  220. package/dest/public/state_manager/nullifiers.d.ts.map +1 -1
  221. package/dest/public/state_manager/public_storage.d.ts +2 -2
  222. package/dest/public/state_manager/public_storage.d.ts.map +1 -1
  223. package/dest/public/state_manager/public_storage.js +1 -1
  224. package/dest/public/state_manager/state_manager.d.ts +11 -5
  225. package/dest/public/state_manager/state_manager.d.ts.map +1 -1
  226. package/dest/public/state_manager/state_manager.js +15 -8
  227. package/dest/public/test_executor_metrics.d.ts +3 -2
  228. package/dest/public/test_executor_metrics.d.ts.map +1 -1
  229. package/dest/public/test_executor_metrics.js +2 -2
  230. package/package.json +18 -18
  231. package/src/common/errors.ts +1 -1
  232. package/src/private/acvm/acvm.ts +4 -3
  233. package/src/private/acvm/deserialize.ts +1 -1
  234. package/src/private/acvm/serialize.ts +1 -1
  235. package/src/private/acvm_native.ts +11 -5
  236. package/src/private/acvm_wasm.ts +7 -3
  237. package/src/private/circuit_recording/circuit_recorder.ts +22 -19
  238. package/src/private/circuit_recording/file_circuit_recorder.ts +7 -2
  239. package/src/private/circuit_recording/memory_circuit_recorder.ts +6 -4
  240. package/src/private/factory.ts +7 -4
  241. package/src/public/avm/avm_context.ts +2 -2
  242. package/src/public/avm/avm_contract_call_result.ts +8 -6
  243. package/src/public/avm/avm_execution_environment.ts +10 -5
  244. package/src/public/avm/avm_gas.ts +3 -3
  245. package/src/public/avm/avm_machine_state.ts +7 -6
  246. package/src/public/avm/avm_memory_types.ts +5 -1
  247. package/src/public/avm/avm_simulator.ts +9 -6
  248. package/src/public/avm/calldata.ts +100 -0
  249. package/src/public/avm/errors.ts +1 -1
  250. package/src/public/avm/fixtures/avm_simulation_tester.ts +9 -3
  251. package/src/public/avm/fixtures/base_avm_simulation_tester.ts +1 -1
  252. package/src/public/avm/fixtures/initializers.ts +3 -2
  253. package/src/public/avm/fixtures/utils.ts +1 -1
  254. package/src/public/avm/opcodes/accrued_substate.ts +28 -30
  255. package/src/public/avm/opcodes/arithmetic.ts +14 -2
  256. package/src/public/avm/opcodes/bitwise.ts +3 -3
  257. package/src/public/avm/opcodes/comparators.ts +1 -1
  258. package/src/public/avm/opcodes/contract.ts +4 -7
  259. package/src/public/avm/opcodes/control_flow.ts +2 -2
  260. package/src/public/avm/opcodes/conversion.ts +3 -3
  261. package/src/public/avm/opcodes/ec_add.ts +15 -6
  262. package/src/public/avm/opcodes/environment_getters.ts +7 -7
  263. package/src/public/avm/opcodes/external_calls.ts +17 -15
  264. package/src/public/avm/opcodes/hashing.ts +16 -10
  265. package/src/public/avm/opcodes/instruction_impl.ts +2 -2
  266. package/src/public/avm/opcodes/memory.ts +20 -20
  267. package/src/public/avm/opcodes/misc.ts +2 -2
  268. package/src/public/avm/opcodes/storage.ts +30 -22
  269. package/src/public/avm/revert_reason.ts +1 -1
  270. package/src/public/avm/serialization/instruction_serialization.ts +1 -1
  271. package/src/public/avm/test_utils.ts +1 -1
  272. package/src/public/contracts_db_checkpoint.ts +1 -1
  273. package/src/public/db_interfaces.ts +1 -1
  274. package/src/public/debug_fn_name.ts +17 -8
  275. package/src/public/executor_metrics.ts +9 -33
  276. package/src/public/fixtures/amm_test.ts +2 -2
  277. package/src/public/fixtures/bulk_test.ts +9 -9
  278. package/src/public/fixtures/custom_bytecode_tester.ts +53 -19
  279. package/src/public/fixtures/custom_bytecode_tests.ts +111 -18
  280. package/src/public/fixtures/index.ts +7 -1
  281. package/src/public/fixtures/minimal_public_tx.ts +6 -15
  282. package/src/public/fixtures/opcode_spammer.ts +1721 -0
  283. package/src/public/fixtures/public_tx_simulation_tester.ts +40 -6
  284. package/src/public/fixtures/simple_contract_data_source.ts +1 -1
  285. package/src/public/fixtures/token_test.ts +1 -1
  286. package/src/public/fixtures/utils.ts +2 -3
  287. package/src/public/fuzzing/avm_fuzzer_simulator.ts +288 -0
  288. package/src/public/fuzzing/avm_simulator_bin.ts +175 -0
  289. package/src/public/hinting_db_sources.ts +6 -2
  290. package/src/public/index.ts +2 -0
  291. package/src/public/public_db_sources.ts +16 -6
  292. package/src/public/public_processor/guarded_merkle_tree.ts +4 -0
  293. package/src/public/public_processor/public_processor.ts +49 -19
  294. package/src/public/public_processor/public_processor_metrics.ts +16 -44
  295. package/src/public/public_tx_simulator/contract_provider_for_cpp.ts +25 -63
  296. package/src/public/public_tx_simulator/cpp_public_tx_simulator.ts +65 -9
  297. package/src/public/public_tx_simulator/cpp_public_tx_simulator_with_hinted_dbs.ts +7 -5
  298. package/src/public/public_tx_simulator/cpp_vs_ts_public_tx_simulator.ts +13 -14
  299. package/src/public/public_tx_simulator/dumping_cpp_public_tx_simulator.ts +83 -0
  300. package/src/public/public_tx_simulator/factories.ts +43 -0
  301. package/src/public/public_tx_simulator/index.ts +2 -0
  302. package/src/public/public_tx_simulator/measured_public_tx_simulator.ts +1 -1
  303. package/src/public/public_tx_simulator/public_tx_context.ts +14 -7
  304. package/src/public/public_tx_simulator/public_tx_simulator.ts +32 -10
  305. package/src/public/public_tx_simulator/public_tx_simulator_interface.ts +23 -0
  306. package/src/public/public_tx_simulator/telemetry_public_tx_simulator.ts +1 -1
  307. package/src/public/side_effect_trace.ts +6 -3
  308. package/src/public/side_effect_trace_interface.ts +1 -1
  309. package/src/public/state_manager/nullifiers.ts +1 -1
  310. package/src/public/state_manager/public_storage.ts +1 -1
  311. package/src/public/state_manager/state_manager.ts +31 -22
  312. package/src/public/test_executor_metrics.ts +3 -3
@@ -1,4 +1,5 @@
1
- import { Attributes, Metrics, ValueType } from '@aztec/telemetry-client';
1
+ import { TxExecutionPhase } from '@aztec/stdlib/tx';
2
+ import { Attributes, Metrics, createUpDownCounterWithDefault } from '@aztec/telemetry-client';
2
3
  export class PublicProcessorMetrics {
3
4
  tracer;
4
5
  txDuration;
@@ -15,50 +16,32 @@ export class PublicProcessorMetrics {
15
16
  constructor(client, name = 'PublicProcessor'){
16
17
  this.tracer = client.getTracer(name);
17
18
  const meter = client.getMeter(name);
18
- this.txDuration = meter.createHistogram(Metrics.PUBLIC_PROCESSOR_TX_DURATION, {
19
- description: 'How long it takes to process a transaction',
20
- unit: 'ms',
21
- valueType: ValueType.INT
22
- });
23
- this.txCount = meter.createUpDownCounter(Metrics.PUBLIC_PROCESSOR_TX_COUNT, {
24
- description: 'Number of transactions processed'
25
- });
26
- this.txPhaseCount = meter.createUpDownCounter(Metrics.PUBLIC_PROCESSOR_TX_PHASE_COUNT, {
27
- description: 'Number of phases processed'
28
- });
29
- this.phaseDuration = meter.createHistogram(Metrics.PUBLIC_PROCESSOR_PHASE_DURATION, {
30
- description: 'How long it takes to process a phase',
31
- unit: 'ms',
32
- valueType: ValueType.INT
33
- });
34
- this.phaseCount = meter.createUpDownCounter(Metrics.PUBLIC_PROCESSOR_PHASE_COUNT, {
35
- description: 'Number of failed phases'
36
- });
37
- this.bytecodeDeployed = meter.createHistogram(Metrics.PUBLIC_PROCESSOR_DEPLOY_BYTECODE_SIZE, {
38
- description: 'Size of deployed bytecode',
39
- unit: 'By'
40
- });
41
- this.totalGas = meter.createGauge(Metrics.PUBLIC_PROCESSOR_TOTAL_GAS, {
42
- description: 'Total gas used in block',
43
- unit: 'gas'
44
- });
45
- this.totalGasHistogram = meter.createHistogram(Metrics.PUBLIC_PROCESSOR_TOTAL_GAS_HISTOGRAM, {
46
- description: 'Total gas used in block as histogram',
47
- unit: 'gas/block'
48
- });
49
- this.txGas = meter.createHistogram(Metrics.PUBLIC_PROCESSOR_TX_GAS, {
50
- description: 'Gas used in transaction',
51
- unit: 'gas/tx'
52
- });
53
- this.gasRate = meter.createHistogram(Metrics.PUBLIC_PROCESSOR_GAS_RATE, {
54
- description: 'L2 gas per second for complete block',
55
- unit: 'gas/s'
56
- });
57
- this.treeInsertionDuration = meter.createHistogram(Metrics.PUBLIC_PROCESSOR_TREE_INSERTION, {
58
- description: 'How long it takes for tree insertion',
59
- unit: 'us',
60
- valueType: ValueType.INT
61
- });
19
+ this.txDuration = meter.createHistogram(Metrics.PUBLIC_PROCESSOR_TX_DURATION);
20
+ this.txCount = createUpDownCounterWithDefault(meter, Metrics.PUBLIC_PROCESSOR_TX_COUNT, {
21
+ [Attributes.OK]: [
22
+ true,
23
+ false
24
+ ]
25
+ });
26
+ this.txPhaseCount = createUpDownCounterWithDefault(meter, Metrics.PUBLIC_PROCESSOR_TX_PHASE_COUNT);
27
+ this.phaseDuration = meter.createHistogram(Metrics.PUBLIC_PROCESSOR_PHASE_DURATION);
28
+ this.phaseCount = createUpDownCounterWithDefault(meter, Metrics.PUBLIC_PROCESSOR_PHASE_COUNT, {
29
+ [Attributes.TX_PHASE_NAME]: [
30
+ TxExecutionPhase.SETUP,
31
+ TxExecutionPhase.APP_LOGIC,
32
+ TxExecutionPhase.TEARDOWN
33
+ ],
34
+ [Attributes.OK]: [
35
+ true,
36
+ false
37
+ ]
38
+ });
39
+ this.bytecodeDeployed = meter.createHistogram(Metrics.PUBLIC_PROCESSOR_DEPLOY_BYTECODE_SIZE);
40
+ this.totalGas = meter.createGauge(Metrics.PUBLIC_PROCESSOR_TOTAL_GAS);
41
+ this.totalGasHistogram = meter.createHistogram(Metrics.PUBLIC_PROCESSOR_TOTAL_GAS_HISTOGRAM);
42
+ this.txGas = meter.createHistogram(Metrics.PUBLIC_PROCESSOR_TX_GAS);
43
+ this.gasRate = meter.createHistogram(Metrics.PUBLIC_PROCESSOR_GAS_RATE);
44
+ this.treeInsertionDuration = meter.createHistogram(Metrics.PUBLIC_PROCESSOR_TREE_INSERTION);
62
45
  }
63
46
  recordPhaseDuration(phaseName, durationMs) {
64
47
  this.phaseCount.add(1, {
@@ -1,3 +1,4 @@
1
+ import { type LoggerBindings } from '@aztec/foundation/log';
1
2
  import type { ContractProvider } from '@aztec/native';
2
3
  import type { GlobalVariables } from '@aztec/stdlib/tx';
3
4
  import type { PublicContractsDB } from '../public_db_sources.js';
@@ -5,7 +6,7 @@ export declare class ContractProviderForCpp implements ContractProvider {
5
6
  private contractsDB;
6
7
  private globalVariables;
7
8
  private log;
8
- constructor(contractsDB: PublicContractsDB, globalVariables: GlobalVariables);
9
+ constructor(contractsDB: PublicContractsDB, globalVariables: GlobalVariables, bindings?: LoggerBindings);
9
10
  getContractInstance: (address: string) => Promise<Buffer<ArrayBufferLike> | undefined>;
10
11
  getContractClass: (classId: string) => Promise<Buffer<ArrayBufferLike> | undefined>;
11
12
  addContracts: (contractDeploymentDataBuffer: Buffer<ArrayBufferLike>) => Promise<void>;
@@ -14,17 +15,5 @@ export declare class ContractProviderForCpp implements ContractProvider {
14
15
  createCheckpoint: () => Promise<void>;
15
16
  commitCheckpoint: () => Promise<void>;
16
17
  revertCheckpoint: () => Promise<void>;
17
- /**
18
- * Reconstruct ContractDeploymentData from plain msgpack-deserialized objects.
19
- *
20
- * msgpackr does not automatically apply extensions to nested fields, so we need to
21
- * manually reconstruct ContractClassLog and PrivateLog instances with proper types.
22
- *
23
- * TODO(dbanks12): we really shouldn't have to do this.... We need to for now because
24
- * msgpack deserialization doesn't give us actual typed objects, but rather just JSON.
25
- * It would be easier if all types matched between languages (like AztecAddress which is just
26
- * FF in C++).
27
- */
28
- private reconstructContractDeploymentData;
29
18
  }
30
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29udHJhY3RfcHJvdmlkZXJfZm9yX2NwcC5kLnRzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vc3JjL3B1YmxpYy9wdWJsaWNfdHhfc2ltdWxhdG9yL2NvbnRyYWN0X3Byb3ZpZGVyX2Zvcl9jcHAudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBRUEsT0FBTyxLQUFLLEVBQUUsZ0JBQWdCLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFNdEQsT0FBTyxLQUFLLEVBQUUsZUFBZSxFQUFFLE1BQU0sa0JBQWtCLENBQUM7QUFFeEQsT0FBTyxLQUFLLEVBQUUsaUJBQWlCLEVBQUUsTUFBTSx5QkFBeUIsQ0FBQztBQUVqRSxxQkFBYSxzQkFBdUIsWUFBVyxnQkFBZ0I7SUFJM0QsT0FBTyxDQUFDLFdBQVc7SUFDbkIsT0FBTyxDQUFDLGVBQWU7SUFKekIsT0FBTyxDQUFDLEdBQUcsQ0FBK0Q7SUFFMUUsWUFDVSxXQUFXLEVBQUUsaUJBQWlCLEVBQzlCLGVBQWUsRUFBRSxlQUFlLEVBQ3RDO0lBRUcsbUJBQW1CLG9FQWF4QjtJQUVLLGdCQUFnQixvRUFlckI7SUFFSyxZQUFZLDJFQVdqQjtJQUVLLHFCQUFxQixvRUFnQjFCO0lBRUssb0JBQW9CLHFFQWlCekI7SUFFSyxnQkFBZ0Isc0JBR3JCO0lBRUssZ0JBQWdCLHNCQUdyQjtJQUVLLGdCQUFnQixzQkFHckI7SUFFRjs7Ozs7Ozs7OztPQVVHO0lBQ0gsT0FBTyxDQUFDLGlDQUFpQztDQWlDMUMifQ==
19
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29udHJhY3RfcHJvdmlkZXJfZm9yX2NwcC5kLnRzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vc3JjL3B1YmxpYy9wdWJsaWNfdHhfc2ltdWxhdG9yL2NvbnRyYWN0X3Byb3ZpZGVyX2Zvcl9jcHAudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQ0EsT0FBTyxFQUFlLEtBQUssY0FBYyxFQUFnQixNQUFNLHVCQUF1QixDQUFDO0FBQ3ZGLE9BQU8sS0FBSyxFQUFFLGdCQUFnQixFQUFFLE1BQU0sZUFBZSxDQUFDO0FBS3RELE9BQU8sS0FBSyxFQUFFLGVBQWUsRUFBRSxNQUFNLGtCQUFrQixDQUFDO0FBRXhELE9BQU8sS0FBSyxFQUFFLGlCQUFpQixFQUFFLE1BQU0seUJBQXlCLENBQUM7QUFFakUscUJBQWEsc0JBQXVCLFlBQVcsZ0JBQWdCO0lBSTNELE9BQU8sQ0FBQyxXQUFXO0lBQ25CLE9BQU8sQ0FBQyxlQUFlO0lBSnpCLE9BQU8sQ0FBQyxHQUFHLENBQVM7SUFFcEIsWUFDVSxXQUFXLEVBQUUsaUJBQWlCLEVBQzlCLGVBQWUsRUFBRSxlQUFlLEVBQ3hDLFFBQVEsQ0FBQyxFQUFFLGNBQWMsRUFHMUI7SUFFTSxtQkFBbUIsb0VBYXhCO0lBRUssZ0JBQWdCLG9FQWVyQjtJQUVLLFlBQVksMkVBV2pCO0lBRUsscUJBQXFCLG9FQWdCMUI7SUFFSyxvQkFBb0IscUVBc0J6QjtJQUVLLGdCQUFnQixzQkFHckI7SUFFSyxnQkFBZ0Isc0JBR3JCO0lBRUssZ0JBQWdCLHNCQUdyQjtDQUNIIn0=
@@ -1 +1 @@
1
- {"version":3,"file":"contract_provider_for_cpp.d.ts","sourceRoot":"","sources":["../../../src/public/public_tx_simulator/contract_provider_for_cpp.ts"],"names":[],"mappings":"AAEA,OAAO,KAAK,EAAE,gBAAgB,EAAE,MAAM,eAAe,CAAC;AAMtD,OAAO,KAAK,EAAE,eAAe,EAAE,MAAM,kBAAkB,CAAC;AAExD,OAAO,KAAK,EAAE,iBAAiB,EAAE,MAAM,yBAAyB,CAAC;AAEjE,qBAAa,sBAAuB,YAAW,gBAAgB;IAI3D,OAAO,CAAC,WAAW;IACnB,OAAO,CAAC,eAAe;IAJzB,OAAO,CAAC,GAAG,CAA+D;IAE1E,YACU,WAAW,EAAE,iBAAiB,EAC9B,eAAe,EAAE,eAAe,EACtC;IAEG,mBAAmB,oEAaxB;IAEK,gBAAgB,oEAerB;IAEK,YAAY,2EAWjB;IAEK,qBAAqB,oEAgB1B;IAEK,oBAAoB,qEAiBzB;IAEK,gBAAgB,sBAGrB;IAEK,gBAAgB,sBAGrB;IAEK,gBAAgB,sBAGrB;IAEF;;;;;;;;;;OAUG;IACH,OAAO,CAAC,iCAAiC;CAiC1C"}
1
+ {"version":3,"file":"contract_provider_for_cpp.d.ts","sourceRoot":"","sources":["../../../src/public/public_tx_simulator/contract_provider_for_cpp.ts"],"names":[],"mappings":"AACA,OAAO,EAAe,KAAK,cAAc,EAAgB,MAAM,uBAAuB,CAAC;AACvF,OAAO,KAAK,EAAE,gBAAgB,EAAE,MAAM,eAAe,CAAC;AAKtD,OAAO,KAAK,EAAE,eAAe,EAAE,MAAM,kBAAkB,CAAC;AAExD,OAAO,KAAK,EAAE,iBAAiB,EAAE,MAAM,yBAAyB,CAAC;AAEjE,qBAAa,sBAAuB,YAAW,gBAAgB;IAI3D,OAAO,CAAC,WAAW;IACnB,OAAO,CAAC,eAAe;IAJzB,OAAO,CAAC,GAAG,CAAS;IAEpB,YACU,WAAW,EAAE,iBAAiB,EAC9B,eAAe,EAAE,eAAe,EACxC,QAAQ,CAAC,EAAE,cAAc,EAG1B;IAEM,mBAAmB,oEAaxB;IAEK,gBAAgB,oEAerB;IAEK,YAAY,2EAWjB;IAEK,qBAAqB,oEAgB1B;IAEK,oBAAoB,qEAsBzB;IAEK,gBAAgB,sBAGrB;IAEK,gBAAgB,sBAGrB;IAEK,gBAAgB,sBAGrB;CACH"}
@@ -1,20 +1,18 @@
1
- import { Fr } from '@aztec/foundation/fields';
1
+ import { Fr } from '@aztec/foundation/curves/bn254';
2
2
  import { createLogger } from '@aztec/foundation/log';
3
3
  import { FunctionSelector } from '@aztec/stdlib/abi';
4
4
  import { deserializeFromMessagePack, serializeWithMessagePack } from '@aztec/stdlib/avm';
5
5
  import { AztecAddress } from '@aztec/stdlib/aztec-address';
6
6
  import { ContractDeploymentData } from '@aztec/stdlib/contract';
7
- import { ContractClassLog, ContractClassLogFields, PrivateLog } from '@aztec/stdlib/logs';
8
7
  export class ContractProviderForCpp {
9
8
  contractsDB;
10
9
  globalVariables;
11
10
  log;
12
- constructor(contractsDB, globalVariables){
11
+ constructor(contractsDB, globalVariables, bindings){
13
12
  this.contractsDB = contractsDB;
14
13
  this.globalVariables = globalVariables;
15
- this.log = createLogger('simulator:contract_provider_for_cpp');
16
14
  this.getContractInstance = async (address)=>{
17
- this.log.debug(`Contract provider callback: getContractInstance(${address})`);
15
+ this.log.trace(`Contract provider callback: getContractInstance(${address})`);
18
16
  const aztecAddr = AztecAddress.fromString(address);
19
17
  const instance = await this.contractsDB.getContractInstance(aztecAddr, this.globalVariables.timestamp);
20
18
  if (!instance) {
@@ -24,7 +22,7 @@ export class ContractProviderForCpp {
24
22
  return serializeWithMessagePack(instance);
25
23
  };
26
24
  this.getContractClass = async (classId)=>{
27
- this.log.debug(`Contract provider callback: getContractClass(${classId})`);
25
+ this.log.trace(`Contract provider callback: getContractClass(${classId})`);
28
26
  // Parse classId string to Fr
29
27
  const classIdFr = Fr.fromString(classId);
30
28
  // Fetch contract class from the contracts DB
@@ -36,16 +34,16 @@ export class ContractProviderForCpp {
36
34
  return serializeWithMessagePack(contractClass);
37
35
  };
38
36
  this.addContracts = async (contractDeploymentDataBuffer)=>{
39
- this.log.debug(`Contract provider callback: addContracts`);
37
+ this.log.trace(`Contract provider callback: addContracts`);
40
38
  const rawData = deserializeFromMessagePack(contractDeploymentDataBuffer);
41
- // Construct class instances using the from method
42
- const contractDeploymentData = this.reconstructContractDeploymentData(rawData);
39
+ // Construct ContractDeploymentData from plain object.
40
+ const contractDeploymentData = ContractDeploymentData.fromPlainObject(rawData);
43
41
  // Add contracts to the contracts DB
44
- this.log.debug(`Calling contractsDB.addContracts`);
42
+ this.log.trace(`Calling contractsDB.addContracts`);
45
43
  await this.contractsDB.addContracts(contractDeploymentData);
46
44
  };
47
45
  this.getBytecodeCommitment = async (classId)=>{
48
- this.log.debug(`Contract provider callback: getBytecodeCommitment(${classId})`);
46
+ this.log.trace(`Contract provider callback: getBytecodeCommitment(${classId})`);
49
47
  // Parse classId string to Fr
50
48
  const classIdFr = Fr.fromString(classId);
51
49
  // Fetch bytecode commitment from the contracts DB
@@ -58,31 +56,36 @@ export class ContractProviderForCpp {
58
56
  return serializeWithMessagePack(commitment);
59
57
  };
60
58
  this.getDebugFunctionName = async (address, selector)=>{
61
- this.log.debug(`Contract provider callback: getDebugFunctionName(${address}, ${selector})`);
59
+ this.log.trace(`Contract provider callback: getDebugFunctionName(${address}, ${selector})`);
62
60
  // Parse address and selector strings
63
61
  const aztecAddr = AztecAddress.fromString(address);
64
62
  const selectorFr = Fr.fromString(selector);
65
- const functionSelector = FunctionSelector.fromField(selectorFr);
63
+ const functionSelector = FunctionSelector.fromFieldOrUndefined(selectorFr);
64
+ if (!functionSelector) {
65
+ this.log.trace(`calldata[0] is not a function selector: ${selector}`);
66
+ return undefined;
67
+ }
66
68
  // Fetch debug function name from the contracts DB
67
69
  const name = await this.contractsDB.getDebugFunctionName(aztecAddr, functionSelector);
68
70
  if (!name) {
69
- this.log.debug(`Debug function name not found for ${address}:${selector}`);
71
+ this.log.trace(`Debug function name not found for ${address}:${selector}`);
70
72
  return undefined;
71
73
  }
72
74
  return name;
73
75
  };
74
76
  this.createCheckpoint = ()=>{
75
- this.log.debug(`Contract provider callback: createCheckpoint`);
77
+ this.log.trace(`Contract provider callback: createCheckpoint`);
76
78
  return Promise.resolve(this.contractsDB.createCheckpoint());
77
79
  };
78
80
  this.commitCheckpoint = ()=>{
79
- this.log.debug(`Contract provider callback: commitCheckpoint`);
81
+ this.log.trace(`Contract provider callback: commitCheckpoint`);
80
82
  return Promise.resolve(this.contractsDB.commitCheckpoint());
81
83
  };
82
84
  this.revertCheckpoint = ()=>{
83
- this.log.debug(`Contract provider callback: revertCheckpoint`);
85
+ this.log.trace(`Contract provider callback: revertCheckpoint`);
84
86
  return Promise.resolve(this.contractsDB.revertCheckpoint());
85
87
  };
88
+ this.log = createLogger('simulator:contract_provider_for_cpp', bindings);
86
89
  }
87
90
  getContractInstance;
88
91
  getContractClass;
@@ -92,42 +95,4 @@ export class ContractProviderForCpp {
92
95
  createCheckpoint;
93
96
  commitCheckpoint;
94
97
  revertCheckpoint;
95
- /**
96
- * Reconstruct ContractDeploymentData from plain msgpack-deserialized objects.
97
- *
98
- * msgpackr does not automatically apply extensions to nested fields, so we need to
99
- * manually reconstruct ContractClassLog and PrivateLog instances with proper types.
100
- *
101
- * TODO(dbanks12): we really shouldn't have to do this.... We need to for now because
102
- * msgpack deserialization doesn't give us actual typed objects, but rather just JSON.
103
- * It would be easier if all types matched between languages (like AztecAddress which is just
104
- * FF in C++).
105
- */ reconstructContractDeploymentData(rawData) {
106
- // Helper to ensure a value is an Fr instance
107
- const toFr = (value)=>{
108
- if (value instanceof Fr) {
109
- return value;
110
- }
111
- if (Buffer.isBuffer(value)) {
112
- return Fr.fromBuffer(value);
113
- }
114
- return new Fr(value);
115
- };
116
- // Reconstruct ContractClassLogs
117
- const contractClassLogs = (rawData.contractClassLogs || []).map((log)=>{
118
- // Convert contractAddress to TS AztecAddress
119
- const addressFr = toFr(log.contractAddress);
120
- const address = AztecAddress.fromField(addressFr);
121
- // Ensure all fields are Fr instances
122
- const fields = (log.fields.fields || []).map((field)=>toFr(field));
123
- // Create proper ContractClassLog instance
124
- return new ContractClassLog(address, new ContractClassLogFields(fields), log.emittedLength);
125
- });
126
- // Reconstruct PrivateLogs - ensure fields are Fr instances
127
- const privateLogs = (rawData.privateLogs || []).map((log)=>{
128
- const fields = (log.fields || []).map((field)=>toFr(field));
129
- return new PrivateLog(fields, log.emittedLength);
130
- });
131
- return new ContractDeploymentData(contractClassLogs, privateLogs);
132
- }
133
98
  }
@@ -1,4 +1,4 @@
1
- import { type Logger } from '@aztec/foundation/log';
1
+ import { type Logger, type LoggerBindings } from '@aztec/foundation/log';
2
2
  import { type PublicSimulatorConfig, PublicTxResult } from '@aztec/stdlib/avm';
3
3
  import type { MerkleTreeWriteOperations } from '@aztec/stdlib/trees';
4
4
  import type { GlobalVariables, Tx } from '@aztec/stdlib/tx';
@@ -14,7 +14,11 @@ import type { MeasuredPublicTxSimulatorInterface, PublicTxSimulatorInterface } f
14
14
  */
15
15
  export declare class CppPublicTxSimulator extends PublicTxSimulator implements PublicTxSimulatorInterface {
16
16
  protected log: Logger;
17
- constructor(merkleTree: MerkleTreeWriteOperations, contractsDB: PublicContractsDB, globalVariables: GlobalVariables, config?: Partial<PublicSimulatorConfig>);
17
+ /** Current cancellation token for in-flight simulation. */
18
+ private cancellationToken?;
19
+ /** Current simulation promise, used to wait for completion after cancellation. */
20
+ private simulationPromise?;
21
+ constructor(merkleTree: MerkleTreeWriteOperations, contractsDB: PublicContractsDB, globalVariables: GlobalVariables, config?: Partial<PublicSimulatorConfig>, bindings?: LoggerBindings);
18
22
  /**
19
23
  * Simulate a transaction's public portion using the C++ avvm simulator.
20
24
  *
@@ -22,10 +26,21 @@ export declare class CppPublicTxSimulator extends PublicTxSimulator implements P
22
26
  * @returns The result of the transaction's public execution.
23
27
  */
24
28
  simulate(tx: Tx): Promise<PublicTxResult>;
29
+ /**
30
+ * Cancel the current simulation if one is in progress.
31
+ * This signals the C++ simulator to stop at the next opcode or before the next WorldState write.
32
+ * Safe to call even if no simulation is in progress.
33
+ *
34
+ * @param waitTimeoutMs - If provided, wait up to this many ms for the simulation to actually stop.
35
+ * This is important because C++ might be in the middle of a slow operation
36
+ * (e.g., pad_trees) and won't check the cancellation flag until it completes.
37
+ * Default timeout of 100ms after cancellation.
38
+ */
39
+ cancel(waitTimeoutMs?: number): Promise<void>;
25
40
  }
26
41
  export declare class MeasuredCppPublicTxSimulator extends CppPublicTxSimulator implements MeasuredPublicTxSimulatorInterface {
27
42
  protected readonly metrics: ExecutorMetricsInterface;
28
- constructor(merkleTree: MerkleTreeWriteOperations, contractsDB: PublicContractsDB, globalVariables: GlobalVariables, metrics: ExecutorMetricsInterface, config?: Partial<PublicSimulatorConfig>);
43
+ constructor(merkleTree: MerkleTreeWriteOperations, contractsDB: PublicContractsDB, globalVariables: GlobalVariables, metrics: ExecutorMetricsInterface, config?: Partial<PublicSimulatorConfig>, bindings?: LoggerBindings);
29
44
  simulate(tx: Tx, txLabel?: string): Promise<PublicTxResult>;
30
45
  }
31
46
  /**
@@ -33,6 +48,6 @@ export declare class MeasuredCppPublicTxSimulator extends CppPublicTxSimulator i
33
48
  */
34
49
  export declare class TelemetryCppPublicTxSimulator extends MeasuredCppPublicTxSimulator {
35
50
  readonly tracer: Tracer;
36
- constructor(merkleTree: MerkleTreeWriteOperations, contractsDB: PublicContractsDB, globalVariables: GlobalVariables, telemetryClient?: TelemetryClient, config?: Partial<PublicSimulatorConfig>);
51
+ constructor(merkleTree: MerkleTreeWriteOperations, contractsDB: PublicContractsDB, globalVariables: GlobalVariables, telemetryClient?: TelemetryClient, config?: Partial<PublicSimulatorConfig>, bindings?: LoggerBindings);
37
52
  }
38
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY3BwX3B1YmxpY190eF9zaW11bGF0b3IuZC50cyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9wdWJsaWMvcHVibGljX3R4X3NpbXVsYXRvci9jcHBfcHVibGljX3R4X3NpbXVsYXRvci50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsS0FBSyxNQUFNLEVBQTBCLE1BQU0sdUJBQXVCLENBQUM7QUFHNUUsT0FBTyxFQUdMLEtBQUsscUJBQXFCLEVBQzFCLGNBQWMsRUFFZixNQUFNLG1CQUFtQixDQUFDO0FBRTNCLE9BQU8sS0FBSyxFQUFFLHlCQUF5QixFQUFFLE1BQU0scUJBQXFCLENBQUM7QUFDckUsT0FBTyxLQUFLLEVBQUUsZUFBZSxFQUFFLEVBQUUsRUFBRSxNQUFNLGtCQUFrQixDQUFDO0FBRTVELE9BQU8sRUFBRSxLQUFLLGVBQWUsRUFBRSxLQUFLLE1BQU0sRUFBc0IsTUFBTSx5QkFBeUIsQ0FBQztBQUtoRyxPQUFPLEtBQUssRUFBRSx3QkFBd0IsRUFBRSxNQUFNLGtDQUFrQyxDQUFDO0FBQ2pGLE9BQU8sS0FBSyxFQUFFLGlCQUFpQixFQUFFLE1BQU0seUJBQXlCLENBQUM7QUFFakUsT0FBTyxFQUFFLGlCQUFpQixFQUFFLE1BQU0sMEJBQTBCLENBQUM7QUFDN0QsT0FBTyxLQUFLLEVBQ1Ysa0NBQWtDLEVBQ2xDLDBCQUEwQixFQUMzQixNQUFNLG9DQUFvQyxDQUFDO0FBRTVDOzs7O0dBSUc7QUFDSCxxQkFBYSxvQkFBcUIsU0FBUSxpQkFBa0IsWUFBVywwQkFBMEI7SUFDL0YsVUFBbUIsR0FBRyxFQUFFLE1BQU0sQ0FBQztJQUUvQixZQUNFLFVBQVUsRUFBRSx5QkFBeUIsRUFDckMsV0FBVyxFQUFFLGlCQUFpQixFQUM5QixlQUFlLEVBQUUsZUFBZSxFQUNoQyxNQUFNLENBQUMsRUFBRSxPQUFPLENBQUMscUJBQXFCLENBQUMsRUFJeEM7SUFFRDs7Ozs7T0FLRztJQUNtQixRQUFRLENBQUMsRUFBRSxFQUFFLEVBQUUsR0FBRyxPQUFPLENBQUMsY0FBYyxDQUFDLENBMEQ5RDtDQUNGO0FBRUQscUJBQWEsNEJBQTZCLFNBQVEsb0JBQXFCLFlBQVcsa0NBQWtDO0lBS2hILFNBQVMsQ0FBQyxRQUFRLENBQUMsT0FBTyxFQUFFLHdCQUF3QjtJQUp0RCxZQUNFLFVBQVUsRUFBRSx5QkFBeUIsRUFDckMsV0FBVyxFQUFFLGlCQUFpQixFQUM5QixlQUFlLEVBQUUsZUFBZSxFQUNiLE9BQU8sRUFBRSx3QkFBd0IsRUFDcEQsTUFBTSxDQUFDLEVBQUUsT0FBTyxDQUFDLHFCQUFxQixDQUFDLEVBR3hDO0lBRXFCLFFBQVEsQ0FBQyxFQUFFLEVBQUUsRUFBRSxFQUFFLE9BQU8sR0FBRSxNQUFzQixHQUFHLE9BQU8sQ0FBQyxjQUFjLENBQUMsQ0FTL0Y7Q0FDRjtBQUVEOztHQUVHO0FBQ0gscUJBQWEsNkJBQThCLFNBQVEsNEJBQTRCO0lBRTdFLFNBQWdCLE1BQU0sRUFBRSxNQUFNLENBQUM7SUFFL0IsWUFDRSxVQUFVLEVBQUUseUJBQXlCLEVBQ3JDLFdBQVcsRUFBRSxpQkFBaUIsRUFDOUIsZUFBZSxFQUFFLGVBQWUsRUFDaEMsZUFBZSxHQUFFLGVBQXNDLEVBQ3ZELE1BQU0sQ0FBQyxFQUFFLE9BQU8sQ0FBQyxxQkFBcUIsQ0FBQyxFQUt4QztDQUNGIn0=
53
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY3BwX3B1YmxpY190eF9zaW11bGF0b3IuZC50cyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9wdWJsaWMvcHVibGljX3R4X3NpbXVsYXRvci9jcHBfcHVibGljX3R4X3NpbXVsYXRvci50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsS0FBSyxNQUFNLEVBQUUsS0FBSyxjQUFjLEVBQTBCLE1BQU0sdUJBQXVCLENBQUM7QUFJakcsT0FBTyxFQUdMLEtBQUsscUJBQXFCLEVBQzFCLGNBQWMsRUFFZixNQUFNLG1CQUFtQixDQUFDO0FBRTNCLE9BQU8sS0FBSyxFQUFFLHlCQUF5QixFQUFFLE1BQU0scUJBQXFCLENBQUM7QUFDckUsT0FBTyxLQUFLLEVBQUUsZUFBZSxFQUFFLEVBQUUsRUFBRSxNQUFNLGtCQUFrQixDQUFDO0FBRTVELE9BQU8sRUFBRSxLQUFLLGVBQWUsRUFBRSxLQUFLLE1BQU0sRUFBc0IsTUFBTSx5QkFBeUIsQ0FBQztBQUtoRyxPQUFPLEtBQUssRUFBRSx3QkFBd0IsRUFBRSxNQUFNLGtDQUFrQyxDQUFDO0FBQ2pGLE9BQU8sS0FBSyxFQUFFLGlCQUFpQixFQUFFLE1BQU0seUJBQXlCLENBQUM7QUFFakUsT0FBTyxFQUFFLGlCQUFpQixFQUFFLE1BQU0sMEJBQTBCLENBQUM7QUFDN0QsT0FBTyxLQUFLLEVBQ1Ysa0NBQWtDLEVBQ2xDLDBCQUEwQixFQUMzQixNQUFNLG9DQUFvQyxDQUFDO0FBRTVDOzs7O0dBSUc7QUFDSCxxQkFBYSxvQkFBcUIsU0FBUSxpQkFBa0IsWUFBVywwQkFBMEI7SUFDL0YsVUFBbUIsR0FBRyxFQUFFLE1BQU0sQ0FBQztJQUMvQiwyREFBMkQ7SUFDM0QsT0FBTyxDQUFDLGlCQUFpQixDQUFDLENBQW9CO0lBQzlDLGtGQUFrRjtJQUNsRixPQUFPLENBQUMsaUJBQWlCLENBQUMsQ0FBa0I7SUFFNUMsWUFDRSxVQUFVLEVBQUUseUJBQXlCLEVBQ3JDLFdBQVcsRUFBRSxpQkFBaUIsRUFDOUIsZUFBZSxFQUFFLGVBQWUsRUFDaEMsTUFBTSxDQUFDLEVBQUUsT0FBTyxDQUFDLHFCQUFxQixDQUFDLEVBQ3ZDLFFBQVEsQ0FBQyxFQUFFLGNBQWMsRUFJMUI7SUFFRDs7Ozs7T0FLRztJQUNtQixRQUFRLENBQUMsRUFBRSxFQUFFLEVBQUUsR0FBRyxPQUFPLENBQUMsY0FBYyxDQUFDLENBK0U5RDtJQUVEOzs7Ozs7Ozs7T0FTRztJQUNVLE1BQU0sQ0FBQyxhQUFhLEdBQUUsTUFBWSxHQUFHLE9BQU8sQ0FBQyxJQUFJLENBQUMsQ0FlOUQ7Q0FDRjtBQUVELHFCQUFhLDRCQUE2QixTQUFRLG9CQUFxQixZQUFXLGtDQUFrQztJQUtoSCxTQUFTLENBQUMsUUFBUSxDQUFDLE9BQU8sRUFBRSx3QkFBd0I7SUFKdEQsWUFDRSxVQUFVLEVBQUUseUJBQXlCLEVBQ3JDLFdBQVcsRUFBRSxpQkFBaUIsRUFDOUIsZUFBZSxFQUFFLGVBQWUsRUFDYixPQUFPLEVBQUUsd0JBQXdCLEVBQ3BELE1BQU0sQ0FBQyxFQUFFLE9BQU8sQ0FBQyxxQkFBcUIsQ0FBQyxFQUN2QyxRQUFRLENBQUMsRUFBRSxjQUFjLEVBRzFCO0lBRXFCLFFBQVEsQ0FBQyxFQUFFLEVBQUUsRUFBRSxFQUFFLE9BQU8sR0FBRSxNQUFzQixHQUFHLE9BQU8sQ0FBQyxjQUFjLENBQUMsQ0FTL0Y7Q0FDRjtBQUVEOztHQUVHO0FBQ0gscUJBQWEsNkJBQThCLFNBQVEsNEJBQTRCO0lBRTdFLFNBQWdCLE1BQU0sRUFBRSxNQUFNLENBQUM7SUFFL0IsWUFDRSxVQUFVLEVBQUUseUJBQXlCLEVBQ3JDLFdBQVcsRUFBRSxpQkFBaUIsRUFDOUIsZUFBZSxFQUFFLGVBQWUsRUFDaEMsZUFBZSxHQUFFLGVBQXNDLEVBQ3ZELE1BQU0sQ0FBQyxFQUFFLE9BQU8sQ0FBQyxxQkFBcUIsQ0FBQyxFQUN2QyxRQUFRLENBQUMsRUFBRSxjQUFjLEVBSzFCO0NBQ0YifQ==
@@ -1 +1 @@
1
- {"version":3,"file":"cpp_public_tx_simulator.d.ts","sourceRoot":"","sources":["../../../src/public/public_tx_simulator/cpp_public_tx_simulator.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,KAAK,MAAM,EAA0B,MAAM,uBAAuB,CAAC;AAG5E,OAAO,EAGL,KAAK,qBAAqB,EAC1B,cAAc,EAEf,MAAM,mBAAmB,CAAC;AAE3B,OAAO,KAAK,EAAE,yBAAyB,EAAE,MAAM,qBAAqB,CAAC;AACrE,OAAO,KAAK,EAAE,eAAe,EAAE,EAAE,EAAE,MAAM,kBAAkB,CAAC;AAE5D,OAAO,EAAE,KAAK,eAAe,EAAE,KAAK,MAAM,EAAsB,MAAM,yBAAyB,CAAC;AAKhG,OAAO,KAAK,EAAE,wBAAwB,EAAE,MAAM,kCAAkC,CAAC;AACjF,OAAO,KAAK,EAAE,iBAAiB,EAAE,MAAM,yBAAyB,CAAC;AAEjE,OAAO,EAAE,iBAAiB,EAAE,MAAM,0BAA0B,CAAC;AAC7D,OAAO,KAAK,EACV,kCAAkC,EAClC,0BAA0B,EAC3B,MAAM,oCAAoC,CAAC;AAE5C;;;;GAIG;AACH,qBAAa,oBAAqB,SAAQ,iBAAkB,YAAW,0BAA0B;IAC/F,UAAmB,GAAG,EAAE,MAAM,CAAC;IAE/B,YACE,UAAU,EAAE,yBAAyB,EACrC,WAAW,EAAE,iBAAiB,EAC9B,eAAe,EAAE,eAAe,EAChC,MAAM,CAAC,EAAE,OAAO,CAAC,qBAAqB,CAAC,EAIxC;IAED;;;;;OAKG;IACmB,QAAQ,CAAC,EAAE,EAAE,EAAE,GAAG,OAAO,CAAC,cAAc,CAAC,CA0D9D;CACF;AAED,qBAAa,4BAA6B,SAAQ,oBAAqB,YAAW,kCAAkC;IAKhH,SAAS,CAAC,QAAQ,CAAC,OAAO,EAAE,wBAAwB;IAJtD,YACE,UAAU,EAAE,yBAAyB,EACrC,WAAW,EAAE,iBAAiB,EAC9B,eAAe,EAAE,eAAe,EACb,OAAO,EAAE,wBAAwB,EACpD,MAAM,CAAC,EAAE,OAAO,CAAC,qBAAqB,CAAC,EAGxC;IAEqB,QAAQ,CAAC,EAAE,EAAE,EAAE,EAAE,OAAO,GAAE,MAAsB,GAAG,OAAO,CAAC,cAAc,CAAC,CAS/F;CACF;AAED;;GAEG;AACH,qBAAa,6BAA8B,SAAQ,4BAA4B;IAE7E,SAAgB,MAAM,EAAE,MAAM,CAAC;IAE/B,YACE,UAAU,EAAE,yBAAyB,EACrC,WAAW,EAAE,iBAAiB,EAC9B,eAAe,EAAE,eAAe,EAChC,eAAe,GAAE,eAAsC,EACvD,MAAM,CAAC,EAAE,OAAO,CAAC,qBAAqB,CAAC,EAKxC;CACF"}
1
+ {"version":3,"file":"cpp_public_tx_simulator.d.ts","sourceRoot":"","sources":["../../../src/public/public_tx_simulator/cpp_public_tx_simulator.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,KAAK,MAAM,EAAE,KAAK,cAAc,EAA0B,MAAM,uBAAuB,CAAC;AAIjG,OAAO,EAGL,KAAK,qBAAqB,EAC1B,cAAc,EAEf,MAAM,mBAAmB,CAAC;AAE3B,OAAO,KAAK,EAAE,yBAAyB,EAAE,MAAM,qBAAqB,CAAC;AACrE,OAAO,KAAK,EAAE,eAAe,EAAE,EAAE,EAAE,MAAM,kBAAkB,CAAC;AAE5D,OAAO,EAAE,KAAK,eAAe,EAAE,KAAK,MAAM,EAAsB,MAAM,yBAAyB,CAAC;AAKhG,OAAO,KAAK,EAAE,wBAAwB,EAAE,MAAM,kCAAkC,CAAC;AACjF,OAAO,KAAK,EAAE,iBAAiB,EAAE,MAAM,yBAAyB,CAAC;AAEjE,OAAO,EAAE,iBAAiB,EAAE,MAAM,0BAA0B,CAAC;AAC7D,OAAO,KAAK,EACV,kCAAkC,EAClC,0BAA0B,EAC3B,MAAM,oCAAoC,CAAC;AAE5C;;;;GAIG;AACH,qBAAa,oBAAqB,SAAQ,iBAAkB,YAAW,0BAA0B;IAC/F,UAAmB,GAAG,EAAE,MAAM,CAAC;IAC/B,2DAA2D;IAC3D,OAAO,CAAC,iBAAiB,CAAC,CAAoB;IAC9C,kFAAkF;IAClF,OAAO,CAAC,iBAAiB,CAAC,CAAkB;IAE5C,YACE,UAAU,EAAE,yBAAyB,EACrC,WAAW,EAAE,iBAAiB,EAC9B,eAAe,EAAE,eAAe,EAChC,MAAM,CAAC,EAAE,OAAO,CAAC,qBAAqB,CAAC,EACvC,QAAQ,CAAC,EAAE,cAAc,EAI1B;IAED;;;;;OAKG;IACmB,QAAQ,CAAC,EAAE,EAAE,EAAE,GAAG,OAAO,CAAC,cAAc,CAAC,CA+E9D;IAED;;;;;;;;;OASG;IACU,MAAM,CAAC,aAAa,GAAE,MAAY,GAAG,OAAO,CAAC,IAAI,CAAC,CAe9D;CACF;AAED,qBAAa,4BAA6B,SAAQ,oBAAqB,YAAW,kCAAkC;IAKhH,SAAS,CAAC,QAAQ,CAAC,OAAO,EAAE,wBAAwB;IAJtD,YACE,UAAU,EAAE,yBAAyB,EACrC,WAAW,EAAE,iBAAiB,EAC9B,eAAe,EAAE,eAAe,EACb,OAAO,EAAE,wBAAwB,EACpD,MAAM,CAAC,EAAE,OAAO,CAAC,qBAAqB,CAAC,EACvC,QAAQ,CAAC,EAAE,cAAc,EAG1B;IAEqB,QAAQ,CAAC,EAAE,EAAE,EAAE,EAAE,OAAO,GAAE,MAAsB,GAAG,OAAO,CAAC,cAAc,CAAC,CAS/F;CACF;AAED;;GAEG;AACH,qBAAa,6BAA8B,SAAQ,4BAA4B;IAE7E,SAAgB,MAAM,EAAE,MAAM,CAAC;IAE/B,YACE,UAAU,EAAE,yBAAyB,EACrC,WAAW,EAAE,iBAAiB,EAC9B,eAAe,EAAE,eAAe,EAChC,eAAe,GAAE,eAAsC,EACvD,MAAM,CAAC,EAAE,OAAO,CAAC,qBAAqB,CAAC,EACvC,QAAQ,CAAC,EAAE,cAAc,EAK1B;CACF"}
@@ -1,5 +1,6 @@
1
1
  import { createLogger, logLevel } from '@aztec/foundation/log';
2
- import { avmSimulate } from '@aztec/native';
2
+ import { sleep } from '@aztec/foundation/sleep';
3
+ import { avmSimulate, cancelSimulation, createCancellationToken } from '@aztec/native';
3
4
  import { ProtocolContractsList } from '@aztec/protocol-contracts';
4
5
  import { AvmFastSimulationInputs, AvmTxHint, PublicTxResult, deserializeFromMessagePack } from '@aztec/stdlib/avm';
5
6
  import { SimulationError } from '@aztec/stdlib/errors';
@@ -15,9 +16,11 @@ import { PublicTxSimulator } from './public_tx_simulator.js';
15
16
  * For contract DB accesses, it makes callbacks through NAPI back to the TS PublicContractsDB cache.
16
17
  */ export class CppPublicTxSimulator extends PublicTxSimulator {
17
18
  log;
18
- constructor(merkleTree, contractsDB, globalVariables, config){
19
- super(merkleTree, contractsDB, globalVariables, config);
20
- this.log = createLogger(`simulator:cpp_public_tx_simulator`);
19
+ /** Current cancellation token for in-flight simulation. */ cancellationToken;
20
+ /** Current simulation promise, used to wait for completion after cancellation. */ simulationPromise;
21
+ constructor(merkleTree, contractsDB, globalVariables, config, bindings){
22
+ super(merkleTree, contractsDB, globalVariables, config, undefined, bindings);
23
+ this.log = createLogger(`simulator:cpp_public_tx_simulator`, bindings);
21
24
  }
22
25
  /**
23
26
  * Simulate a transaction's public portion using the C++ avvm simulator.
@@ -40,16 +43,28 @@ import { PublicTxSimulator } from './public_tx_simulator.js';
40
43
  const protocolContracts = ProtocolContractsList;
41
44
  const fastSimInputs = new AvmFastSimulationInputs(wsRevision, this.config, txHint, this.globalVariables, protocolContracts);
42
45
  // Create contract provider for callbacks to TypeScript PublicContractsDB from C++
43
- const contractProvider = new ContractProviderForCpp(this.contractsDB, this.globalVariables);
46
+ const contractProvider = new ContractProviderForCpp(this.contractsDB, this.globalVariables, this.bindings);
44
47
  // Serialize to msgpack and call the C++ simulator
45
48
  this.log.trace(`Serializing fast simulation inputs to msgpack...`);
46
49
  const inputBuffer = fastSimInputs.serializeWithMessagePack();
50
+ // Create cancellation token for this simulation
51
+ this.cancellationToken = createCancellationToken();
52
+ // Store the promise so cancel() can wait for it
53
+ this.log.debug(`Calling C++ simulator for tx ${txHash}`);
54
+ this.simulationPromise = avmSimulate(inputBuffer, contractProvider, wsCppHandle, logLevel, // TODO: re-enable logging
55
+ undefined, this.cancellationToken);
47
56
  let resultBuffer;
48
57
  try {
49
- this.log.debug(`Calling C++ simulator for tx ${txHash}`);
50
- resultBuffer = await avmSimulate(inputBuffer, contractProvider, wsCppHandle, logLevel);
58
+ resultBuffer = await this.simulationPromise;
51
59
  } catch (error) {
60
+ // Check if this was a cancellation
61
+ if (error.message?.includes('Simulation cancelled')) {
62
+ throw new SimulationError(`C++ simulation cancelled`, []);
63
+ }
52
64
  throw new SimulationError(`C++ simulation failed: ${error.message}`, []);
65
+ } finally{
66
+ this.cancellationToken = undefined;
67
+ this.simulationPromise = undefined;
53
68
  }
54
69
  // If we've reached this point, C++ succeeded during simulation,
55
70
  // Deserialize the msgpack result
@@ -64,11 +79,35 @@ import { PublicTxSimulator } from './public_tx_simulator.js';
64
79
  });
65
80
  return cppResult;
66
81
  }
82
+ /**
83
+ * Cancel the current simulation if one is in progress.
84
+ * This signals the C++ simulator to stop at the next opcode or before the next WorldState write.
85
+ * Safe to call even if no simulation is in progress.
86
+ *
87
+ * @param waitTimeoutMs - If provided, wait up to this many ms for the simulation to actually stop.
88
+ * This is important because C++ might be in the middle of a slow operation
89
+ * (e.g., pad_trees) and won't check the cancellation flag until it completes.
90
+ * Default timeout of 100ms after cancellation.
91
+ */ async cancel(waitTimeoutMs = 100) {
92
+ if (this.cancellationToken) {
93
+ this.log.debug('Cancelling C++ simulation');
94
+ cancelSimulation(this.cancellationToken);
95
+ }
96
+ // Wait for the simulation to actually complete if not already done
97
+ if (this.simulationPromise) {
98
+ this.log.debug(`Waiting up to ${waitTimeoutMs}ms for C++ simulation to stop`);
99
+ await Promise.race([
100
+ this.simulationPromise.catch(()=>{}),
101
+ sleep(waitTimeoutMs)
102
+ ]);
103
+ this.log.debug('C++ simulation stopped or wait timed out');
104
+ }
105
+ }
67
106
  }
68
107
  export class MeasuredCppPublicTxSimulator extends CppPublicTxSimulator {
69
108
  metrics;
70
- constructor(merkleTree, contractsDB, globalVariables, metrics, config){
71
- super(merkleTree, contractsDB, globalVariables, config), this.metrics = metrics;
109
+ constructor(merkleTree, contractsDB, globalVariables, metrics, config, bindings){
110
+ super(merkleTree, contractsDB, globalVariables, config, bindings), this.metrics = metrics;
72
111
  }
73
112
  async simulate(tx, txLabel = 'unlabeledTx') {
74
113
  this.metrics.startRecordingTxSimulation(txLabel);
@@ -85,9 +124,9 @@ export class MeasuredCppPublicTxSimulator extends CppPublicTxSimulator {
85
124
  * A C++ public tx simulator that tracks runtime/production metrics with telemetry.
86
125
  */ export class TelemetryCppPublicTxSimulator extends MeasuredCppPublicTxSimulator {
87
126
  /* tracer needed by trackSpans */ tracer;
88
- constructor(merkleTree, contractsDB, globalVariables, telemetryClient = getTelemetryClient(), config){
127
+ constructor(merkleTree, contractsDB, globalVariables, telemetryClient = getTelemetryClient(), config, bindings){
89
128
  const metrics = new ExecutorMetrics(telemetryClient, 'CppPublicTxSimulator');
90
- super(merkleTree, contractsDB, globalVariables, metrics, config);
129
+ super(merkleTree, contractsDB, globalVariables, metrics, config, bindings);
91
130
  this.tracer = metrics.tracer;
92
131
  }
93
132
  }
@@ -1,4 +1,4 @@
1
- import { type Logger } from '@aztec/foundation/log';
1
+ import { type Logger, type LoggerBindings } from '@aztec/foundation/log';
2
2
  import { type PublicSimulatorConfig, PublicTxResult } from '@aztec/stdlib/avm';
3
3
  import type { MerkleTreeWriteOperations } from '@aztec/stdlib/trees';
4
4
  import type { GlobalVariables, Tx } from '@aztec/stdlib/tx';
@@ -14,7 +14,7 @@ import type { MeasuredPublicTxSimulatorInterface, PublicTxSimulatorInterface } f
14
14
  */
15
15
  export declare class CppPublicTxSimulatorHintedDbs extends PublicTxSimulator implements PublicTxSimulatorInterface {
16
16
  protected log: Logger;
17
- constructor(merkleTree: MerkleTreeWriteOperations, contractsDB: PublicContractsDB, globalVariables: GlobalVariables, config?: Partial<PublicSimulatorConfig>);
17
+ constructor(merkleTree: MerkleTreeWriteOperations, contractsDB: PublicContractsDB, globalVariables: GlobalVariables, config?: Partial<PublicSimulatorConfig>, bindings?: LoggerBindings);
18
18
  /**
19
19
  * Simulate a transaction's public portion using the C++ vm2 simulator with hinted DBs.
20
20
  *
@@ -36,7 +36,7 @@ export declare class CppPublicTxSimulatorHintedDbs extends PublicTxSimulator imp
36
36
  */
37
37
  export declare class MeasuredCppPublicTxSimulatorHintedDbs extends CppPublicTxSimulatorHintedDbs implements MeasuredPublicTxSimulatorInterface {
38
38
  protected readonly metrics: ExecutorMetricsInterface;
39
- constructor(merkleTree: MerkleTreeWriteOperations, contractsDB: PublicContractsDB, globalVariables: GlobalVariables, metrics: ExecutorMetricsInterface, config?: Partial<PublicSimulatorConfig>);
39
+ constructor(merkleTree: MerkleTreeWriteOperations, contractsDB: PublicContractsDB, globalVariables: GlobalVariables, metrics: ExecutorMetricsInterface, config?: Partial<PublicSimulatorConfig>, bindings?: LoggerBindings);
40
40
  simulate(tx: Tx, txLabel?: string): Promise<PublicTxResult>;
41
41
  }
42
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY3BwX3B1YmxpY190eF9zaW11bGF0b3Jfd2l0aF9oaW50ZWRfZGJzLmQudHMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi9zcmMvcHVibGljL3B1YmxpY190eF9zaW11bGF0b3IvY3BwX3B1YmxpY190eF9zaW11bGF0b3Jfd2l0aF9oaW50ZWRfZGJzLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxLQUFLLE1BQU0sRUFBMEIsTUFBTSx1QkFBdUIsQ0FBQztBQUU1RSxPQUFPLEVBRUwsS0FBSyxxQkFBcUIsRUFDMUIsY0FBYyxFQUVmLE1BQU0sbUJBQW1CLENBQUM7QUFFM0IsT0FBTyxLQUFLLEVBQUUseUJBQXlCLEVBQUUsTUFBTSxxQkFBcUIsQ0FBQztBQUNyRSxPQUFPLEtBQUssRUFBRSxlQUFlLEVBQUUsRUFBRSxFQUFFLE1BQU0sa0JBQWtCLENBQUM7QUFJNUQsT0FBTyxLQUFLLEVBQUUsd0JBQXdCLEVBQUUsTUFBTSxrQ0FBa0MsQ0FBQztBQUNqRixPQUFPLEtBQUssRUFBRSxpQkFBaUIsRUFBRSxNQUFNLHlCQUF5QixDQUFDO0FBQ2pFLE9BQU8sRUFBRSxpQkFBaUIsRUFBRSxNQUFNLDBCQUEwQixDQUFDO0FBQzdELE9BQU8sS0FBSyxFQUNWLGtDQUFrQyxFQUNsQywwQkFBMEIsRUFDM0IsTUFBTSxvQ0FBb0MsQ0FBQztBQUU1Qzs7Ozs7R0FLRztBQUNILHFCQUFhLDZCQUE4QixTQUFRLGlCQUFrQixZQUFXLDBCQUEwQjtJQUN4RyxVQUFtQixHQUFHLEVBQUUsTUFBTSxDQUFDO0lBRS9CLFlBQ0UsVUFBVSxFQUFFLHlCQUF5QixFQUNyQyxXQUFXLEVBQUUsaUJBQWlCLEVBQzlCLGVBQWUsRUFBRSxlQUFlLEVBQ2hDLE1BQU0sQ0FBQyxFQUFFLE9BQU8sQ0FBQyxxQkFBcUIsQ0FBQyxFQUl4QztJQUVEOzs7Ozs7Ozs7T0FTRztJQUNtQixRQUFRLENBQUMsRUFBRSxFQUFFLEVBQUUsR0FBRyxPQUFPLENBQUMsY0FBYyxDQUFDLENBOEM5RDtDQUNGO0FBRUQ7Ozs7OztHQU1HO0FBQ0gscUJBQWEscUNBQ1gsU0FBUSw2QkFDUixZQUFXLGtDQUFrQztJQU0zQyxTQUFTLENBQUMsUUFBUSxDQUFDLE9BQU8sRUFBRSx3QkFBd0I7SUFKdEQsWUFDRSxVQUFVLEVBQUUseUJBQXlCLEVBQ3JDLFdBQVcsRUFBRSxpQkFBaUIsRUFDOUIsZUFBZSxFQUFFLGVBQWUsRUFDYixPQUFPLEVBQUUsd0JBQXdCLEVBQ3BELE1BQU0sQ0FBQyxFQUFFLE9BQU8sQ0FBQyxxQkFBcUIsQ0FBQyxFQUd4QztJQUVxQixRQUFRLENBQUMsRUFBRSxFQUFFLEVBQUUsRUFBRSxPQUFPLEdBQUUsTUFBc0IsR0FBRyxPQUFPLENBQUMsY0FBYyxDQUFDLENBUy9GO0NBQ0YifQ==
42
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY3BwX3B1YmxpY190eF9zaW11bGF0b3Jfd2l0aF9oaW50ZWRfZGJzLmQudHMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi9zcmMvcHVibGljL3B1YmxpY190eF9zaW11bGF0b3IvY3BwX3B1YmxpY190eF9zaW11bGF0b3Jfd2l0aF9oaW50ZWRfZGJzLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxLQUFLLE1BQU0sRUFBRSxLQUFLLGNBQWMsRUFBMEIsTUFBTSx1QkFBdUIsQ0FBQztBQUVqRyxPQUFPLEVBRUwsS0FBSyxxQkFBcUIsRUFDMUIsY0FBYyxFQUVmLE1BQU0sbUJBQW1CLENBQUM7QUFFM0IsT0FBTyxLQUFLLEVBQUUseUJBQXlCLEVBQUUsTUFBTSxxQkFBcUIsQ0FBQztBQUNyRSxPQUFPLEtBQUssRUFBRSxlQUFlLEVBQUUsRUFBRSxFQUFFLE1BQU0sa0JBQWtCLENBQUM7QUFJNUQsT0FBTyxLQUFLLEVBQUUsd0JBQXdCLEVBQUUsTUFBTSxrQ0FBa0MsQ0FBQztBQUNqRixPQUFPLEtBQUssRUFBRSxpQkFBaUIsRUFBRSxNQUFNLHlCQUF5QixDQUFDO0FBQ2pFLE9BQU8sRUFBRSxpQkFBaUIsRUFBRSxNQUFNLDBCQUEwQixDQUFDO0FBQzdELE9BQU8sS0FBSyxFQUNWLGtDQUFrQyxFQUNsQywwQkFBMEIsRUFDM0IsTUFBTSxvQ0FBb0MsQ0FBQztBQUU1Qzs7Ozs7R0FLRztBQUNILHFCQUFhLDZCQUE4QixTQUFRLGlCQUFrQixZQUFXLDBCQUEwQjtJQUN4RyxVQUFtQixHQUFHLEVBQUUsTUFBTSxDQUFDO0lBRS9CLFlBQ0UsVUFBVSxFQUFFLHlCQUF5QixFQUNyQyxXQUFXLEVBQUUsaUJBQWlCLEVBQzlCLGVBQWUsRUFBRSxlQUFlLEVBQ2hDLE1BQU0sQ0FBQyxFQUFFLE9BQU8sQ0FBQyxxQkFBcUIsQ0FBQyxFQUN2QyxRQUFRLENBQUMsRUFBRSxjQUFjLEVBSTFCO0lBRUQ7Ozs7Ozs7OztPQVNHO0lBQ21CLFFBQVEsQ0FBQyxFQUFFLEVBQUUsRUFBRSxHQUFHLE9BQU8sQ0FBQyxjQUFjLENBQUMsQ0E4QzlEO0NBQ0Y7QUFFRDs7Ozs7O0dBTUc7QUFDSCxxQkFBYSxxQ0FDWCxTQUFRLDZCQUNSLFlBQVcsa0NBQWtDO0lBTTNDLFNBQVMsQ0FBQyxRQUFRLENBQUMsT0FBTyxFQUFFLHdCQUF3QjtJQUp0RCxZQUNFLFVBQVUsRUFBRSx5QkFBeUIsRUFDckMsV0FBVyxFQUFFLGlCQUFpQixFQUM5QixlQUFlLEVBQUUsZUFBZSxFQUNiLE9BQU8sRUFBRSx3QkFBd0IsRUFDcEQsTUFBTSxDQUFDLEVBQUUsT0FBTyxDQUFDLHFCQUFxQixDQUFDLEVBQ3ZDLFFBQVEsQ0FBQyxFQUFFLGNBQWMsRUFHMUI7SUFFcUIsUUFBUSxDQUFDLEVBQUUsRUFBRSxFQUFFLEVBQUUsT0FBTyxHQUFFLE1BQXNCLEdBQUcsT0FBTyxDQUFDLGNBQWMsQ0FBQyxDQVMvRjtDQUNGIn0=
@@ -1 +1 @@
1
- {"version":3,"file":"cpp_public_tx_simulator_with_hinted_dbs.d.ts","sourceRoot":"","sources":["../../../src/public/public_tx_simulator/cpp_public_tx_simulator_with_hinted_dbs.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,KAAK,MAAM,EAA0B,MAAM,uBAAuB,CAAC;AAE5E,OAAO,EAEL,KAAK,qBAAqB,EAC1B,cAAc,EAEf,MAAM,mBAAmB,CAAC;AAE3B,OAAO,KAAK,EAAE,yBAAyB,EAAE,MAAM,qBAAqB,CAAC;AACrE,OAAO,KAAK,EAAE,eAAe,EAAE,EAAE,EAAE,MAAM,kBAAkB,CAAC;AAI5D,OAAO,KAAK,EAAE,wBAAwB,EAAE,MAAM,kCAAkC,CAAC;AACjF,OAAO,KAAK,EAAE,iBAAiB,EAAE,MAAM,yBAAyB,CAAC;AACjE,OAAO,EAAE,iBAAiB,EAAE,MAAM,0BAA0B,CAAC;AAC7D,OAAO,KAAK,EACV,kCAAkC,EAClC,0BAA0B,EAC3B,MAAM,oCAAoC,CAAC;AAE5C;;;;;GAKG;AACH,qBAAa,6BAA8B,SAAQ,iBAAkB,YAAW,0BAA0B;IACxG,UAAmB,GAAG,EAAE,MAAM,CAAC;IAE/B,YACE,UAAU,EAAE,yBAAyB,EACrC,WAAW,EAAE,iBAAiB,EAC9B,eAAe,EAAE,eAAe,EAChC,MAAM,CAAC,EAAE,OAAO,CAAC,qBAAqB,CAAC,EAIxC;IAED;;;;;;;;;OASG;IACmB,QAAQ,CAAC,EAAE,EAAE,EAAE,GAAG,OAAO,CAAC,cAAc,CAAC,CA8C9D;CACF;AAED;;;;;;GAMG;AACH,qBAAa,qCACX,SAAQ,6BACR,YAAW,kCAAkC;IAM3C,SAAS,CAAC,QAAQ,CAAC,OAAO,EAAE,wBAAwB;IAJtD,YACE,UAAU,EAAE,yBAAyB,EACrC,WAAW,EAAE,iBAAiB,EAC9B,eAAe,EAAE,eAAe,EACb,OAAO,EAAE,wBAAwB,EACpD,MAAM,CAAC,EAAE,OAAO,CAAC,qBAAqB,CAAC,EAGxC;IAEqB,QAAQ,CAAC,EAAE,EAAE,EAAE,EAAE,OAAO,GAAE,MAAsB,GAAG,OAAO,CAAC,cAAc,CAAC,CAS/F;CACF"}
1
+ {"version":3,"file":"cpp_public_tx_simulator_with_hinted_dbs.d.ts","sourceRoot":"","sources":["../../../src/public/public_tx_simulator/cpp_public_tx_simulator_with_hinted_dbs.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,KAAK,MAAM,EAAE,KAAK,cAAc,EAA0B,MAAM,uBAAuB,CAAC;AAEjG,OAAO,EAEL,KAAK,qBAAqB,EAC1B,cAAc,EAEf,MAAM,mBAAmB,CAAC;AAE3B,OAAO,KAAK,EAAE,yBAAyB,EAAE,MAAM,qBAAqB,CAAC;AACrE,OAAO,KAAK,EAAE,eAAe,EAAE,EAAE,EAAE,MAAM,kBAAkB,CAAC;AAI5D,OAAO,KAAK,EAAE,wBAAwB,EAAE,MAAM,kCAAkC,CAAC;AACjF,OAAO,KAAK,EAAE,iBAAiB,EAAE,MAAM,yBAAyB,CAAC;AACjE,OAAO,EAAE,iBAAiB,EAAE,MAAM,0BAA0B,CAAC;AAC7D,OAAO,KAAK,EACV,kCAAkC,EAClC,0BAA0B,EAC3B,MAAM,oCAAoC,CAAC;AAE5C;;;;;GAKG;AACH,qBAAa,6BAA8B,SAAQ,iBAAkB,YAAW,0BAA0B;IACxG,UAAmB,GAAG,EAAE,MAAM,CAAC;IAE/B,YACE,UAAU,EAAE,yBAAyB,EACrC,WAAW,EAAE,iBAAiB,EAC9B,eAAe,EAAE,eAAe,EAChC,MAAM,CAAC,EAAE,OAAO,CAAC,qBAAqB,CAAC,EACvC,QAAQ,CAAC,EAAE,cAAc,EAI1B;IAED;;;;;;;;;OASG;IACmB,QAAQ,CAAC,EAAE,EAAE,EAAE,GAAG,OAAO,CAAC,cAAc,CAAC,CA8C9D;CACF;AAED;;;;;;GAMG;AACH,qBAAa,qCACX,SAAQ,6BACR,YAAW,kCAAkC;IAM3C,SAAS,CAAC,QAAQ,CAAC,OAAO,EAAE,wBAAwB;IAJtD,YACE,UAAU,EAAE,yBAAyB,EACrC,WAAW,EAAE,iBAAiB,EAC9B,eAAe,EAAE,eAAe,EACb,OAAO,EAAE,wBAAwB,EACpD,MAAM,CAAC,EAAE,OAAO,CAAC,qBAAqB,CAAC,EACvC,QAAQ,CAAC,EAAE,cAAc,EAG1B;IAEqB,QAAQ,CAAC,EAAE,EAAE,EAAE,EAAE,OAAO,GAAE,MAAsB,GAAG,OAAO,CAAC,cAAc,CAAC,CAS/F;CACF"}
@@ -11,9 +11,9 @@ import { PublicTxSimulator } from './public_tx_simulator.js';
11
11
  * to C++ to run hinted simulation.
12
12
  */ export class CppPublicTxSimulatorHintedDbs extends PublicTxSimulator {
13
13
  log;
14
- constructor(merkleTree, contractsDB, globalVariables, config){
15
- super(merkleTree, contractsDB, globalVariables, config);
16
- this.log = createLogger(`simulator:cpp_public_tx_simulator_hinted_dbs`);
14
+ constructor(merkleTree, contractsDB, globalVariables, config, bindings){
15
+ super(merkleTree, contractsDB, globalVariables, config, undefined, bindings);
16
+ this.log = createLogger(`simulator:cpp_public_tx_simulator_hinted_dbs`, bindings);
17
17
  }
18
18
  /**
19
19
  * Simulate a transaction's public portion using the C++ vm2 simulator with hinted DBs.
@@ -70,8 +70,8 @@ import { PublicTxSimulator } from './public_tx_simulator.js';
70
70
  * to TS for tracking.
71
71
  */ export class MeasuredCppPublicTxSimulatorHintedDbs extends CppPublicTxSimulatorHintedDbs {
72
72
  metrics;
73
- constructor(merkleTree, contractsDB, globalVariables, metrics, config){
74
- super(merkleTree, contractsDB, globalVariables, config), this.metrics = metrics;
73
+ constructor(merkleTree, contractsDB, globalVariables, metrics, config, bindings){
74
+ super(merkleTree, contractsDB, globalVariables, config, bindings), this.metrics = metrics;
75
75
  }
76
76
  async simulate(tx, txLabel = 'unlabeledTx') {
77
77
  this.metrics.startRecordingTxSimulation(txLabel);
@@ -1,4 +1,4 @@
1
- import { type Logger } from '@aztec/foundation/log';
1
+ import { type Logger, type LoggerBindings } from '@aztec/foundation/log';
2
2
  import { type PublicSimulatorConfig, PublicTxResult } from '@aztec/stdlib/avm';
3
3
  import type { MerkleTreeWriteOperations } from '@aztec/stdlib/trees';
4
4
  import type { GlobalVariables, Tx } from '@aztec/stdlib/tx';
@@ -13,7 +13,7 @@ import type { MeasuredPublicTxSimulatorInterface, PublicTxSimulatorInterface } f
13
13
  */
14
14
  export declare class CppVsTsPublicTxSimulator extends PublicTxSimulator implements PublicTxSimulatorInterface {
15
15
  protected log: Logger;
16
- constructor(merkleTree: MerkleTreeWriteOperations, contractsDB: PublicContractsDB, globalVariables: GlobalVariables, config?: Partial<PublicSimulatorConfig>);
16
+ constructor(merkleTree: MerkleTreeWriteOperations, contractsDB: PublicContractsDB, globalVariables: GlobalVariables, config?: Partial<PublicSimulatorConfig>, bindings?: LoggerBindings);
17
17
  /**
18
18
  * Simulate a transaction's public portion using the C++ avvm simulator.
19
19
  *
@@ -24,7 +24,7 @@ export declare class CppVsTsPublicTxSimulator extends PublicTxSimulator implemen
24
24
  }
25
25
  export declare class MeasuredCppVsTsPublicTxSimulator extends CppVsTsPublicTxSimulator implements MeasuredPublicTxSimulatorInterface {
26
26
  protected readonly metrics: ExecutorMetricsInterface;
27
- constructor(merkleTree: MerkleTreeWriteOperations, contractsDB: PublicContractsDB, globalVariables: GlobalVariables, metrics: ExecutorMetricsInterface, config?: Partial<PublicSimulatorConfig>);
27
+ constructor(merkleTree: MerkleTreeWriteOperations, contractsDB: PublicContractsDB, globalVariables: GlobalVariables, metrics: ExecutorMetricsInterface, config?: Partial<PublicSimulatorConfig>, bindings?: LoggerBindings);
28
28
  simulate(tx: Tx, txLabel?: string): Promise<PublicTxResult>;
29
29
  }
30
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY3BwX3ZzX3RzX3B1YmxpY190eF9zaW11bGF0b3IuZC50cyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9wdWJsaWMvcHVibGljX3R4X3NpbXVsYXRvci9jcHBfdnNfdHNfcHVibGljX3R4X3NpbXVsYXRvci50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsS0FBSyxNQUFNLEVBQTBCLE1BQU0sdUJBQXVCLENBQUM7QUFJNUUsT0FBTyxFQUdMLEtBQUsscUJBQXFCLEVBQzFCLGNBQWMsRUFFZixNQUFNLG1CQUFtQixDQUFDO0FBRTNCLE9BQU8sS0FBSyxFQUFFLHlCQUF5QixFQUFFLE1BQU0scUJBQXFCLENBQUM7QUFDckUsT0FBTyxLQUFLLEVBQUUsZUFBZSxFQUFrQixFQUFFLEVBQUUsTUFBTSxrQkFBa0IsQ0FBQztBQUs1RSxPQUFPLEtBQUssRUFBRSx3QkFBd0IsRUFBRSxNQUFNLGtDQUFrQyxDQUFDO0FBQ2pGLE9BQU8sS0FBSyxFQUFFLGlCQUFpQixFQUFFLE1BQU0seUJBQXlCLENBQUM7QUFFakUsT0FBTyxFQUFFLGlCQUFpQixFQUFFLE1BQU0sMEJBQTBCLENBQUM7QUFDN0QsT0FBTyxLQUFLLEVBQ1Ysa0NBQWtDLEVBQ2xDLDBCQUEwQixFQUMzQixNQUFNLG9DQUFvQyxDQUFDO0FBRTVDOzs7O0dBSUc7QUFDSCxxQkFBYSx3QkFBeUIsU0FBUSxpQkFBa0IsWUFBVywwQkFBMEI7SUFDbkcsVUFBbUIsR0FBRyxFQUFFLE1BQU0sQ0FBQztJQUUvQixZQUNFLFVBQVUsRUFBRSx5QkFBeUIsRUFDckMsV0FBVyxFQUFFLGlCQUFpQixFQUM5QixlQUFlLEVBQUUsZUFBZSxFQUNoQyxNQUFNLENBQUMsRUFBRSxPQUFPLENBQUMscUJBQXFCLENBQUMsRUFJeEM7SUFFRDs7Ozs7T0FLRztJQUNtQixRQUFRLENBQUMsRUFBRSxFQUFFLEVBQUUsR0FBRyxPQUFPLENBQUMsY0FBYyxDQUFDLENBaUs5RDtDQUNGO0FBRUQscUJBQWEsZ0NBQ1gsU0FBUSx3QkFDUixZQUFXLGtDQUFrQztJQU0zQyxTQUFTLENBQUMsUUFBUSxDQUFDLE9BQU8sRUFBRSx3QkFBd0I7SUFKdEQsWUFDRSxVQUFVLEVBQUUseUJBQXlCLEVBQ3JDLFdBQVcsRUFBRSxpQkFBaUIsRUFDOUIsZUFBZSxFQUFFLGVBQWUsRUFDYixPQUFPLEVBQUUsd0JBQXdCLEVBQ3BELE1BQU0sQ0FBQyxFQUFFLE9BQU8sQ0FBQyxxQkFBcUIsQ0FBQyxFQUd4QztJQUVxQixRQUFRLENBQUMsRUFBRSxFQUFFLEVBQUUsRUFBRSxPQUFPLEdBQUUsTUFBc0IsR0FBRyxPQUFPLENBQUMsY0FBYyxDQUFDLENBUy9GO0NBQ0YifQ==
30
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY3BwX3ZzX3RzX3B1YmxpY190eF9zaW11bGF0b3IuZC50cyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9wdWJsaWMvcHVibGljX3R4X3NpbXVsYXRvci9jcHBfdnNfdHNfcHVibGljX3R4X3NpbXVsYXRvci50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsS0FBSyxNQUFNLEVBQUUsS0FBSyxjQUFjLEVBQTBCLE1BQU0sdUJBQXVCLENBQUM7QUFHakcsT0FBTyxFQUdMLEtBQUsscUJBQXFCLEVBQzFCLGNBQWMsRUFFZixNQUFNLG1CQUFtQixDQUFDO0FBRTNCLE9BQU8sS0FBSyxFQUFFLHlCQUF5QixFQUFFLE1BQU0scUJBQXFCLENBQUM7QUFDckUsT0FBTyxLQUFLLEVBQUUsZUFBZSxFQUFrQixFQUFFLEVBQUUsTUFBTSxrQkFBa0IsQ0FBQztBQUs1RSxPQUFPLEtBQUssRUFBRSx3QkFBd0IsRUFBRSxNQUFNLGtDQUFrQyxDQUFDO0FBQ2pGLE9BQU8sS0FBSyxFQUFFLGlCQUFpQixFQUFFLE1BQU0seUJBQXlCLENBQUM7QUFFakUsT0FBTyxFQUFFLGlCQUFpQixFQUFFLE1BQU0sMEJBQTBCLENBQUM7QUFDN0QsT0FBTyxLQUFLLEVBQ1Ysa0NBQWtDLEVBQ2xDLDBCQUEwQixFQUMzQixNQUFNLG9DQUFvQyxDQUFDO0FBRTVDOzs7O0dBSUc7QUFDSCxxQkFBYSx3QkFBeUIsU0FBUSxpQkFBa0IsWUFBVywwQkFBMEI7SUFDbkcsVUFBbUIsR0FBRyxFQUFFLE1BQU0sQ0FBQztJQUUvQixZQUNFLFVBQVUsRUFBRSx5QkFBeUIsRUFDckMsV0FBVyxFQUFFLGlCQUFpQixFQUM5QixlQUFlLEVBQUUsZUFBZSxFQUNoQyxNQUFNLENBQUMsRUFBRSxPQUFPLENBQUMscUJBQXFCLENBQUMsRUFDdkMsUUFBUSxDQUFDLEVBQUUsY0FBYyxFQUkxQjtJQUVEOzs7OztPQUtHO0lBQ21CLFFBQVEsQ0FBQyxFQUFFLEVBQUUsRUFBRSxHQUFHLE9BQU8sQ0FBQyxjQUFjLENBQUMsQ0ErSjlEO0NBQ0Y7QUFFRCxxQkFBYSxnQ0FDWCxTQUFRLHdCQUNSLFlBQVcsa0NBQWtDO0lBTTNDLFNBQVMsQ0FBQyxRQUFRLENBQUMsT0FBTyxFQUFFLHdCQUF3QjtJQUp0RCxZQUNFLFVBQVUsRUFBRSx5QkFBeUIsRUFDckMsV0FBVyxFQUFFLGlCQUFpQixFQUM5QixlQUFlLEVBQUUsZUFBZSxFQUNiLE9BQU8sRUFBRSx3QkFBd0IsRUFDcEQsTUFBTSxDQUFDLEVBQUUsT0FBTyxDQUFDLHFCQUFxQixDQUFDLEVBQ3ZDLFFBQVEsQ0FBQyxFQUFFLGNBQWMsRUFHMUI7SUFFcUIsUUFBUSxDQUFDLEVBQUUsRUFBRSxFQUFFLEVBQUUsT0FBTyxHQUFFLE1BQXNCLEdBQUcsT0FBTyxDQUFDLGNBQWMsQ0FBQyxDQVMvRjtDQUNGIn0=
@@ -1 +1 @@
1
- {"version":3,"file":"cpp_vs_ts_public_tx_simulator.d.ts","sourceRoot":"","sources":["../../../src/public/public_tx_simulator/cpp_vs_ts_public_tx_simulator.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,KAAK,MAAM,EAA0B,MAAM,uBAAuB,CAAC;AAI5E,OAAO,EAGL,KAAK,qBAAqB,EAC1B,cAAc,EAEf,MAAM,mBAAmB,CAAC;AAE3B,OAAO,KAAK,EAAE,yBAAyB,EAAE,MAAM,qBAAqB,CAAC;AACrE,OAAO,KAAK,EAAE,eAAe,EAAkB,EAAE,EAAE,MAAM,kBAAkB,CAAC;AAK5E,OAAO,KAAK,EAAE,wBAAwB,EAAE,MAAM,kCAAkC,CAAC;AACjF,OAAO,KAAK,EAAE,iBAAiB,EAAE,MAAM,yBAAyB,CAAC;AAEjE,OAAO,EAAE,iBAAiB,EAAE,MAAM,0BAA0B,CAAC;AAC7D,OAAO,KAAK,EACV,kCAAkC,EAClC,0BAA0B,EAC3B,MAAM,oCAAoC,CAAC;AAE5C;;;;GAIG;AACH,qBAAa,wBAAyB,SAAQ,iBAAkB,YAAW,0BAA0B;IACnG,UAAmB,GAAG,EAAE,MAAM,CAAC;IAE/B,YACE,UAAU,EAAE,yBAAyB,EACrC,WAAW,EAAE,iBAAiB,EAC9B,eAAe,EAAE,eAAe,EAChC,MAAM,CAAC,EAAE,OAAO,CAAC,qBAAqB,CAAC,EAIxC;IAED;;;;;OAKG;IACmB,QAAQ,CAAC,EAAE,EAAE,EAAE,GAAG,OAAO,CAAC,cAAc,CAAC,CAiK9D;CACF;AAED,qBAAa,gCACX,SAAQ,wBACR,YAAW,kCAAkC;IAM3C,SAAS,CAAC,QAAQ,CAAC,OAAO,EAAE,wBAAwB;IAJtD,YACE,UAAU,EAAE,yBAAyB,EACrC,WAAW,EAAE,iBAAiB,EAC9B,eAAe,EAAE,eAAe,EACb,OAAO,EAAE,wBAAwB,EACpD,MAAM,CAAC,EAAE,OAAO,CAAC,qBAAqB,CAAC,EAGxC;IAEqB,QAAQ,CAAC,EAAE,EAAE,EAAE,EAAE,OAAO,GAAE,MAAsB,GAAG,OAAO,CAAC,cAAc,CAAC,CAS/F;CACF"}
1
+ {"version":3,"file":"cpp_vs_ts_public_tx_simulator.d.ts","sourceRoot":"","sources":["../../../src/public/public_tx_simulator/cpp_vs_ts_public_tx_simulator.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,KAAK,MAAM,EAAE,KAAK,cAAc,EAA0B,MAAM,uBAAuB,CAAC;AAGjG,OAAO,EAGL,KAAK,qBAAqB,EAC1B,cAAc,EAEf,MAAM,mBAAmB,CAAC;AAE3B,OAAO,KAAK,EAAE,yBAAyB,EAAE,MAAM,qBAAqB,CAAC;AACrE,OAAO,KAAK,EAAE,eAAe,EAAkB,EAAE,EAAE,MAAM,kBAAkB,CAAC;AAK5E,OAAO,KAAK,EAAE,wBAAwB,EAAE,MAAM,kCAAkC,CAAC;AACjF,OAAO,KAAK,EAAE,iBAAiB,EAAE,MAAM,yBAAyB,CAAC;AAEjE,OAAO,EAAE,iBAAiB,EAAE,MAAM,0BAA0B,CAAC;AAC7D,OAAO,KAAK,EACV,kCAAkC,EAClC,0BAA0B,EAC3B,MAAM,oCAAoC,CAAC;AAE5C;;;;GAIG;AACH,qBAAa,wBAAyB,SAAQ,iBAAkB,YAAW,0BAA0B;IACnG,UAAmB,GAAG,EAAE,MAAM,CAAC;IAE/B,YACE,UAAU,EAAE,yBAAyB,EACrC,WAAW,EAAE,iBAAiB,EAC9B,eAAe,EAAE,eAAe,EAChC,MAAM,CAAC,EAAE,OAAO,CAAC,qBAAqB,CAAC,EACvC,QAAQ,CAAC,EAAE,cAAc,EAI1B;IAED;;;;;OAKG;IACmB,QAAQ,CAAC,EAAE,EAAE,EAAE,GAAG,OAAO,CAAC,cAAc,CAAC,CA+J9D;CACF;AAED,qBAAa,gCACX,SAAQ,wBACR,YAAW,kCAAkC;IAM3C,SAAS,CAAC,QAAQ,CAAC,OAAO,EAAE,wBAAwB;IAJtD,YACE,UAAU,EAAE,yBAAyB,EACrC,WAAW,EAAE,iBAAiB,EAC9B,eAAe,EAAE,eAAe,EACb,OAAO,EAAE,wBAAwB,EACpD,MAAM,CAAC,EAAE,OAAO,CAAC,qBAAqB,CAAC,EACvC,QAAQ,CAAC,EAAE,cAAc,EAG1B;IAEqB,QAAQ,CAAC,EAAE,EAAE,EAAE,EAAE,OAAO,GAAE,MAAsB,GAAG,OAAO,CAAC,cAAc,CAAC,CAS/F;CACF"}
@@ -1,5 +1,4 @@
1
1
  import { createLogger, logLevel } from '@aztec/foundation/log';
2
- import { writeTestData } from '@aztec/foundation/testing/files';
3
2
  import { avmSimulate } from '@aztec/native';
4
3
  import { ProtocolContractsList } from '@aztec/protocol-contracts';
5
4
  import { AvmFastSimulationInputs, AvmTxHint, PublicTxResult, deserializeFromMessagePack } from '@aztec/stdlib/avm';
@@ -14,9 +13,9 @@ import { PublicTxSimulator } from './public_tx_simulator.js';
14
13
  * For contract DB accesses, it makes callbacks through NAPI back to the TS PublicContractsDB cache.
15
14
  */ export class CppVsTsPublicTxSimulator extends PublicTxSimulator {
16
15
  log;
17
- constructor(merkleTree, contractsDB, globalVariables, config){
18
- super(merkleTree, contractsDB, globalVariables, config);
19
- this.log = createLogger(`simulator:cpp_public_tx_simulator`);
16
+ constructor(merkleTree, contractsDB, globalVariables, config, bindings){
17
+ super(merkleTree, contractsDB, globalVariables, config, undefined, bindings);
18
+ this.log = createLogger(`simulator:cpp_vs_public_tx_simulator`, bindings);
20
19
  }
21
20
  /**
22
21
  * Simulate a transaction's public portion using the C++ avvm simulator.
@@ -61,7 +60,7 @@ import { PublicTxSimulator } from './public_tx_simulator.js';
61
60
  const protocolContracts = ProtocolContractsList;
62
61
  const fastSimInputs = new AvmFastSimulationInputs(wsRevision, this.config, txHint, this.globalVariables, protocolContracts);
63
62
  // Create contract provider for callbacks to TypeScript PublicContractsDB from C++
64
- const contractProvider = new ContractProviderForCpp(this.contractsDB, this.globalVariables);
63
+ const contractProvider = new ContractProviderForCpp(this.contractsDB, this.globalVariables, this.bindings);
65
64
  // Serialize to msgpack and call the C++ simulator
66
65
  this.log.debug(`Serializing fast simulation inputs to msgpack...`);
67
66
  const inputBuffer = fastSimInputs.serializeWithMessagePack();
@@ -79,8 +78,6 @@ import { PublicTxSimulator } from './public_tx_simulator.js';
79
78
  // Deserialize the msgpack result
80
79
  this.log.debug(`Deserializing C++ from buffer (size: ${resultBuffer.length})...`);
81
80
  const cppResultJSON = deserializeFromMessagePack(resultBuffer);
82
- // Write testdata if AZTEC_WRITE_TESTDATA=1.
83
- writeTestData(`barretenberg/cpp/src/barretenberg/vm2/testing/tx_result_${txHash}.testdata.bin`, resultBuffer, /*raw=*/ true);
84
81
  this.log.debug(`Deserializing C++ result to PublicTxResult...`);
85
82
  const cppResult = PublicTxResult.fromPlainObject(cppResultJSON);
86
83
  this.log.debug(`Done.`);
@@ -89,7 +86,10 @@ import { PublicTxSimulator } from './public_tx_simulator.js';
89
86
  assert(cppResult.gasUsed.publicGas.equals(tsResult.gasUsed.publicGas));
90
87
  assert(cppResult.gasUsed.teardownGas.equals(tsResult.gasUsed.teardownGas));
91
88
  assert(cppResult.gasUsed.billedGas.equals(tsResult.gasUsed.billedGas));
92
- assert(cppResult.publicInputs.toBuffer().equals(tsResult.publicInputs.toBuffer()));
89
+ assert(cppResult.publicTxEffect.equals(tsResult.publicTxEffect));
90
+ if (cppResult.publicInputs !== undefined) {
91
+ assert(cppResult.publicInputs.toBuffer().equals(tsResult.publicInputs.toBuffer()));
92
+ }
93
93
  // TODO(fcarreiro): complete this.
94
94
  // Check that C++ hints are a strict subset of TS hints.
95
95
  // Then enable for misc tests and validate hints.
@@ -149,13 +149,14 @@ import { PublicTxSimulator } from './public_tx_simulator.js';
149
149
  reverted: !cppResult.revertCode.isOK(),
150
150
  cppGasUsed: cppResult.gasUsed.totalGas.l2Gas
151
151
  });
152
- return tsResult;
152
+ // Return cpp result as it has more detailed metadata / revert reasons
153
+ return cppResult;
153
154
  }
154
155
  }
155
156
  export class MeasuredCppVsTsPublicTxSimulator extends CppVsTsPublicTxSimulator {
156
157
  metrics;
157
- constructor(merkleTree, contractsDB, globalVariables, metrics, config){
158
- super(merkleTree, contractsDB, globalVariables, config), this.metrics = metrics;
158
+ constructor(merkleTree, contractsDB, globalVariables, metrics, config, bindings){
159
+ super(merkleTree, contractsDB, globalVariables, config, bindings), this.metrics = metrics;
159
160
  }
160
161
  async simulate(tx, txLabel = 'unlabeledTx') {
161
162
  this.metrics.startRecordingTxSimulation(txLabel);