@aztec/simulator 0.0.1-commit.9b94fc1 → 0.0.1-commit.b468ad8

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 (323) 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 +11 -9
  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 +8 -2
  54. package/dest/public/avm/errors.d.ts.map +1 -1
  55. package/dest/public/avm/errors.js +14 -2
  56. package/dest/public/avm/fixtures/avm_simulation_tester.d.ts +1 -1
  57. package/dest/public/avm/fixtures/avm_simulation_tester.d.ts.map +1 -1
  58. package/dest/public/avm/fixtures/avm_simulation_tester.js +4 -3
  59. package/dest/public/avm/fixtures/base_avm_simulation_tester.d.ts +2 -2
  60. package/dest/public/avm/fixtures/base_avm_simulation_tester.d.ts.map +1 -1
  61. package/dest/public/avm/fixtures/base_avm_simulation_tester.js +1 -1
  62. package/dest/public/avm/fixtures/initializers.d.ts +2 -2
  63. package/dest/public/avm/fixtures/initializers.d.ts.map +1 -1
  64. package/dest/public/avm/fixtures/initializers.js +5 -4
  65. package/dest/public/avm/fixtures/utils.d.ts +4 -3
  66. package/dest/public/avm/fixtures/utils.d.ts.map +1 -1
  67. package/dest/public/avm/fixtures/utils.js +3 -2
  68. package/dest/public/avm/opcodes/accrued_substate.d.ts +16 -17
  69. package/dest/public/avm/opcodes/accrued_substate.d.ts.map +1 -1
  70. package/dest/public/avm/opcodes/accrued_substate.js +39 -39
  71. package/dest/public/avm/opcodes/addressing_mode.js +2 -2
  72. package/dest/public/avm/opcodes/arithmetic.d.ts +10 -8
  73. package/dest/public/avm/opcodes/arithmetic.d.ts.map +1 -1
  74. package/dest/public/avm/opcodes/arithmetic.js +12 -2
  75. package/dest/public/avm/opcodes/bitwise.d.ts +7 -7
  76. package/dest/public/avm/opcodes/bitwise.d.ts.map +1 -1
  77. package/dest/public/avm/opcodes/bitwise.js +5 -5
  78. package/dest/public/avm/opcodes/comparators.d.ts +4 -4
  79. package/dest/public/avm/opcodes/comparators.d.ts.map +1 -1
  80. package/dest/public/avm/opcodes/comparators.js +1 -1
  81. package/dest/public/avm/opcodes/contract.d.ts +3 -3
  82. package/dest/public/avm/opcodes/contract.d.ts.map +1 -1
  83. package/dest/public/avm/opcodes/contract.js +8 -8
  84. package/dest/public/avm/opcodes/control_flow.d.ts +3 -3
  85. package/dest/public/avm/opcodes/control_flow.d.ts.map +1 -1
  86. package/dest/public/avm/opcodes/control_flow.js +4 -4
  87. package/dest/public/avm/opcodes/conversion.d.ts +3 -3
  88. package/dest/public/avm/opcodes/conversion.d.ts.map +1 -1
  89. package/dest/public/avm/opcodes/conversion.js +4 -4
  90. package/dest/public/avm/opcodes/ec_add.d.ts +4 -4
  91. package/dest/public/avm/opcodes/ec_add.d.ts.map +1 -1
  92. package/dest/public/avm/opcodes/ec_add.js +17 -8
  93. package/dest/public/avm/opcodes/environment_getters.d.ts +5 -5
  94. package/dest/public/avm/opcodes/environment_getters.d.ts.map +1 -1
  95. package/dest/public/avm/opcodes/environment_getters.js +6 -6
  96. package/dest/public/avm/opcodes/external_calls.d.ts +9 -9
  97. package/dest/public/avm/opcodes/external_calls.d.ts.map +1 -1
  98. package/dest/public/avm/opcodes/external_calls.js +23 -22
  99. package/dest/public/avm/opcodes/hashing.d.ts +8 -8
  100. package/dest/public/avm/opcodes/hashing.d.ts.map +1 -1
  101. package/dest/public/avm/opcodes/hashing.js +21 -16
  102. package/dest/public/avm/opcodes/instruction_impl.d.ts +4 -4
  103. package/dest/public/avm/opcodes/instruction_impl.d.ts.map +1 -1
  104. package/dest/public/avm/opcodes/instruction_impl.js +4 -4
  105. package/dest/public/avm/opcodes/memory.d.ts +14 -14
  106. package/dest/public/avm/opcodes/memory.d.ts.map +1 -1
  107. package/dest/public/avm/opcodes/memory.js +26 -26
  108. package/dest/public/avm/opcodes/misc.d.ts +3 -3
  109. package/dest/public/avm/opcodes/misc.d.ts.map +1 -1
  110. package/dest/public/avm/opcodes/misc.js +6 -6
  111. package/dest/public/avm/opcodes/storage.d.ts +16 -15
  112. package/dest/public/avm/opcodes/storage.d.ts.map +1 -1
  113. package/dest/public/avm/opcodes/storage.js +34 -24
  114. package/dest/public/avm/revert_reason.d.ts +2 -2
  115. package/dest/public/avm/revert_reason.d.ts.map +1 -1
  116. package/dest/public/avm/revert_reason.js +3 -2
  117. package/dest/public/avm/serialization/bytecode_serialization.d.ts +1 -1
  118. package/dest/public/avm/serialization/bytecode_serialization.d.ts.map +1 -1
  119. package/dest/public/avm/serialization/bytecode_serialization.js +9 -6
  120. package/dest/public/avm/serialization/instruction_serialization.js +1 -1
  121. package/dest/public/avm/test_utils.d.ts +2 -2
  122. package/dest/public/avm/test_utils.d.ts.map +1 -1
  123. package/dest/public/avm/test_utils.js +1 -1
  124. package/dest/public/contracts_db_checkpoint.d.ts +2 -2
  125. package/dest/public/contracts_db_checkpoint.d.ts.map +1 -1
  126. package/dest/public/db_interfaces.d.ts +2 -2
  127. package/dest/public/db_interfaces.d.ts.map +1 -1
  128. package/dest/public/debug_fn_name.d.ts +16 -3
  129. package/dest/public/debug_fn_name.d.ts.map +1 -1
  130. package/dest/public/debug_fn_name.js +31 -3
  131. package/dest/public/executor_metrics.d.ts +1 -1
  132. package/dest/public/executor_metrics.d.ts.map +1 -1
  133. package/dest/public/executor_metrics.js +12 -33
  134. package/dest/public/fixtures/amm_test.js +2 -2
  135. package/dest/public/fixtures/bulk_test.d.ts +3 -3
  136. package/dest/public/fixtures/bulk_test.d.ts.map +1 -1
  137. package/dest/public/fixtures/bulk_test.js +5 -69
  138. package/dest/public/fixtures/custom_bytecode_tester.d.ts +28 -6
  139. package/dest/public/fixtures/custom_bytecode_tester.d.ts.map +1 -1
  140. package/dest/public/fixtures/custom_bytecode_tester.js +36 -12
  141. package/dest/public/fixtures/custom_bytecode_tests.d.ts +11 -8
  142. package/dest/public/fixtures/custom_bytecode_tests.d.ts.map +1 -1
  143. package/dest/public/fixtures/custom_bytecode_tests.js +83 -18
  144. package/dest/public/fixtures/index.d.ts +4 -2
  145. package/dest/public/fixtures/index.d.ts.map +1 -1
  146. package/dest/public/fixtures/index.js +3 -1
  147. package/dest/public/fixtures/minimal_public_tx.d.ts +2 -7
  148. package/dest/public/fixtures/minimal_public_tx.d.ts.map +1 -1
  149. package/dest/public/fixtures/minimal_public_tx.js +4 -14
  150. package/dest/public/fixtures/opcode_spammer.d.ts +122 -0
  151. package/dest/public/fixtures/opcode_spammer.d.ts.map +1 -0
  152. package/dest/public/fixtures/opcode_spammer.js +1653 -0
  153. package/dest/public/fixtures/public_tx_simulation_tester.d.ts +22 -3
  154. package/dest/public/fixtures/public_tx_simulation_tester.d.ts.map +1 -1
  155. package/dest/public/fixtures/public_tx_simulation_tester.js +50 -13
  156. package/dest/public/fixtures/simple_contract_data_source.d.ts +5 -4
  157. package/dest/public/fixtures/simple_contract_data_source.d.ts.map +1 -1
  158. package/dest/public/fixtures/simple_contract_data_source.js +4 -4
  159. package/dest/public/fixtures/token_test.d.ts +6 -2
  160. package/dest/public/fixtures/token_test.d.ts.map +1 -1
  161. package/dest/public/fixtures/token_test.js +13 -11
  162. package/dest/public/fixtures/utils.d.ts +2 -2
  163. package/dest/public/fixtures/utils.d.ts.map +1 -1
  164. package/dest/public/fixtures/utils.js +4 -3
  165. package/dest/public/fuzzing/avm_fuzzer_simulator.d.ts +60 -0
  166. package/dest/public/fuzzing/avm_fuzzer_simulator.d.ts.map +1 -0
  167. package/dest/public/fuzzing/avm_fuzzer_simulator.js +171 -0
  168. package/dest/public/fuzzing/avm_simulator_bin.d.ts +2 -0
  169. package/dest/public/fuzzing/avm_simulator_bin.d.ts.map +1 -0
  170. package/dest/public/fuzzing/avm_simulator_bin.js +118 -0
  171. package/dest/public/hinting_db_sources.d.ts +5 -3
  172. package/dest/public/hinting_db_sources.d.ts.map +1 -1
  173. package/dest/public/hinting_db_sources.js +7 -2
  174. package/dest/public/index.d.ts +2 -2
  175. package/dest/public/index.d.ts.map +1 -1
  176. package/dest/public/index.js +1 -1
  177. package/dest/public/public_db_sources.d.ts +5 -4
  178. package/dest/public/public_db_sources.d.ts.map +1 -1
  179. package/dest/public/public_db_sources.js +5 -5
  180. package/dest/public/public_processor/guarded_merkle_tree.d.ts +4 -2
  181. package/dest/public/public_processor/guarded_merkle_tree.d.ts.map +1 -1
  182. package/dest/public/public_processor/guarded_merkle_tree.js +5 -0
  183. package/dest/public/public_processor/public_processor.d.ts +9 -7
  184. package/dest/public/public_processor/public_processor.d.ts.map +1 -1
  185. package/dest/public/public_processor/public_processor.js +444 -47
  186. package/dest/public/public_processor/public_processor_metrics.d.ts +2 -2
  187. package/dest/public/public_processor/public_processor_metrics.d.ts.map +1 -1
  188. package/dest/public/public_processor/public_processor_metrics.js +28 -45
  189. package/dest/public/public_tx_simulator/contract_provider_for_cpp.d.ts +3 -14
  190. package/dest/public/public_tx_simulator/contract_provider_for_cpp.d.ts.map +1 -1
  191. package/dest/public/public_tx_simulator/contract_provider_for_cpp.js +20 -55
  192. package/dest/public/public_tx_simulator/cpp_public_tx_simulator.d.ts +24 -37
  193. package/dest/public/public_tx_simulator/cpp_public_tx_simulator.d.ts.map +1 -1
  194. package/dest/public/public_tx_simulator/cpp_public_tx_simulator.js +67 -145
  195. package/dest/public/public_tx_simulator/cpp_public_tx_simulator_with_hinted_dbs.d.ts +42 -0
  196. package/dest/public/public_tx_simulator/cpp_public_tx_simulator_with_hinted_dbs.d.ts.map +1 -0
  197. package/dest/public/public_tx_simulator/cpp_public_tx_simulator_with_hinted_dbs.js +86 -0
  198. package/dest/public/public_tx_simulator/cpp_vs_ts_public_tx_simulator.d.ts +30 -0
  199. package/dest/public/public_tx_simulator/cpp_vs_ts_public_tx_simulator.d.ts.map +1 -0
  200. package/dest/public/public_tx_simulator/cpp_vs_ts_public_tx_simulator.js +171 -0
  201. package/dest/public/public_tx_simulator/dumping_cpp_public_tx_simulator.d.ts +23 -0
  202. package/dest/public/public_tx_simulator/dumping_cpp_public_tx_simulator.d.ts.map +1 -0
  203. package/dest/public/public_tx_simulator/dumping_cpp_public_tx_simulator.js +52 -0
  204. package/dest/public/public_tx_simulator/factories.d.ts +14 -0
  205. package/dest/public/public_tx_simulator/factories.d.ts.map +1 -0
  206. package/dest/public/public_tx_simulator/factories.js +28 -0
  207. package/dest/public/public_tx_simulator/index.d.ts +4 -1
  208. package/dest/public/public_tx_simulator/index.d.ts.map +1 -1
  209. package/dest/public/public_tx_simulator/index.js +3 -0
  210. package/dest/public/public_tx_simulator/measured_public_tx_simulator.d.ts +3 -3
  211. package/dest/public/public_tx_simulator/measured_public_tx_simulator.d.ts.map +1 -1
  212. package/dest/public/public_tx_simulator/public_tx_context.d.ts +5 -4
  213. package/dest/public/public_tx_simulator/public_tx_context.d.ts.map +1 -1
  214. package/dest/public/public_tx_simulator/public_tx_context.js +9 -9
  215. package/dest/public/public_tx_simulator/public_tx_simulator.d.ts +8 -6
  216. package/dest/public/public_tx_simulator/public_tx_simulator.d.ts.map +1 -1
  217. package/dest/public/public_tx_simulator/public_tx_simulator.js +23 -12
  218. package/dest/public/public_tx_simulator/public_tx_simulator_interface.d.ts +24 -1
  219. package/dest/public/public_tx_simulator/public_tx_simulator_interface.d.ts.map +1 -1
  220. package/dest/public/public_tx_simulator/telemetry_public_tx_simulator.d.ts +2 -2
  221. package/dest/public/public_tx_simulator/telemetry_public_tx_simulator.d.ts.map +1 -1
  222. package/dest/public/public_tx_simulator/telemetry_public_tx_simulator.js +395 -19
  223. package/dest/public/side_effect_trace.d.ts +6 -5
  224. package/dest/public/side_effect_trace.d.ts.map +1 -1
  225. package/dest/public/side_effect_trace.js +4 -4
  226. package/dest/public/side_effect_trace_interface.d.ts +2 -2
  227. package/dest/public/side_effect_trace_interface.d.ts.map +1 -1
  228. package/dest/public/state_manager/nullifiers.d.ts +2 -2
  229. package/dest/public/state_manager/nullifiers.d.ts.map +1 -1
  230. package/dest/public/state_manager/public_storage.d.ts +2 -2
  231. package/dest/public/state_manager/public_storage.d.ts.map +1 -1
  232. package/dest/public/state_manager/public_storage.js +1 -1
  233. package/dest/public/state_manager/state_manager.d.ts +16 -5
  234. package/dest/public/state_manager/state_manager.d.ts.map +1 -1
  235. package/dest/public/state_manager/state_manager.js +19 -9
  236. package/dest/public/test_executor_metrics.d.ts +3 -2
  237. package/dest/public/test_executor_metrics.d.ts.map +1 -1
  238. package/dest/public/test_executor_metrics.js +2 -2
  239. package/package.json +20 -20
  240. package/src/common/errors.ts +1 -1
  241. package/src/private/acvm/acvm.ts +4 -3
  242. package/src/private/acvm/deserialize.ts +1 -1
  243. package/src/private/acvm/serialize.ts +1 -1
  244. package/src/private/acvm_native.ts +11 -5
  245. package/src/private/acvm_wasm.ts +7 -3
  246. package/src/private/circuit_recording/circuit_recorder.ts +22 -19
  247. package/src/private/circuit_recording/file_circuit_recorder.ts +7 -2
  248. package/src/private/circuit_recording/memory_circuit_recorder.ts +6 -4
  249. package/src/private/factory.ts +7 -4
  250. package/src/public/avm/avm_context.ts +2 -2
  251. package/src/public/avm/avm_contract_call_result.ts +8 -6
  252. package/src/public/avm/avm_execution_environment.ts +10 -5
  253. package/src/public/avm/avm_gas.ts +3 -3
  254. package/src/public/avm/avm_machine_state.ts +7 -6
  255. package/src/public/avm/avm_memory_types.ts +5 -1
  256. package/src/public/avm/avm_simulator.ts +16 -10
  257. package/src/public/avm/calldata.ts +100 -0
  258. package/src/public/avm/errors.ts +17 -3
  259. package/src/public/avm/fixtures/avm_simulation_tester.ts +9 -3
  260. package/src/public/avm/fixtures/base_avm_simulation_tester.ts +1 -1
  261. package/src/public/avm/fixtures/initializers.ts +5 -4
  262. package/src/public/avm/fixtures/utils.ts +3 -2
  263. package/src/public/avm/opcodes/accrued_substate.ts +28 -30
  264. package/src/public/avm/opcodes/addressing_mode.ts +2 -2
  265. package/src/public/avm/opcodes/arithmetic.ts +14 -2
  266. package/src/public/avm/opcodes/bitwise.ts +3 -3
  267. package/src/public/avm/opcodes/comparators.ts +1 -1
  268. package/src/public/avm/opcodes/contract.ts +4 -7
  269. package/src/public/avm/opcodes/control_flow.ts +2 -2
  270. package/src/public/avm/opcodes/conversion.ts +3 -3
  271. package/src/public/avm/opcodes/ec_add.ts +15 -6
  272. package/src/public/avm/opcodes/environment_getters.ts +7 -7
  273. package/src/public/avm/opcodes/external_calls.ts +17 -15
  274. package/src/public/avm/opcodes/hashing.ts +16 -10
  275. package/src/public/avm/opcodes/instruction_impl.ts +2 -2
  276. package/src/public/avm/opcodes/memory.ts +20 -20
  277. package/src/public/avm/opcodes/misc.ts +4 -4
  278. package/src/public/avm/opcodes/storage.ts +30 -22
  279. package/src/public/avm/revert_reason.ts +6 -3
  280. package/src/public/avm/serialization/bytecode_serialization.ts +17 -6
  281. package/src/public/avm/serialization/instruction_serialization.ts +1 -1
  282. package/src/public/avm/test_utils.ts +1 -1
  283. package/src/public/contracts_db_checkpoint.ts +1 -1
  284. package/src/public/db_interfaces.ts +1 -1
  285. package/src/public/debug_fn_name.ts +39 -5
  286. package/src/public/executor_metrics.ts +9 -33
  287. package/src/public/fixtures/amm_test.ts +2 -2
  288. package/src/public/fixtures/bulk_test.ts +9 -9
  289. package/src/public/fixtures/custom_bytecode_tester.ts +53 -19
  290. package/src/public/fixtures/custom_bytecode_tests.ts +111 -18
  291. package/src/public/fixtures/index.ts +7 -1
  292. package/src/public/fixtures/minimal_public_tx.ts +6 -15
  293. package/src/public/fixtures/opcode_spammer.ts +1721 -0
  294. package/src/public/fixtures/public_tx_simulation_tester.ts +69 -13
  295. package/src/public/fixtures/simple_contract_data_source.ts +8 -9
  296. package/src/public/fixtures/token_test.ts +18 -9
  297. package/src/public/fixtures/utils.ts +2 -3
  298. package/src/public/fuzzing/avm_fuzzer_simulator.ts +288 -0
  299. package/src/public/fuzzing/avm_simulator_bin.ts +175 -0
  300. package/src/public/hinting_db_sources.ts +8 -3
  301. package/src/public/index.ts +7 -1
  302. package/src/public/public_db_sources.ts +16 -6
  303. package/src/public/public_processor/guarded_merkle_tree.ts +6 -1
  304. package/src/public/public_processor/public_processor.ts +63 -33
  305. package/src/public/public_processor/public_processor_metrics.ts +16 -44
  306. package/src/public/public_tx_simulator/contract_provider_for_cpp.ts +25 -63
  307. package/src/public/public_tx_simulator/cpp_public_tx_simulator.ts +83 -178
  308. package/src/public/public_tx_simulator/cpp_public_tx_simulator_with_hinted_dbs.ts +134 -0
  309. package/src/public/public_tx_simulator/cpp_vs_ts_public_tx_simulator.ts +239 -0
  310. package/src/public/public_tx_simulator/dumping_cpp_public_tx_simulator.ts +83 -0
  311. package/src/public/public_tx_simulator/factories.ts +43 -0
  312. package/src/public/public_tx_simulator/index.ts +3 -0
  313. package/src/public/public_tx_simulator/measured_public_tx_simulator.ts +1 -1
  314. package/src/public/public_tx_simulator/public_tx_context.ts +14 -7
  315. package/src/public/public_tx_simulator/public_tx_simulator.ts +42 -16
  316. package/src/public/public_tx_simulator/public_tx_simulator_interface.ts +23 -0
  317. package/src/public/public_tx_simulator/telemetry_public_tx_simulator.ts +1 -1
  318. package/src/public/side_effect_trace.ts +6 -3
  319. package/src/public/side_effect_trace_interface.ts +1 -1
  320. package/src/public/state_manager/nullifiers.ts +1 -1
  321. package/src/public/state_manager/public_storage.ts +1 -1
  322. package/src/public/state_manager/state_manager.ts +39 -23
  323. package/src/public/test_executor_metrics.ts +3 -3
@@ -1,25 +1,27 @@
1
- import { Fr } from '@aztec/foundation/fields';
2
- import { type Logger, createLogger } from '@aztec/foundation/log';
1
+ import { Fr } from '@aztec/foundation/curves/bn254';
2
+ import { type Logger, type LoggerBindings, createLogger } from '@aztec/foundation/log';
3
3
  import type { ContractProvider } from '@aztec/native';
4
4
  import { FunctionSelector } from '@aztec/stdlib/abi';
5
5
  import { deserializeFromMessagePack, serializeWithMessagePack } from '@aztec/stdlib/avm';
6
6
  import { AztecAddress } from '@aztec/stdlib/aztec-address';
7
7
  import { ContractDeploymentData } from '@aztec/stdlib/contract';
8
- import { ContractClassLog, ContractClassLogFields, PrivateLog } from '@aztec/stdlib/logs';
9
8
  import type { GlobalVariables } from '@aztec/stdlib/tx';
10
9
 
11
10
  import type { PublicContractsDB } from '../public_db_sources.js';
12
11
 
13
12
  export class ContractProviderForCpp implements ContractProvider {
14
- private log: Logger = createLogger('simulator:contract_provider_for_cpp');
13
+ private log: Logger;
15
14
 
16
15
  constructor(
17
16
  private contractsDB: PublicContractsDB,
18
17
  private globalVariables: GlobalVariables,
19
- ) {}
18
+ bindings?: LoggerBindings,
19
+ ) {
20
+ this.log = createLogger('simulator:contract_provider_for_cpp', bindings);
21
+ }
20
22
 
21
23
  public getContractInstance = async (address: string): Promise<Buffer | undefined> => {
22
- this.log.debug(`Contract provider callback: getContractInstance(${address})`);
24
+ this.log.trace(`Contract provider callback: getContractInstance(${address})`);
23
25
 
24
26
  const aztecAddr = AztecAddress.fromString(address);
25
27
 
@@ -34,7 +36,7 @@ export class ContractProviderForCpp implements ContractProvider {
34
36
  };
35
37
 
36
38
  public getContractClass = async (classId: string): Promise<Buffer | undefined> => {
37
- this.log.debug(`Contract provider callback: getContractClass(${classId})`);
39
+ this.log.trace(`Contract provider callback: getContractClass(${classId})`);
38
40
 
39
41
  // Parse classId string to Fr
40
42
  const classIdFr = Fr.fromString(classId);
@@ -51,20 +53,20 @@ export class ContractProviderForCpp implements ContractProvider {
51
53
  };
52
54
 
53
55
  public addContracts = async (contractDeploymentDataBuffer: Buffer): Promise<void> => {
54
- this.log.debug(`Contract provider callback: addContracts`);
56
+ this.log.trace(`Contract provider callback: addContracts`);
55
57
 
56
58
  const rawData: any = deserializeFromMessagePack(contractDeploymentDataBuffer);
57
59
 
58
- // Construct class instances using the from method
59
- const contractDeploymentData = this.reconstructContractDeploymentData(rawData);
60
+ // Construct ContractDeploymentData from plain object.
61
+ const contractDeploymentData = ContractDeploymentData.fromPlainObject(rawData);
60
62
 
61
63
  // Add contracts to the contracts DB
62
- this.log.debug(`Calling contractsDB.addContracts`);
64
+ this.log.trace(`Calling contractsDB.addContracts`);
63
65
  await this.contractsDB.addContracts(contractDeploymentData);
64
66
  };
65
67
 
66
68
  public getBytecodeCommitment = async (classId: string): Promise<Buffer | undefined> => {
67
- this.log.debug(`Contract provider callback: getBytecodeCommitment(${classId})`);
69
+ this.log.trace(`Contract provider callback: getBytecodeCommitment(${classId})`);
68
70
 
69
71
  // Parse classId string to Fr
70
72
  const classIdFr = Fr.fromString(classId);
@@ -82,18 +84,23 @@ export class ContractProviderForCpp implements ContractProvider {
82
84
  };
83
85
 
84
86
  public getDebugFunctionName = async (address: string, selector: string): Promise<string | undefined> => {
85
- this.log.debug(`Contract provider callback: getDebugFunctionName(${address}, ${selector})`);
87
+ this.log.trace(`Contract provider callback: getDebugFunctionName(${address}, ${selector})`);
86
88
 
87
89
  // Parse address and selector strings
88
90
  const aztecAddr = AztecAddress.fromString(address);
89
91
  const selectorFr = Fr.fromString(selector);
90
- const functionSelector = FunctionSelector.fromField(selectorFr);
92
+ const functionSelector = FunctionSelector.fromFieldOrUndefined(selectorFr);
93
+
94
+ if (!functionSelector) {
95
+ this.log.trace(`calldata[0] is not a function selector: ${selector}`);
96
+ return undefined;
97
+ }
91
98
 
92
99
  // Fetch debug function name from the contracts DB
93
100
  const name = await this.contractsDB.getDebugFunctionName(aztecAddr, functionSelector);
94
101
 
95
102
  if (!name) {
96
- this.log.debug(`Debug function name not found for ${address}:${selector}`);
103
+ this.log.trace(`Debug function name not found for ${address}:${selector}`);
97
104
  return undefined;
98
105
  }
99
106
 
@@ -101,62 +108,17 @@ export class ContractProviderForCpp implements ContractProvider {
101
108
  };
102
109
 
103
110
  public createCheckpoint = (): Promise<void> => {
104
- this.log.debug(`Contract provider callback: createCheckpoint`);
111
+ this.log.trace(`Contract provider callback: createCheckpoint`);
105
112
  return Promise.resolve(this.contractsDB.createCheckpoint());
106
113
  };
107
114
 
108
115
  public commitCheckpoint = (): Promise<void> => {
109
- this.log.debug(`Contract provider callback: commitCheckpoint`);
116
+ this.log.trace(`Contract provider callback: commitCheckpoint`);
110
117
  return Promise.resolve(this.contractsDB.commitCheckpoint());
111
118
  };
112
119
 
113
120
  public revertCheckpoint = (): Promise<void> => {
114
- this.log.debug(`Contract provider callback: revertCheckpoint`);
121
+ this.log.trace(`Contract provider callback: revertCheckpoint`);
115
122
  return Promise.resolve(this.contractsDB.revertCheckpoint());
116
123
  };
117
-
118
- /**
119
- * Reconstruct ContractDeploymentData from plain msgpack-deserialized objects.
120
- *
121
- * msgpackr does not automatically apply extensions to nested fields, so we need to
122
- * manually reconstruct ContractClassLog and PrivateLog instances with proper types.
123
- *
124
- * TODO(dbanks12): we really shouldn't have to do this.... We need to for now because
125
- * msgpack deserialization doesn't give us actual typed objects, but rather just JSON.
126
- * It would be easier if all types matched between languages (like AztecAddress which is just
127
- * FF in C++).
128
- */
129
- private reconstructContractDeploymentData(rawData: any): ContractDeploymentData {
130
- // Helper to ensure a value is an Fr instance
131
- const toFr = (value: any): Fr => {
132
- if (value instanceof Fr) {
133
- return value;
134
- }
135
- if (Buffer.isBuffer(value)) {
136
- return Fr.fromBuffer(value);
137
- }
138
- return new Fr(value);
139
- };
140
-
141
- // Reconstruct ContractClassLogs
142
- const contractClassLogs = (rawData.contractClassLogs || []).map((log: any) => {
143
- // Convert contractAddress to TS AztecAddress
144
- const addressFr = toFr(log.contractAddress);
145
- const address = AztecAddress.fromField(addressFr);
146
-
147
- // Ensure all fields are Fr instances
148
- const fields = (log.fields.fields || []).map((field: any) => toFr(field));
149
-
150
- // Create proper ContractClassLog instance
151
- return new ContractClassLog(address, new ContractClassLogFields(fields), log.emittedLength);
152
- });
153
-
154
- // Reconstruct PrivateLogs - ensure fields are Fr instances
155
- const privateLogs = (rawData.privateLogs || []).map((log: any) => {
156
- const fields = (log.fields || []).map((field: any) => toFr(field));
157
- return new PrivateLog(fields as any, log.emittedLength);
158
- });
159
-
160
- return new ContractDeploymentData(contractClassLogs, privateLogs);
161
- }
162
124
  }
@@ -1,9 +1,8 @@
1
- import { type Logger, createLogger } from '@aztec/foundation/log';
2
- import { writeTestData } from '@aztec/foundation/testing/files';
3
- import { avmSimulate, avmSimulateWithHintedDbs } from '@aztec/native';
1
+ import { type Logger, type LoggerBindings, createLogger, logLevel } from '@aztec/foundation/log';
2
+ import { sleep } from '@aztec/foundation/sleep';
3
+ import { type CancellationToken, avmSimulate, cancelSimulation, createCancellationToken } from '@aztec/native';
4
4
  import { ProtocolContractsList } from '@aztec/protocol-contracts';
5
5
  import {
6
- AvmCircuitInputs,
7
6
  AvmFastSimulationInputs,
8
7
  AvmTxHint,
9
8
  type PublicSimulatorConfig,
@@ -12,11 +11,13 @@ import {
12
11
  } from '@aztec/stdlib/avm';
13
12
  import { SimulationError } from '@aztec/stdlib/errors';
14
13
  import type { MerkleTreeWriteOperations } from '@aztec/stdlib/trees';
15
- import type { GlobalVariables, StateReference, Tx } from '@aztec/stdlib/tx';
14
+ import type { GlobalVariables, Tx } from '@aztec/stdlib/tx';
16
15
  import { WorldStateRevisionWithHandle } from '@aztec/stdlib/world-state';
16
+ import { type TelemetryClient, type Tracer, getTelemetryClient } from '@aztec/telemetry-client';
17
17
 
18
18
  import { strict as assert } from 'assert';
19
19
 
20
+ import { ExecutorMetrics } from '../executor_metrics.js';
20
21
  import type { ExecutorMetricsInterface } from '../executor_metrics_interface.js';
21
22
  import type { PublicContractsDB } from '../public_db_sources.js';
22
23
  import { ContractProviderForCpp } from './contract_provider_for_cpp.js';
@@ -30,21 +31,23 @@ import type {
30
31
  * C++ implementation of PublicTxSimulator using the C++ simulator.
31
32
  * The C++ simulator accesses the world state directly/natively within C++.
32
33
  * For contract DB accesses, it makes callbacks through NAPI back to the TS PublicContractsDB cache.
33
- *
34
- * TODO(dbanks12): for now this still simulates first in TS to generate hints and public inputs,
35
- * since the C++ simulator doesn't have hinting & PI generation logic yet.
36
34
  */
37
35
  export class CppPublicTxSimulator extends PublicTxSimulator implements PublicTxSimulatorInterface {
38
36
  protected override log: Logger;
37
+ /** Current cancellation token for in-flight simulation. */
38
+ private cancellationToken?: CancellationToken;
39
+ /** Current simulation promise, used to wait for completion after cancellation. */
40
+ private simulationPromise?: Promise<Buffer>;
39
41
 
40
42
  constructor(
41
43
  merkleTree: MerkleTreeWriteOperations,
42
44
  contractsDB: PublicContractsDB,
43
45
  globalVariables: GlobalVariables,
44
46
  config?: Partial<PublicSimulatorConfig>,
47
+ bindings?: LoggerBindings,
45
48
  ) {
46
- super(merkleTree, contractsDB, globalVariables, config);
47
- this.log = createLogger(`simulator:cpp_public_tx_simulator`);
49
+ super(merkleTree, contractsDB, globalVariables, config, undefined, bindings);
50
+ this.log = createLogger(`simulator:cpp_public_tx_simulator`, bindings);
48
51
  }
49
52
 
50
53
  /**
@@ -59,33 +62,6 @@ export class CppPublicTxSimulator extends PublicTxSimulator implements PublicTxS
59
62
  txHash,
60
63
  });
61
64
 
62
- // TODO(dbanks12): remove the first run with TS that hints!
63
- // Run TS simulation to generate hints and public inputs
64
- this.log.debug(`Running TS simulation for tx ${txHash}`);
65
-
66
- // create checkpoint for ws
67
- let tsResult: PublicTxResult | undefined;
68
- let tsStateRef: StateReference | undefined;
69
- await this.merkleTree.createCheckpoint();
70
- this.contractsDB.createCheckpoint();
71
- try {
72
- // Run the full TypeScript simulation using the parent class
73
- // This will modify the merkle tree with the transaction's state changes
74
- tsResult = await super.simulate(tx);
75
- this.log.debug(`TS simulation completed for tx ${txHash}`);
76
-
77
- tsStateRef = await this.merkleTree.getStateReference(); // capture tree roots for later comparsion
78
- } catch (error: any) {
79
- this.log.warn(`TS simulation failed, but still continuing with C++ simulation: ${error.message} ${error.stack}`);
80
- } finally {
81
- // revert checkpoint for ws and clear contract db changes
82
- // (cpp should reapply exactly the same changes if there are no bugs)
83
- await this.merkleTree.revertCheckpoint();
84
- this.contractsDB.revertCheckpoint();
85
- }
86
-
87
- this.log.debug(`Running C++ simulation for tx ${txHash}`);
88
-
89
65
  // Using the "as WorldStateRevisionWithHandle" is a bit of a "trust me bro", hence the assert.
90
66
  let wsRevision = this.merkleTree.getRevision();
91
67
  assert(
@@ -95,7 +71,7 @@ export class CppPublicTxSimulator extends PublicTxSimulator implements PublicTxS
95
71
  const wsCppHandle = (wsRevision as WorldStateRevisionWithHandle).handle;
96
72
  wsRevision = wsRevision.toWorldStateRevision(); // for msgpack serialization, we don't include the handle in the type
97
73
 
98
- this.log.debug(`Running C++ simulation with world state revision ${JSON.stringify(wsRevision)}`);
74
+ this.log.trace(`Running C++ simulation with world state revision ${JSON.stringify(wsRevision)}`);
99
75
 
100
76
  // Create the fast simulation inputs
101
77
  const txHint = AvmTxHint.fromTx(tx, this.globalVariables.gasFees);
@@ -109,65 +85,83 @@ export class CppPublicTxSimulator extends PublicTxSimulator implements PublicTxS
109
85
  );
110
86
 
111
87
  // Create contract provider for callbacks to TypeScript PublicContractsDB from C++
112
- const contractProvider = new ContractProviderForCpp(this.contractsDB, this.globalVariables);
88
+ const contractProvider = new ContractProviderForCpp(this.contractsDB, this.globalVariables, this.bindings);
113
89
 
114
90
  // Serialize to msgpack and call the C++ simulator
115
- this.log.verbose(`Serializing fast simulation inputs to msgpack...`);
91
+ this.log.trace(`Serializing fast simulation inputs to msgpack...`);
116
92
  const inputBuffer = fastSimInputs.serializeWithMessagePack();
117
93
 
94
+ // Create cancellation token for this simulation
95
+ this.cancellationToken = createCancellationToken();
96
+
97
+ // Store the promise so cancel() can wait for it
98
+ this.log.debug(`Calling C++ simulator for tx ${txHash}`);
99
+ this.simulationPromise = avmSimulate(
100
+ inputBuffer,
101
+ contractProvider,
102
+ wsCppHandle,
103
+ logLevel,
104
+ // TODO: re-enable logging
105
+ undefined,
106
+ this.cancellationToken,
107
+ );
108
+
118
109
  let resultBuffer: Buffer;
119
110
  try {
120
- this.log.verbose(`Calling C++ simulator for tx ${txHash}`);
121
- resultBuffer = await avmSimulate(inputBuffer, contractProvider, wsCppHandle);
111
+ resultBuffer = await this.simulationPromise;
122
112
  } catch (error: any) {
113
+ // Check if this was a cancellation
114
+ if (error.message?.includes('Simulation cancelled')) {
115
+ throw new SimulationError(`C++ simulation cancelled`, []);
116
+ }
123
117
  throw new SimulationError(`C++ simulation failed: ${error.message}`, []);
118
+ } finally {
119
+ this.cancellationToken = undefined;
120
+ this.simulationPromise = undefined;
124
121
  }
125
122
 
126
123
  // If we've reached this point, C++ succeeded during simulation,
127
- // so we assert that TS also succeeded.
128
- assert(tsResult !== undefined, 'TS simulation should have succeeded if C++ succeeded');
129
- assert(tsStateRef !== undefined, 'TS state reference should have been captured if C++ succeeded');
130
124
 
131
125
  // Deserialize the msgpack result
132
- this.log.verbose(`Deserializing C++ from buffer (size: ${resultBuffer.length})...`);
126
+ this.log.trace(`Deserializing C++ from buffer (size: ${resultBuffer.length})...`);
133
127
  const cppResultJSON: object = deserializeFromMessagePack(resultBuffer);
134
- // Write testdata if AZTEC_WRITE_TESTDATA=1.
135
- writeTestData(
136
- `barretenberg/cpp/src/barretenberg/vm2/testing/tx_result_${txHash}.testdata.bin`,
137
- resultBuffer,
138
- /*raw=*/ true,
139
- );
140
- this.log.verbose(`Deserializing C++ result to PublicTxResult...`);
128
+ this.log.trace(`Deserializing C++ result to PublicTxResult...`);
141
129
  const cppResult = PublicTxResult.fromPlainObject(cppResultJSON);
142
- this.log.verbose(`Done.`);
143
- // TODO(fcarreiro): complete this.
144
- assert(cppResult.revertCode.equals(tsResult.revertCode));
145
- assert(cppResult.gasUsed.totalGas.equals(tsResult.gasUsed.totalGas));
146
- assert(cppResult.gasUsed.publicGas.equals(tsResult.gasUsed.publicGas));
147
- assert(cppResult.gasUsed.teardownGas.equals(tsResult.gasUsed.teardownGas));
148
- assert(cppResult.gasUsed.billedGas.equals(tsResult.gasUsed.billedGas));
149
- assert(cppResult.publicInputs.toBuffer().equals(tsResult.publicInputs.toBuffer()));
150
- if (this.config?.collectCallMetadata) {
151
- assert(cppResult.appLogicReturnValues.length == tsResult.appLogicReturnValues.length);
152
- assert(cppResult.appLogicReturnValues.every((v, i) => v.equals(tsResult.appLogicReturnValues[i])));
153
- }
154
-
155
- // Confirm that tree roots match
156
- const cppStateRef = await this.merkleTree.getStateReference();
157
- assert(
158
- cppStateRef.equals(tsStateRef),
159
- `Tree roots mismatch between TS and C++ public simulations for tx ${txHash}`,
160
- );
161
130
 
162
- this.log.debug(`C++ simulation completed for tx ${txHash}`, {
131
+ this.log.trace(`C++ simulation completed for tx ${txHash}`, {
163
132
  txHash,
164
- reverted: !tsResult.revertCode.isOK(),
165
- tsGasUsed: tsResult.gasUsed.totalGas.l2Gas,
166
- cppGasUsed: tsResult.gasUsed.totalGas.l2Gas,
133
+ reverted: !cppResult.revertCode.isOK(),
134
+ cppGasUsed: cppResult.gasUsed.totalGas.l2Gas,
167
135
  });
168
136
 
169
- // TODO(dbanks12): C++ should return PublicTxResult (or something similar)
170
- return tsResult;
137
+ return cppResult;
138
+ }
139
+
140
+ /**
141
+ * Cancel the current simulation if one is in progress.
142
+ * This signals the C++ simulator to stop at the next opcode or before the next WorldState write.
143
+ * Safe to call even if no simulation is in progress.
144
+ *
145
+ * @param waitTimeoutMs - If provided, wait up to this many ms for the simulation to actually stop.
146
+ * This is important because C++ might be in the middle of a slow operation
147
+ * (e.g., pad_trees) and won't check the cancellation flag until it completes.
148
+ * Default timeout of 100ms after cancellation.
149
+ */
150
+ public async cancel(waitTimeoutMs: number = 100): Promise<void> {
151
+ if (this.cancellationToken) {
152
+ this.log.debug('Cancelling C++ simulation');
153
+ cancelSimulation(this.cancellationToken);
154
+ }
155
+
156
+ // Wait for the simulation to actually complete if not already done
157
+ if (this.simulationPromise) {
158
+ this.log.debug(`Waiting up to ${waitTimeoutMs}ms for C++ simulation to stop`);
159
+ await Promise.race([
160
+ this.simulationPromise.catch(() => {}), // Ignore rejection, just wait for completion
161
+ sleep(waitTimeoutMs),
162
+ ]);
163
+ this.log.debug('C++ simulation stopped or wait timed out');
164
+ }
171
165
  }
172
166
  }
173
167
 
@@ -178,8 +172,9 @@ export class MeasuredCppPublicTxSimulator extends CppPublicTxSimulator implement
178
172
  globalVariables: GlobalVariables,
179
173
  protected readonly metrics: ExecutorMetricsInterface,
180
174
  config?: Partial<PublicSimulatorConfig>,
175
+ bindings?: LoggerBindings,
181
176
  ) {
182
- super(merkleTree, contractsDB, globalVariables, config);
177
+ super(merkleTree, contractsDB, globalVariables, config, bindings);
183
178
  }
184
179
 
185
180
  public override async simulate(tx: Tx, txLabel: string = 'unlabeledTx'): Promise<PublicTxResult> {
@@ -195,112 +190,22 @@ export class MeasuredCppPublicTxSimulator extends CppPublicTxSimulator implement
195
190
  }
196
191
 
197
192
  /**
198
- * C++ implementation of PublicTxSimulator using pre-collected hints.
199
- * This implementation runs TS simulation first to collect all hints,
200
- * then passes the complete AvmCircuitInputs (hints + public inputs)
201
- * to C++ to run hinted simulation.
193
+ * A C++ public tx simulator that tracks runtime/production metrics with telemetry.
202
194
  */
203
- export class CppPublicTxSimulatorHintedDbs extends PublicTxSimulator implements PublicTxSimulatorInterface {
204
- protected override log: Logger;
205
-
206
- constructor(
207
- merkleTree: MerkleTreeWriteOperations,
208
- contractsDB: PublicContractsDB,
209
- globalVariables: GlobalVariables,
210
- config?: Partial<PublicSimulatorConfig>,
211
- ) {
212
- super(merkleTree, contractsDB, globalVariables, config);
213
- this.log = createLogger(`simulator:cpp_public_tx_simulator_hinted_dbs`);
214
- }
215
-
216
- /**
217
- * Simulate a transaction's public portion using the C++ vm2 simulator with hinted DBs.
218
- *
219
- * This implementation:
220
- * 1. Runs the full TypeScript simulation to generate AvmCircuitInputs (hints + public inputs)
221
- * 2. Passes the complete AvmCircuitInputs to C++ to run hinted simulation
222
- *
223
- * @param tx - The transaction to simulate.
224
- * @returns The result of the transaction's public execution.
225
- */
226
- public override async simulate(tx: Tx): Promise<PublicTxResult> {
227
- const txHash = this.computeTxHash(tx);
228
- this.log.debug(`C++ hinted DB simulation of ${tx.publicFunctionCalldata.length} public calls for tx ${txHash}`, {
229
- txHash,
230
- });
231
-
232
- // First, run TS simulation to generate hints and public inputs
233
- this.log.debug(`Running TS simulation for tx ${txHash}`);
234
-
235
- // Run the full TypeScript simulation using the parent class
236
- // This will modify the merkle tree with the transaction's state changes
237
- const tsResult = await super.simulate(tx);
238
- this.log.debug(`TS simulation succeeded for tx ${txHash}`);
239
-
240
- // Extract the full AvmCircuitInputs from the TS result
241
- const avmCircuitInputs = new AvmCircuitInputs(tsResult.hints!, tsResult.publicInputs);
242
-
243
- // Second, run C++ simulation with hinted DBs
244
- this.log.debug(`Running C++ simulation with hinted DBs for tx ${txHash}`);
245
-
246
- // Serialize to msgpack and call the C++ simulator
247
- const inputBuffer = avmCircuitInputs.serializeWithMessagePack();
248
-
249
- let resultBuffer: Buffer;
250
- try {
251
- resultBuffer = await avmSimulateWithHintedDbs(inputBuffer);
252
- } catch (error: any) {
253
- throw new SimulationError(`C++ hinted simulation failed: ${error.message}`, []);
254
- }
255
-
256
- // Deserialize the msgpack result
257
- const cppResultJSON: object = deserializeFromMessagePack(resultBuffer);
258
- const cppResult = PublicTxResult.fromPlainObject(cppResultJSON);
259
-
260
- assert(cppResult.revertCode.equals(tsResult.revertCode));
261
- assert(cppResult.gasUsed.totalGas.equals(tsResult.gasUsed.totalGas));
195
+ export class TelemetryCppPublicTxSimulator extends MeasuredCppPublicTxSimulator {
196
+ /* tracer needed by trackSpans */
197
+ public readonly tracer: Tracer;
262
198
 
263
- this.log.debug(`C++ hinted simulation completed for tx ${txHash}`, {
264
- txHash,
265
- reverted: !tsResult.revertCode.isOK(),
266
- tsGasUsed: tsResult.gasUsed.totalGas.l2Gas,
267
- cppGasUsed: tsResult.gasUsed.totalGas.l2Gas,
268
- });
269
-
270
- // TODO(fcarreiro): complete this.
271
- return tsResult;
272
- }
273
- }
274
-
275
- /**
276
- * Class to record metrics for simulation.
277
- *
278
- * Note(dbanks12): We might not be able to collect all the same metrics in C++ as we do in TS!
279
- * Unless we move some of the metrics collection to C++, we don't have inner functions exposed
280
- * to TS for tracking.
281
- */
282
- export class MeasuredCppPublicTxSimulatorHintedDbs
283
- extends CppPublicTxSimulatorHintedDbs
284
- implements MeasuredPublicTxSimulatorInterface
285
- {
286
199
  constructor(
287
200
  merkleTree: MerkleTreeWriteOperations,
288
201
  contractsDB: PublicContractsDB,
289
202
  globalVariables: GlobalVariables,
290
- protected readonly metrics: ExecutorMetricsInterface,
203
+ telemetryClient: TelemetryClient = getTelemetryClient(),
291
204
  config?: Partial<PublicSimulatorConfig>,
205
+ bindings?: LoggerBindings,
292
206
  ) {
293
- super(merkleTree, contractsDB, globalVariables, config);
294
- }
295
-
296
- public override async simulate(tx: Tx, txLabel: string = 'unlabeledTx'): Promise<PublicTxResult> {
297
- this.metrics.startRecordingTxSimulation(txLabel);
298
- let result: PublicTxResult | undefined;
299
- try {
300
- result = await super.simulate(tx);
301
- } finally {
302
- this.metrics.stopRecordingTxSimulation(txLabel, result?.gasUsed, result?.revertCode);
303
- }
304
- return result;
207
+ const metrics = new ExecutorMetrics(telemetryClient, 'CppPublicTxSimulator');
208
+ super(merkleTree, contractsDB, globalVariables, metrics, config, bindings);
209
+ this.tracer = metrics.tracer;
305
210
  }
306
211
  }
@@ -0,0 +1,134 @@
1
+ import { type Logger, type LoggerBindings, createLogger, logLevel } from '@aztec/foundation/log';
2
+ import { avmSimulateWithHintedDbs } from '@aztec/native';
3
+ import {
4
+ AvmCircuitInputs,
5
+ type PublicSimulatorConfig,
6
+ PublicTxResult,
7
+ deserializeFromMessagePack,
8
+ } from '@aztec/stdlib/avm';
9
+ import { SimulationError } from '@aztec/stdlib/errors';
10
+ import type { MerkleTreeWriteOperations } from '@aztec/stdlib/trees';
11
+ import type { GlobalVariables, Tx } from '@aztec/stdlib/tx';
12
+
13
+ import { strict as assert } from 'assert';
14
+
15
+ import type { ExecutorMetricsInterface } from '../executor_metrics_interface.js';
16
+ import type { PublicContractsDB } from '../public_db_sources.js';
17
+ import { PublicTxSimulator } from './public_tx_simulator.js';
18
+ import type {
19
+ MeasuredPublicTxSimulatorInterface,
20
+ PublicTxSimulatorInterface,
21
+ } from './public_tx_simulator_interface.js';
22
+
23
+ /**
24
+ * C++ implementation of PublicTxSimulator using pre-collected hints.
25
+ * This implementation runs TS simulation first to collect all hints,
26
+ * then passes the complete AvmCircuitInputs (hints + public inputs)
27
+ * to C++ to run hinted simulation.
28
+ */
29
+ export class CppPublicTxSimulatorHintedDbs extends PublicTxSimulator implements PublicTxSimulatorInterface {
30
+ protected override log: Logger;
31
+
32
+ constructor(
33
+ merkleTree: MerkleTreeWriteOperations,
34
+ contractsDB: PublicContractsDB,
35
+ globalVariables: GlobalVariables,
36
+ config?: Partial<PublicSimulatorConfig>,
37
+ bindings?: LoggerBindings,
38
+ ) {
39
+ super(merkleTree, contractsDB, globalVariables, config, undefined, bindings);
40
+ this.log = createLogger(`simulator:cpp_public_tx_simulator_hinted_dbs`, bindings);
41
+ }
42
+
43
+ /**
44
+ * Simulate a transaction's public portion using the C++ vm2 simulator with hinted DBs.
45
+ *
46
+ * This implementation:
47
+ * 1. Runs the full TypeScript simulation to generate AvmCircuitInputs (hints + public inputs)
48
+ * 2. Passes the complete AvmCircuitInputs to C++ to run hinted simulation
49
+ *
50
+ * @param tx - The transaction to simulate.
51
+ * @returns The result of the transaction's public execution.
52
+ */
53
+ public override async simulate(tx: Tx): Promise<PublicTxResult> {
54
+ const txHash = this.computeTxHash(tx);
55
+ this.log.debug(`C++ hinted DB simulation of ${tx.publicFunctionCalldata.length} public calls for tx ${txHash}`, {
56
+ txHash,
57
+ });
58
+
59
+ // First, run TS simulation to generate hints and public inputs
60
+ this.log.debug(`Running TS simulation for tx ${txHash}`);
61
+
62
+ // Run the full TypeScript simulation using the parent class
63
+ // This will modify the merkle tree with the transaction's state changes
64
+ const tsResult = await super.simulate(tx);
65
+ this.log.debug(`TS simulation succeeded for tx ${txHash}`);
66
+
67
+ // Extract the full AvmCircuitInputs from the TS result
68
+ const avmCircuitInputs = new AvmCircuitInputs(tsResult.hints!, tsResult.publicInputs!);
69
+
70
+ // Second, run C++ simulation with hinted DBs
71
+ this.log.debug(`Running C++ simulation with hinted DBs for tx ${txHash}`);
72
+
73
+ // Serialize to msgpack and call the C++ simulator
74
+ const inputBuffer = avmCircuitInputs.serializeWithMessagePack();
75
+
76
+ let resultBuffer: Buffer;
77
+ try {
78
+ resultBuffer = await avmSimulateWithHintedDbs(inputBuffer, logLevel);
79
+ } catch (error: any) {
80
+ throw new SimulationError(`C++ hinted simulation failed: ${error.message}`, []);
81
+ }
82
+
83
+ // Deserialize the msgpack result
84
+ const cppResultJSON: object = deserializeFromMessagePack(resultBuffer);
85
+ const cppResult = PublicTxResult.fromPlainObject(cppResultJSON);
86
+
87
+ assert(cppResult.revertCode.equals(tsResult.revertCode));
88
+ assert(cppResult.gasUsed.totalGas.equals(tsResult.gasUsed.totalGas));
89
+
90
+ this.log.debug(`C++ hinted simulation completed for tx ${txHash}`, {
91
+ txHash,
92
+ reverted: !tsResult.revertCode.isOK(),
93
+ tsGasUsed: tsResult.gasUsed.totalGas.l2Gas,
94
+ cppGasUsed: tsResult.gasUsed.totalGas.l2Gas,
95
+ });
96
+
97
+ // TODO(fcarreiro): complete this.
98
+ return tsResult;
99
+ }
100
+ }
101
+
102
+ /**
103
+ * Class to record metrics for simulation.
104
+ *
105
+ * Note(dbanks12): We might not be able to collect all the same metrics in C++ as we do in TS!
106
+ * Unless we move some of the metrics collection to C++, we don't have inner functions exposed
107
+ * to TS for tracking.
108
+ */
109
+ export class MeasuredCppPublicTxSimulatorHintedDbs
110
+ extends CppPublicTxSimulatorHintedDbs
111
+ implements MeasuredPublicTxSimulatorInterface
112
+ {
113
+ constructor(
114
+ merkleTree: MerkleTreeWriteOperations,
115
+ contractsDB: PublicContractsDB,
116
+ globalVariables: GlobalVariables,
117
+ protected readonly metrics: ExecutorMetricsInterface,
118
+ config?: Partial<PublicSimulatorConfig>,
119
+ bindings?: LoggerBindings,
120
+ ) {
121
+ super(merkleTree, contractsDB, globalVariables, config, bindings);
122
+ }
123
+
124
+ public override async simulate(tx: Tx, txLabel: string = 'unlabeledTx'): Promise<PublicTxResult> {
125
+ this.metrics.startRecordingTxSimulation(txLabel);
126
+ let result: PublicTxResult | undefined;
127
+ try {
128
+ result = await super.simulate(tx);
129
+ } finally {
130
+ this.metrics.stopRecordingTxSimulation(txLabel, result?.gasUsed, result?.revertCode);
131
+ }
132
+ return result;
133
+ }
134
+ }