@aztec/simulator 3.0.0-devnet.2 → 3.0.0-devnet.2-patch.1

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 (314) hide show
  1. package/dest/client.d.ts +1 -1
  2. package/dest/common/errors.d.ts +2 -8
  3. package/dest/common/errors.d.ts.map +1 -1
  4. package/dest/common/index.d.ts +1 -1
  5. package/dest/common/stats/index.d.ts +1 -1
  6. package/dest/common/stats/stats.d.ts +1 -1
  7. package/dest/private/acvm/acvm.d.ts +1 -1
  8. package/dest/private/acvm/acvm_types.d.ts +1 -1
  9. package/dest/private/acvm/deserialize.d.ts +2 -2
  10. package/dest/private/acvm/deserialize.d.ts.map +1 -1
  11. package/dest/private/acvm/deserialize.js +1 -1
  12. package/dest/private/acvm/index.d.ts +1 -1
  13. package/dest/private/acvm/serialize.d.ts +2 -2
  14. package/dest/private/acvm/serialize.d.ts.map +1 -1
  15. package/dest/private/acvm/serialize.js +1 -1
  16. package/dest/private/acvm_native.d.ts +1 -1
  17. package/dest/private/acvm_native.d.ts.map +1 -1
  18. package/dest/private/acvm_native.js +15 -13
  19. package/dest/private/acvm_wasm.d.ts +1 -1
  20. package/dest/private/acvm_wasm.d.ts.map +1 -1
  21. package/dest/private/acvm_wasm_with_blobs.d.ts +1 -1
  22. package/dest/private/acvm_wasm_with_blobs.d.ts.map +1 -1
  23. package/dest/private/circuit_recording/circuit_recorder.d.ts +1 -1
  24. package/dest/private/circuit_recording/circuit_recorder.d.ts.map +1 -1
  25. package/dest/private/circuit_recording/circuit_recorder.js +1 -1
  26. package/dest/private/circuit_recording/file_circuit_recorder.d.ts +1 -1
  27. package/dest/private/circuit_recording/file_circuit_recorder.d.ts.map +1 -1
  28. package/dest/private/circuit_recording/memory_circuit_recorder.d.ts +1 -1
  29. package/dest/private/circuit_recording/memory_circuit_recorder.d.ts.map +1 -1
  30. package/dest/private/circuit_recording/simulator_recorder_wrapper.d.ts +1 -1
  31. package/dest/private/circuit_recording/simulator_recorder_wrapper.d.ts.map +1 -1
  32. package/dest/private/circuit_simulator.d.ts +1 -1
  33. package/dest/private/factory.d.ts +1 -1
  34. package/dest/public/avm/avm_context.d.ts +2 -2
  35. package/dest/public/avm/avm_context.d.ts.map +1 -1
  36. package/dest/public/avm/avm_contract_call_result.d.ts +2 -2
  37. package/dest/public/avm/avm_contract_call_result.d.ts.map +1 -1
  38. package/dest/public/avm/avm_execution_environment.d.ts +5 -5
  39. package/dest/public/avm/avm_execution_environment.d.ts.map +1 -1
  40. package/dest/public/avm/avm_execution_environment.js +5 -8
  41. package/dest/public/avm/avm_gas.d.ts +2 -2
  42. package/dest/public/avm/avm_gas.d.ts.map +1 -1
  43. package/dest/public/avm/avm_machine_state.d.ts +2 -2
  44. package/dest/public/avm/avm_machine_state.d.ts.map +1 -1
  45. package/dest/public/avm/avm_memory_types.d.ts +14 -14
  46. package/dest/public/avm/avm_memory_types.d.ts.map +1 -1
  47. package/dest/public/avm/avm_memory_types.js +1 -1
  48. package/dest/public/avm/avm_simulator.d.ts +4 -3
  49. package/dest/public/avm/avm_simulator.d.ts.map +1 -1
  50. package/dest/public/avm/avm_simulator.js +8 -7
  51. package/dest/public/avm/avm_simulator_interface.d.ts +1 -1
  52. package/dest/public/avm/errors.d.ts +8 -2
  53. package/dest/public/avm/errors.d.ts.map +1 -1
  54. package/dest/public/avm/errors.js +14 -2
  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 +12 -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 -3
  62. package/dest/public/avm/fixtures/initializers.d.ts.map +1 -1
  63. package/dest/public/avm/fixtures/initializers.js +7 -5
  64. package/dest/public/avm/fixtures/utils.d.ts +4 -3
  65. package/dest/public/avm/fixtures/utils.d.ts.map +1 -1
  66. package/dest/public/avm/fixtures/utils.js +3 -2
  67. package/dest/public/avm/index.d.ts +1 -1
  68. package/dest/public/avm/opcodes/accrued_substate.d.ts +1 -1
  69. package/dest/public/avm/opcodes/accrued_substate.d.ts.map +1 -1
  70. package/dest/public/avm/opcodes/addressing_mode.d.ts +1 -1
  71. package/dest/public/avm/opcodes/addressing_mode.d.ts.map +1 -1
  72. package/dest/public/avm/opcodes/addressing_mode.js +2 -2
  73. package/dest/public/avm/opcodes/arithmetic.d.ts +10 -8
  74. package/dest/public/avm/opcodes/arithmetic.d.ts.map +1 -1
  75. package/dest/public/avm/opcodes/arithmetic.js +11 -1
  76. package/dest/public/avm/opcodes/bitwise.d.ts +5 -5
  77. package/dest/public/avm/opcodes/bitwise.d.ts.map +1 -1
  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/contract.d.ts +1 -1
  81. package/dest/public/avm/opcodes/contract.d.ts.map +1 -1
  82. package/dest/public/avm/opcodes/control_flow.d.ts +1 -1
  83. package/dest/public/avm/opcodes/control_flow.d.ts.map +1 -1
  84. package/dest/public/avm/opcodes/conversion.d.ts +1 -1
  85. package/dest/public/avm/opcodes/conversion.d.ts.map +1 -1
  86. package/dest/public/avm/opcodes/ec_add.d.ts +2 -2
  87. package/dest/public/avm/opcodes/ec_add.d.ts.map +1 -1
  88. package/dest/public/avm/opcodes/ec_add.js +3 -4
  89. package/dest/public/avm/opcodes/environment_getters.d.ts +1 -1
  90. package/dest/public/avm/opcodes/environment_getters.d.ts.map +1 -1
  91. package/dest/public/avm/opcodes/external_calls.d.ts +1 -1
  92. package/dest/public/avm/opcodes/external_calls.d.ts.map +1 -1
  93. package/dest/public/avm/opcodes/external_calls.js +0 -1
  94. package/dest/public/avm/opcodes/hashing.d.ts +2 -2
  95. package/dest/public/avm/opcodes/hashing.d.ts.map +1 -1
  96. package/dest/public/avm/opcodes/hashing.js +3 -1
  97. package/dest/public/avm/opcodes/index.d.ts +1 -1
  98. package/dest/public/avm/opcodes/instruction.d.ts +2 -2
  99. package/dest/public/avm/opcodes/instruction.d.ts.map +1 -1
  100. package/dest/public/avm/opcodes/instruction_impl.d.ts +1 -1
  101. package/dest/public/avm/opcodes/instruction_impl.d.ts.map +1 -1
  102. package/dest/public/avm/opcodes/memory.d.ts +2 -2
  103. package/dest/public/avm/opcodes/memory.d.ts.map +1 -1
  104. package/dest/public/avm/opcodes/memory.js +1 -1
  105. package/dest/public/avm/opcodes/misc.d.ts +1 -1
  106. package/dest/public/avm/opcodes/misc.d.ts.map +1 -1
  107. package/dest/public/avm/opcodes/misc.js +4 -4
  108. package/dest/public/avm/opcodes/storage.d.ts +3 -3
  109. package/dest/public/avm/opcodes/storage.d.ts.map +1 -1
  110. package/dest/public/avm/revert_reason.d.ts +2 -2
  111. package/dest/public/avm/revert_reason.d.ts.map +1 -1
  112. package/dest/public/avm/revert_reason.js +3 -2
  113. package/dest/public/avm/serialization/buffer_cursor.d.ts +1 -1
  114. package/dest/public/avm/serialization/buffer_cursor.d.ts.map +1 -1
  115. package/dest/public/avm/serialization/bytecode_serialization.d.ts +1 -1
  116. package/dest/public/avm/serialization/bytecode_serialization.d.ts.map +1 -1
  117. package/dest/public/avm/serialization/bytecode_serialization.js +9 -6
  118. package/dest/public/avm/serialization/instruction_serialization.d.ts +1 -1
  119. package/dest/public/avm/serialization/instruction_serialization.js +1 -1
  120. package/dest/public/avm/test_utils.d.ts +2 -2
  121. package/dest/public/avm/test_utils.d.ts.map +1 -1
  122. package/dest/public/avm/test_utils.js +1 -1
  123. package/dest/public/contracts_db_checkpoint.d.ts +16 -0
  124. package/dest/public/contracts_db_checkpoint.d.ts.map +1 -0
  125. package/dest/public/contracts_db_checkpoint.js +30 -0
  126. package/dest/public/db_interfaces.d.ts +14 -2
  127. package/dest/public/db_interfaces.d.ts.map +1 -1
  128. package/dest/public/debug_fn_name.d.ts +15 -2
  129. package/dest/public/debug_fn_name.d.ts.map +1 -1
  130. package/dest/public/debug_fn_name.js +19 -0
  131. package/dest/public/executor_metrics.d.ts +3 -2
  132. package/dest/public/executor_metrics.d.ts.map +1 -1
  133. package/dest/public/executor_metrics.js +1 -1
  134. package/dest/public/executor_metrics_interface.d.ts +3 -2
  135. package/dest/public/executor_metrics_interface.d.ts.map +1 -1
  136. package/dest/public/fixtures/amm_test.d.ts +1 -1
  137. package/dest/public/fixtures/amm_test.js +2 -2
  138. package/dest/public/fixtures/bulk_test.d.ts +1 -1
  139. package/dest/public/fixtures/bulk_test.js +1 -1
  140. package/dest/public/fixtures/custom_bytecode_tester.d.ts +2 -2
  141. package/dest/public/fixtures/custom_bytecode_tester.d.ts.map +1 -1
  142. package/dest/public/fixtures/custom_bytecode_tests.d.ts +2 -1
  143. package/dest/public/fixtures/custom_bytecode_tests.d.ts.map +1 -1
  144. package/dest/public/fixtures/custom_bytecode_tests.js +21 -0
  145. package/dest/public/fixtures/index.d.ts +1 -1
  146. package/dest/public/fixtures/minimal_public_tx.d.ts +2 -3
  147. package/dest/public/fixtures/minimal_public_tx.d.ts.map +1 -1
  148. package/dest/public/fixtures/minimal_public_tx.js +2 -2
  149. package/dest/public/fixtures/public_tx_simulation_tester.d.ts +10 -5
  150. package/dest/public/fixtures/public_tx_simulation_tester.d.ts.map +1 -1
  151. package/dest/public/fixtures/public_tx_simulation_tester.js +28 -14
  152. package/dest/public/fixtures/simple_contract_data_source.d.ts +5 -4
  153. package/dest/public/fixtures/simple_contract_data_source.d.ts.map +1 -1
  154. package/dest/public/fixtures/simple_contract_data_source.js +4 -4
  155. package/dest/public/fixtures/token_test.d.ts +6 -2
  156. package/dest/public/fixtures/token_test.d.ts.map +1 -1
  157. package/dest/public/fixtures/token_test.js +13 -12
  158. package/dest/public/fixtures/utils.d.ts +2 -2
  159. package/dest/public/fixtures/utils.d.ts.map +1 -1
  160. package/dest/public/fixtures/utils.js +4 -4
  161. package/dest/public/fuzzing/avm_fuzzer_simulator.d.ts +46 -0
  162. package/dest/public/fuzzing/avm_fuzzer_simulator.d.ts.map +1 -0
  163. package/dest/public/fuzzing/avm_fuzzer_simulator.js +136 -0
  164. package/dest/public/fuzzing/avm_simulator_bin.d.ts +2 -0
  165. package/dest/public/fuzzing/avm_simulator_bin.d.ts.map +1 -0
  166. package/dest/public/fuzzing/avm_simulator_bin.js +84 -0
  167. package/dest/public/hinting_db_sources.d.ts +13 -4
  168. package/dest/public/hinting_db_sources.d.ts.map +1 -1
  169. package/dest/public/hinting_db_sources.js +66 -13
  170. package/dest/public/index.d.ts +3 -2
  171. package/dest/public/index.d.ts.map +1 -1
  172. package/dest/public/index.js +1 -1
  173. package/dest/public/public_db_sources.d.ts +22 -63
  174. package/dest/public/public_db_sources.d.ts.map +1 -1
  175. package/dest/public/public_db_sources.js +74 -131
  176. package/dest/public/public_errors.d.ts +1 -1
  177. package/dest/public/public_errors.d.ts.map +1 -1
  178. package/dest/public/public_processor/guarded_merkle_tree.d.ts +5 -4
  179. package/dest/public/public_processor/guarded_merkle_tree.d.ts.map +1 -1
  180. package/dest/public/public_processor/public_processor.d.ts +11 -18
  181. package/dest/public/public_processor/public_processor.d.ts.map +1 -1
  182. package/dest/public/public_processor/public_processor.js +37 -36
  183. package/dest/public/public_processor/public_processor_metrics.d.ts +1 -1
  184. package/dest/public/public_processor/public_processor_metrics.d.ts.map +1 -1
  185. package/dest/public/public_tx_simulator/contract_provider_for_cpp.d.ts +18 -0
  186. package/dest/public/public_tx_simulator/contract_provider_for_cpp.d.ts.map +1 -0
  187. package/dest/public/public_tx_simulator/contract_provider_for_cpp.js +94 -0
  188. package/dest/public/public_tx_simulator/cpp_public_tx_simulator.d.ts +19 -22
  189. package/dest/public/public_tx_simulator/cpp_public_tx_simulator.d.ts.map +1 -1
  190. package/dest/public/public_tx_simulator/cpp_public_tx_simulator.js +54 -50
  191. package/dest/public/public_tx_simulator/cpp_public_tx_simulator_with_hinted_dbs.d.ts +42 -0
  192. package/dest/public/public_tx_simulator/cpp_public_tx_simulator_with_hinted_dbs.d.ts.map +1 -0
  193. package/dest/public/public_tx_simulator/cpp_public_tx_simulator_with_hinted_dbs.js +86 -0
  194. package/dest/public/public_tx_simulator/cpp_vs_ts_public_tx_simulator.d.ts +30 -0
  195. package/dest/public/public_tx_simulator/cpp_vs_ts_public_tx_simulator.d.ts.map +1 -0
  196. package/dest/public/public_tx_simulator/cpp_vs_ts_public_tx_simulator.js +170 -0
  197. package/dest/public/public_tx_simulator/dumping_cpp_public_tx_simulator.d.ts +22 -0
  198. package/dest/public/public_tx_simulator/dumping_cpp_public_tx_simulator.d.ts.map +1 -0
  199. package/dest/public/public_tx_simulator/dumping_cpp_public_tx_simulator.js +52 -0
  200. package/dest/public/public_tx_simulator/factories.d.ts +13 -0
  201. package/dest/public/public_tx_simulator/factories.d.ts.map +1 -0
  202. package/dest/public/public_tx_simulator/factories.js +28 -0
  203. package/dest/public/public_tx_simulator/index.d.ts +5 -1
  204. package/dest/public/public_tx_simulator/index.d.ts.map +1 -1
  205. package/dest/public/public_tx_simulator/index.js +3 -0
  206. package/dest/public/public_tx_simulator/measured_public_tx_simulator.d.ts +14 -7
  207. package/dest/public/public_tx_simulator/measured_public_tx_simulator.d.ts.map +1 -1
  208. package/dest/public/public_tx_simulator/measured_public_tx_simulator.js +5 -5
  209. package/dest/public/public_tx_simulator/public_tx_context.d.ts +6 -3
  210. package/dest/public/public_tx_simulator/public_tx_context.d.ts.map +1 -1
  211. package/dest/public/public_tx_simulator/public_tx_context.js +13 -5
  212. package/dest/public/public_tx_simulator/public_tx_simulator.d.ts +11 -31
  213. package/dest/public/public_tx_simulator/public_tx_simulator.d.ts.map +1 -1
  214. package/dest/public/public_tx_simulator/public_tx_simulator.js +109 -126
  215. package/dest/public/public_tx_simulator/public_tx_simulator_interface.d.ts +2 -2
  216. package/dest/public/public_tx_simulator/public_tx_simulator_interface.d.ts.map +1 -1
  217. package/dest/public/public_tx_simulator/telemetry_public_tx_simulator.d.ts +4 -4
  218. package/dest/public/public_tx_simulator/telemetry_public_tx_simulator.d.ts.map +1 -1
  219. package/dest/public/side_effect_errors.d.ts +1 -1
  220. package/dest/public/side_effect_errors.d.ts.map +1 -1
  221. package/dest/public/side_effect_trace.d.ts +2 -3
  222. package/dest/public/side_effect_trace.d.ts.map +1 -1
  223. package/dest/public/side_effect_trace.js +1 -1
  224. package/dest/public/side_effect_trace_interface.d.ts +3 -4
  225. package/dest/public/side_effect_trace_interface.d.ts.map +1 -1
  226. package/dest/public/state_manager/index.d.ts +1 -1
  227. package/dest/public/state_manager/nullifiers.d.ts +2 -2
  228. package/dest/public/state_manager/nullifiers.d.ts.map +1 -1
  229. package/dest/public/state_manager/public_storage.d.ts +2 -2
  230. package/dest/public/state_manager/public_storage.d.ts.map +1 -1
  231. package/dest/public/state_manager/public_storage.js +1 -1
  232. package/dest/public/state_manager/state_manager.d.ts +9 -11
  233. package/dest/public/state_manager/state_manager.d.ts.map +1 -1
  234. package/dest/public/state_manager/state_manager.js +10 -6
  235. package/dest/public/test_executor_metrics.d.ts +4 -3
  236. package/dest/public/test_executor_metrics.d.ts.map +1 -1
  237. package/dest/public/test_executor_metrics.js +5 -4
  238. package/dest/public/unique_class_ids.d.ts +1 -1
  239. package/dest/public/unique_class_ids.d.ts.map +1 -1
  240. package/dest/public/utils.d.ts +1 -1
  241. package/dest/server.d.ts +1 -1
  242. package/dest/testing.d.ts +1 -1
  243. package/package.json +21 -20
  244. package/src/common/errors.ts +1 -1
  245. package/src/private/acvm/deserialize.ts +1 -1
  246. package/src/private/acvm/serialize.ts +1 -1
  247. package/src/private/acvm_native.ts +17 -9
  248. package/src/private/circuit_recording/circuit_recorder.ts +1 -1
  249. package/src/public/avm/avm_context.ts +1 -1
  250. package/src/public/avm/avm_contract_call_result.ts +1 -1
  251. package/src/public/avm/avm_execution_environment.ts +4 -6
  252. package/src/public/avm/avm_gas.ts +3 -3
  253. package/src/public/avm/avm_machine_state.ts +1 -1
  254. package/src/public/avm/avm_memory_types.ts +1 -1
  255. package/src/public/avm/avm_simulator.ts +11 -9
  256. package/src/public/avm/errors.ts +17 -3
  257. package/src/public/avm/fixtures/avm_simulation_tester.ts +10 -2
  258. package/src/public/avm/fixtures/base_avm_simulation_tester.ts +1 -1
  259. package/src/public/avm/fixtures/initializers.ts +8 -10
  260. package/src/public/avm/fixtures/utils.ts +3 -2
  261. package/src/public/avm/opcodes/addressing_mode.ts +2 -2
  262. package/src/public/avm/opcodes/arithmetic.ts +13 -1
  263. package/src/public/avm/opcodes/ec_add.ts +3 -4
  264. package/src/public/avm/opcodes/external_calls.ts +0 -1
  265. package/src/public/avm/opcodes/hashing.ts +3 -1
  266. package/src/public/avm/opcodes/memory.ts +1 -1
  267. package/src/public/avm/opcodes/misc.ts +4 -4
  268. package/src/public/avm/revert_reason.ts +6 -3
  269. package/src/public/avm/serialization/bytecode_serialization.ts +17 -6
  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 +41 -0
  273. package/src/public/db_interfaces.ts +16 -1
  274. package/src/public/debug_fn_name.ts +26 -1
  275. package/src/public/executor_metrics.ts +2 -1
  276. package/src/public/executor_metrics_interface.ts +2 -1
  277. package/src/public/fixtures/amm_test.ts +2 -2
  278. package/src/public/fixtures/bulk_test.ts +1 -1
  279. package/src/public/fixtures/custom_bytecode_tester.ts +1 -1
  280. package/src/public/fixtures/custom_bytecode_tests.ts +24 -0
  281. package/src/public/fixtures/minimal_public_tx.ts +3 -4
  282. package/src/public/fixtures/public_tx_simulation_tester.ts +47 -16
  283. package/src/public/fixtures/simple_contract_data_source.ts +8 -9
  284. package/src/public/fixtures/token_test.ts +18 -10
  285. package/src/public/fixtures/utils.ts +4 -4
  286. package/src/public/fuzzing/avm_fuzzer_simulator.ts +233 -0
  287. package/src/public/fuzzing/avm_simulator_bin.ts +121 -0
  288. package/src/public/hinting_db_sources.ts +108 -10
  289. package/src/public/index.ts +6 -4
  290. package/src/public/public_db_sources.ts +93 -172
  291. package/src/public/public_processor/guarded_merkle_tree.ts +4 -3
  292. package/src/public/public_processor/public_processor.ts +63 -48
  293. package/src/public/public_tx_simulator/contract_provider_for_cpp.ts +116 -0
  294. package/src/public/public_tx_simulator/cpp_public_tx_simulator.ts +84 -57
  295. package/src/public/public_tx_simulator/cpp_public_tx_simulator_with_hinted_dbs.ts +132 -0
  296. package/src/public/public_tx_simulator/cpp_vs_ts_public_tx_simulator.ts +236 -0
  297. package/src/public/public_tx_simulator/dumping_cpp_public_tx_simulator.ts +81 -0
  298. package/src/public/public_tx_simulator/factories.ts +41 -0
  299. package/src/public/public_tx_simulator/index.ts +4 -0
  300. package/src/public/public_tx_simulator/measured_public_tx_simulator.ts +10 -14
  301. package/src/public/public_tx_simulator/public_tx_context.ts +9 -3
  302. package/src/public/public_tx_simulator/public_tx_simulator.ts +161 -193
  303. package/src/public/public_tx_simulator/public_tx_simulator_interface.ts +1 -2
  304. package/src/public/public_tx_simulator/telemetry_public_tx_simulator.ts +3 -3
  305. package/src/public/side_effect_trace.ts +1 -1
  306. package/src/public/side_effect_trace_interface.ts +1 -1
  307. package/src/public/state_manager/nullifiers.ts +1 -1
  308. package/src/public/state_manager/public_storage.ts +1 -1
  309. package/src/public/state_manager/state_manager.ts +14 -14
  310. package/src/public/test_executor_metrics.ts +7 -5
  311. package/dest/public/tx_contract_cache.d.ts +0 -41
  312. package/dest/public/tx_contract_cache.d.ts.map +0 -1
  313. package/dest/public/tx_contract_cache.js +0 -49
  314. package/src/public/tx_contract_cache.ts +0 -69
@@ -1,13 +1,20 @@
1
1
  import { MAX_NOTE_HASHES_PER_TX, MAX_NULLIFIERS_PER_TX, NULLIFIER_SUBTREE_HEIGHT } from '@aztec/constants';
2
2
  import { padArrayEnd } from '@aztec/foundation/collection';
3
- import { Fr } from '@aztec/foundation/fields';
3
+ import { Fr } from '@aztec/foundation/curves/bn254';
4
4
  import { createLogger } from '@aztec/foundation/log';
5
5
  import { sleep } from '@aztec/foundation/sleep';
6
6
  import { DateProvider, Timer, elapsed, executeTimeout } from '@aztec/foundation/timer';
7
7
  import { ProtocolContractAddress } from '@aztec/protocol-contracts';
8
8
  import { ContractClassPublishedEvent } from '@aztec/protocol-contracts/class-registry';
9
9
  import { computeFeePayerBalanceLeafSlot, computeFeePayerBalanceStorageSlot } from '@aztec/protocol-contracts/fee-juice';
10
- import { PublicDataWrite } from '@aztec/stdlib/avm';
10
+ import {
11
+ AvmCircuitInputs,
12
+ AvmCircuitPublicInputs,
13
+ AvmExecutionHints,
14
+ type AvmProvingRequest,
15
+ PublicDataWrite,
16
+ PublicSimulatorConfig,
17
+ } from '@aztec/stdlib/avm';
11
18
  import type { AztecAddress } from '@aztec/stdlib/aztec-address';
12
19
  import type { ContractDataSource } from '@aztec/stdlib/contract';
13
20
  import { computeTransactionFee } from '@aztec/stdlib/fees';
@@ -18,6 +25,7 @@ import type {
18
25
  PublicProcessorValidator,
19
26
  SequencerConfig,
20
27
  } from '@aztec/stdlib/interfaces/server';
28
+ import { ProvingRequestType } from '@aztec/stdlib/proofs';
21
29
  import { MerkleTreeId } from '@aztec/stdlib/trees';
22
30
  import {
23
31
  type FailedTx,
@@ -26,7 +34,6 @@ import {
26
34
  type ProcessedTx,
27
35
  StateReference,
28
36
  Tx,
29
- TxExecutionPhase,
30
37
  makeProcessedTxFromPrivateOnlyTx,
31
38
  makeProcessedTxFromTxWithPublicCalls,
32
39
  } from '@aztec/stdlib/tx';
@@ -44,9 +51,9 @@ import { AssertionError } from 'assert';
44
51
 
45
52
  import { PublicContractsDB, PublicTreesDB } from '../public_db_sources.js';
46
53
  import {
47
- type PublicTxSimulator,
48
54
  type PublicTxSimulatorConfig,
49
- TelemetryPublicTxSimulator,
55
+ type PublicTxSimulatorInterface,
56
+ TelemetryCppPublicTxSimulator,
50
57
  } from '../public_tx_simulator/index.js';
51
58
  import { GuardedMerkleTreeOperations } from './guarded_merkle_tree.js';
52
59
  import { PublicProcessorMetrics } from './public_processor_metrics.js';
@@ -70,23 +77,12 @@ export class PublicProcessorFactory {
70
77
  public create(
71
78
  merkleTree: MerkleTreeWriteOperations,
72
79
  globalVariables: GlobalVariables,
73
- config: {
74
- skipFeeEnforcement: boolean;
75
- clientInitiatedSimulation: boolean;
76
- proverId?: Fr;
77
- maxDebugLogMemoryReads?: number;
78
- },
80
+ config: PublicSimulatorConfig,
79
81
  ): PublicProcessor {
80
82
  const contractsDB = new PublicContractsDB(this.contractDataSource);
81
83
 
82
84
  const guardedFork = new GuardedMerkleTreeOperations(merkleTree);
83
- const publicTxSimulator = this.createPublicTxSimulator(guardedFork, contractsDB, globalVariables, {
84
- proverId: config.proverId,
85
- doMerkleOperations: true,
86
- skipFeeEnforcement: config.skipFeeEnforcement,
87
- clientInitiatedSimulation: config.clientInitiatedSimulation,
88
- maxDebugLogMemoryReads: config.maxDebugLogMemoryReads,
89
- });
85
+ const publicTxSimulator = this.createPublicTxSimulator(guardedFork, contractsDB, globalVariables, config);
90
86
 
91
87
  return new PublicProcessor(
92
88
  globalVariables,
@@ -103,8 +99,8 @@ export class PublicProcessorFactory {
103
99
  contractsDB: PublicContractsDB,
104
100
  globalVariables: GlobalVariables,
105
101
  config?: Partial<PublicTxSimulatorConfig>,
106
- ): PublicTxSimulator {
107
- return new TelemetryPublicTxSimulator(merkleTree, contractsDB, globalVariables, this.telemetryClient, config);
102
+ ): PublicTxSimulatorInterface {
103
+ return new TelemetryCppPublicTxSimulator(merkleTree, contractsDB, globalVariables, this.telemetryClient, config);
108
104
  }
109
105
  }
110
106
 
@@ -126,7 +122,7 @@ export class PublicProcessor implements Traceable {
126
122
  protected globalVariables: GlobalVariables,
127
123
  private guardedMerkleTree: GuardedMerkleTreeOperations,
128
124
  protected contractsDB: PublicContractsDB,
129
- protected publicTxSimulator: PublicTxSimulator,
125
+ protected publicTxSimulator: PublicTxSimulatorInterface,
130
126
  private dateProvider: DateProvider,
131
127
  telemetryClient: TelemetryClient = getTelemetryClient(),
132
128
  private log = createLogger('simulator:public-processor'),
@@ -232,12 +228,15 @@ export class PublicProcessor implements Traceable {
232
228
  // Note: We use the underlying fork here not the guarded one, this ensures that it's not impacted by stopping the guarded version
233
229
  const checkpoint = await ForkCheckpoint.new(this.guardedMerkleTree.getUnderlyingFork());
234
230
  const startStateReference = await this.guardedMerkleTree.getUnderlyingFork().getStateReference();
231
+ this.contractsDB.createCheckpoint();
235
232
 
236
233
  try {
237
234
  const [processedTx, returnValues] = await this.processTx(tx, deadline);
238
235
 
236
+ const txBlobFields = processedTx.txEffect.getNumBlobFields();
237
+
239
238
  // If the actual size of this tx would exceed block size, skip it
240
- const txSize = processedTx.txEffect.getDASize();
239
+ const txSize = txBlobFields * Fr.SIZE_IN_BYTES;
241
240
  if (maxBlockSize !== undefined && totalSizeInBytes + txSize > maxBlockSize) {
242
241
  this.log.debug(`Skipping processed tx ${txHash} sized ${txSize} due to max block size.`, {
243
242
  txHash,
@@ -247,11 +246,11 @@ export class PublicProcessor implements Traceable {
247
246
  });
248
247
  // Need to revert the checkpoint here and don't go any further
249
248
  await checkpoint.revert();
249
+ this.contractsDB.revertCheckpoint();
250
250
  continue;
251
251
  }
252
252
 
253
253
  // If the actual blob fields of this tx would exceed the limit, skip it
254
- const txBlobFields = processedTx.txEffect.toBlobFields().length;
255
254
  if (maxBlobFields !== undefined && totalBlobFields + txBlobFields > maxBlobFields) {
256
255
  this.log.debug(
257
256
  `Skipping processed tx ${txHash} with ${txBlobFields} blob fields due to max blob fields limit.`,
@@ -264,6 +263,7 @@ export class PublicProcessor implements Traceable {
264
263
  );
265
264
  // Need to revert the checkpoint here and don't go any further
266
265
  await checkpoint.revert();
266
+ this.contractsDB.revertCheckpoint();
267
267
  continue;
268
268
  }
269
269
 
@@ -298,6 +298,9 @@ export class PublicProcessor implements Traceable {
298
298
  // This needs to be done directly on the underlying fork as the guarded fork has been stopped.
299
299
  await this.guardedMerkleTree.getUnderlyingFork().revertAllCheckpoints();
300
300
 
301
+ // Revert any contracts added to the DB for the tx.
302
+ this.contractsDB.revertCheckpoint();
303
+
301
304
  // Ensure we're at the same state as when we started processing this tx.
302
305
  await this.checkWorldStateUnchanged(startStateReference, txHash, err);
303
306
 
@@ -308,6 +311,7 @@ export class PublicProcessor implements Traceable {
308
311
  // Roll back state to start of TX before proceeding to next TX
309
312
  await checkpoint.revert();
310
313
  await this.guardedMerkleTree.getUnderlyingFork().revertAllCheckpoints();
314
+ this.contractsDB.revertCheckpoint();
311
315
  const errorMessage = err instanceof Error || err instanceof AssertionError ? err.message : 'Unknown error';
312
316
  this.log.warn(`Failed to process tx ${txHash.toString()}: ${errorMessage} ${err?.stack}`);
313
317
  failed.push({ tx, error: err instanceof Error ? err : new Error(errorMessage) });
@@ -318,8 +322,7 @@ export class PublicProcessor implements Traceable {
318
322
  } finally {
319
323
  // Base case is we always commit the checkpoint. Using the ForkCheckpoint means this has no effect if the tx was previously reverted
320
324
  await checkpoint.commit();
321
- // The tx-level contracts cache should not live on to the next tx
322
- this.contractsDB.clearContractsForTx();
325
+ this.contractsDB.commitCheckpointOkIfNone();
323
326
  }
324
327
  }
325
328
 
@@ -507,10 +510,7 @@ export class PublicProcessor implements Traceable {
507
510
  // Fee payment insertion has already been done. Do the rest.
508
511
  await this.doTreeInsertionsForPrivateOnlyTx(processedTx);
509
512
 
510
- // Add any contracts registered/deployed in this private-only tx to the block-level cache
511
- // (add to tx-level cache and then commit to block-level cache)
512
513
  await this.contractsDB.addNewContracts(tx);
513
- this.contractsDB.commitContractsForTx();
514
514
 
515
515
  return [processedTx, undefined];
516
516
  }
@@ -521,21 +521,9 @@ export class PublicProcessor implements Traceable {
521
521
  private async processTxWithPublicCalls(tx: Tx): Promise<[ProcessedTx, NestedProcessReturnValues[]]> {
522
522
  const timer = new Timer();
523
523
 
524
- const { avmProvingRequest, gasUsed, revertCode, revertReason, processedPhases } =
525
- await this.publicTxSimulator.simulate(tx);
526
-
527
- if (!avmProvingRequest) {
528
- this.metrics.recordFailedTx();
529
- throw new Error('Avm proving result was not generated.');
530
- }
531
-
532
- processedPhases.forEach(phase => {
533
- if (phase.reverted) {
534
- this.metrics.recordRevertedPhase(phase.phase);
535
- } else {
536
- this.metrics.recordPhaseDuration(phase.phase, phase.durationMs ?? 0);
537
- }
538
- });
524
+ const result = await this.publicTxSimulator.simulate(tx);
525
+ // TODO: use the callStackMetadata here to extract more data about public execution
526
+ const { hints, publicInputs, publicTxEffect, gasUsed, revertCode /*callStackMetadata*/ } = result;
539
527
 
540
528
  const contractClassLogs = revertCode.isOK()
541
529
  ? tx.getContractClassLogs()
@@ -546,14 +534,41 @@ export class PublicProcessor implements Traceable {
546
534
  .map(log => ContractClassPublishedEvent.fromLog(log)),
547
535
  );
548
536
 
549
- const phaseCount = processedPhases.length;
537
+ // TODO(fcarreiro): remove phase count metric.
550
538
  const durationMs = timer.ms();
551
- this.metrics.recordTx(phaseCount, durationMs, gasUsed.publicGas);
539
+ this.metrics.recordTx(/*phaseCount=*/ 1, durationMs, gasUsed.publicGas);
540
+
541
+ // Extract the return values from the call stack metadata.
542
+ const appLogicReturnValues: NestedProcessReturnValues[] = result.getAppLogicReturnValues();
543
+ // Extract the revert reason from the call stack metadata.
544
+ const revertReason = result.findRevertReason();
545
+ // Create proving request if we have hints and public inputs.
546
+ const avmProvingRequest =
547
+ hints && publicInputs ? PublicProcessor.generateProvingRequest(publicInputs, hints) : undefined;
552
548
 
553
- const processedTx = makeProcessedTxFromTxWithPublicCalls(tx, avmProvingRequest, gasUsed, revertCode, revertReason);
549
+ const processedTx = makeProcessedTxFromTxWithPublicCalls(
550
+ tx,
551
+ this.globalVariables,
552
+ avmProvingRequest,
553
+ publicTxEffect,
554
+ gasUsed,
555
+ revertCode,
556
+ revertReason,
557
+ );
554
558
 
555
- const returnValues = processedPhases.find(({ phase }) => phase === TxExecutionPhase.APP_LOGIC)?.returnValues ?? [];
559
+ return [processedTx, appLogicReturnValues];
560
+ }
556
561
 
557
- return [processedTx, returnValues];
562
+ /**
563
+ * Generate the proving request for the AVM circuit.
564
+ */
565
+ private static generateProvingRequest(
566
+ publicInputs: AvmCircuitPublicInputs,
567
+ hints: AvmExecutionHints = AvmExecutionHints.empty(),
568
+ ): AvmProvingRequest {
569
+ return {
570
+ type: ProvingRequestType.PUBLIC_VM,
571
+ inputs: new AvmCircuitInputs(hints, publicInputs),
572
+ };
558
573
  }
559
574
  }
@@ -0,0 +1,116 @@
1
+ import { Fr } from '@aztec/foundation/curves/bn254';
2
+ import { type Logger, createLogger } from '@aztec/foundation/log';
3
+ import type { ContractProvider } from '@aztec/native';
4
+ import { FunctionSelector } from '@aztec/stdlib/abi';
5
+ import { deserializeFromMessagePack, serializeWithMessagePack } from '@aztec/stdlib/avm';
6
+ import { AztecAddress } from '@aztec/stdlib/aztec-address';
7
+ import { ContractDeploymentData } from '@aztec/stdlib/contract';
8
+ import type { GlobalVariables } from '@aztec/stdlib/tx';
9
+
10
+ import type { PublicContractsDB } from '../public_db_sources.js';
11
+
12
+ export class ContractProviderForCpp implements ContractProvider {
13
+ private log: Logger = createLogger('simulator:contract_provider_for_cpp');
14
+
15
+ constructor(
16
+ private contractsDB: PublicContractsDB,
17
+ private globalVariables: GlobalVariables,
18
+ ) {}
19
+
20
+ public getContractInstance = async (address: string): Promise<Buffer | undefined> => {
21
+ this.log.debug(`Contract provider callback: getContractInstance(${address})`);
22
+
23
+ const aztecAddr = AztecAddress.fromString(address);
24
+
25
+ const instance = await this.contractsDB.getContractInstance(aztecAddr, this.globalVariables.timestamp);
26
+
27
+ if (!instance) {
28
+ this.log.debug(`Contract instance not found: ${address}`);
29
+ return undefined;
30
+ }
31
+
32
+ return serializeWithMessagePack(instance);
33
+ };
34
+
35
+ public getContractClass = async (classId: string): Promise<Buffer | undefined> => {
36
+ this.log.debug(`Contract provider callback: getContractClass(${classId})`);
37
+
38
+ // Parse classId string to Fr
39
+ const classIdFr = Fr.fromString(classId);
40
+
41
+ // Fetch contract class from the contracts DB
42
+ const contractClass = await this.contractsDB.getContractClass(classIdFr);
43
+
44
+ if (!contractClass) {
45
+ this.log.debug(`Contract class not found: ${classId}`);
46
+ return undefined;
47
+ }
48
+
49
+ return serializeWithMessagePack(contractClass);
50
+ };
51
+
52
+ public addContracts = async (contractDeploymentDataBuffer: Buffer): Promise<void> => {
53
+ this.log.debug(`Contract provider callback: addContracts`);
54
+
55
+ const rawData: any = deserializeFromMessagePack(contractDeploymentDataBuffer);
56
+
57
+ // Construct ContractDeploymentData from plain object.
58
+ const contractDeploymentData = ContractDeploymentData.fromPlainObject(rawData);
59
+
60
+ // Add contracts to the contracts DB
61
+ this.log.debug(`Calling contractsDB.addContracts`);
62
+ await this.contractsDB.addContracts(contractDeploymentData);
63
+ };
64
+
65
+ public getBytecodeCommitment = async (classId: string): Promise<Buffer | undefined> => {
66
+ this.log.debug(`Contract provider callback: getBytecodeCommitment(${classId})`);
67
+
68
+ // Parse classId string to Fr
69
+ const classIdFr = Fr.fromString(classId);
70
+
71
+ // Fetch bytecode commitment from the contracts DB
72
+ const commitment = await this.contractsDB.getBytecodeCommitment(classIdFr);
73
+
74
+ if (!commitment) {
75
+ this.log.debug(`Bytecode commitment not found: ${classId}`);
76
+ return undefined;
77
+ }
78
+
79
+ // Serialize the Fr to buffer
80
+ return serializeWithMessagePack(commitment);
81
+ };
82
+
83
+ public getDebugFunctionName = async (address: string, selector: string): Promise<string | undefined> => {
84
+ this.log.debug(`Contract provider callback: getDebugFunctionName(${address}, ${selector})`);
85
+
86
+ // Parse address and selector strings
87
+ const aztecAddr = AztecAddress.fromString(address);
88
+ const selectorFr = Fr.fromString(selector);
89
+ const functionSelector = FunctionSelector.fromField(selectorFr);
90
+
91
+ // Fetch debug function name from the contracts DB
92
+ const name = await this.contractsDB.getDebugFunctionName(aztecAddr, functionSelector);
93
+
94
+ if (!name) {
95
+ this.log.debug(`Debug function name not found for ${address}:${selector}`);
96
+ return undefined;
97
+ }
98
+
99
+ return name;
100
+ };
101
+
102
+ public createCheckpoint = (): Promise<void> => {
103
+ this.log.debug(`Contract provider callback: createCheckpoint`);
104
+ return Promise.resolve(this.contractsDB.createCheckpoint());
105
+ };
106
+
107
+ public commitCheckpoint = (): Promise<void> => {
108
+ this.log.debug(`Contract provider callback: commitCheckpoint`);
109
+ return Promise.resolve(this.contractsDB.commitCheckpoint());
110
+ };
111
+
112
+ public revertCheckpoint = (): Promise<void> => {
113
+ this.log.debug(`Contract provider callback: revertCheckpoint`);
114
+ return Promise.resolve(this.contractsDB.revertCheckpoint());
115
+ };
116
+ }
@@ -1,116 +1,123 @@
1
- import { type Logger, createLogger } from '@aztec/foundation/log';
2
- import { avmSimulateWithHintedDbs } from '@aztec/native';
3
- import { deserializeFromMessagePack } from '@aztec/stdlib/avm';
1
+ import { type Logger, createLogger, logLevel } from '@aztec/foundation/log';
2
+ import { avmSimulate } from '@aztec/native';
3
+ import { ProtocolContractsList } from '@aztec/protocol-contracts';
4
+ import {
5
+ AvmFastSimulationInputs,
6
+ AvmTxHint,
7
+ type PublicSimulatorConfig,
8
+ PublicTxResult,
9
+ deserializeFromMessagePack,
10
+ } from '@aztec/stdlib/avm';
4
11
  import { SimulationError } from '@aztec/stdlib/errors';
5
12
  import type { MerkleTreeWriteOperations } from '@aztec/stdlib/trees';
6
13
  import type { GlobalVariables, Tx } from '@aztec/stdlib/tx';
14
+ import { WorldStateRevisionWithHandle } from '@aztec/stdlib/world-state';
15
+ import { type TelemetryClient, type Tracer, getTelemetryClient } from '@aztec/telemetry-client';
7
16
 
17
+ import { strict as assert } from 'assert';
18
+
19
+ import { ExecutorMetrics } from '../executor_metrics.js';
8
20
  import type { ExecutorMetricsInterface } from '../executor_metrics_interface.js';
9
21
  import type { PublicContractsDB } from '../public_db_sources.js';
10
- import { type PublicTxResult, PublicTxSimulator, type PublicTxSimulatorConfig } from './public_tx_simulator.js';
22
+ import { ContractProviderForCpp } from './contract_provider_for_cpp.js';
23
+ import { PublicTxSimulator } from './public_tx_simulator.js';
11
24
  import type {
12
25
  MeasuredPublicTxSimulatorInterface,
13
26
  PublicTxSimulatorInterface,
14
27
  } from './public_tx_simulator_interface.js';
15
28
 
16
29
  /**
17
- * C++ implementation of PublicTxSimulator using pre-collected hints.
18
- * This implementation runs TS simulation first to collect all hints,
19
- * then passes the complete AvmCircuitInputs (hints + public inputs)
20
- * to C++ to run hinted simulation.
30
+ * C++ implementation of PublicTxSimulator using the C++ simulator.
31
+ * The C++ simulator accesses the world state directly/natively within C++.
32
+ * For contract DB accesses, it makes callbacks through NAPI back to the TS PublicContractsDB cache.
21
33
  */
22
- export class CppPublicTxSimulatorHintedDbs extends PublicTxSimulator implements PublicTxSimulatorInterface {
34
+ export class CppPublicTxSimulator extends PublicTxSimulator implements PublicTxSimulatorInterface {
23
35
  protected override log: Logger;
24
36
 
25
37
  constructor(
26
38
  merkleTree: MerkleTreeWriteOperations,
27
39
  contractsDB: PublicContractsDB,
28
40
  globalVariables: GlobalVariables,
29
- config?: Partial<PublicTxSimulatorConfig>,
41
+ config?: Partial<PublicSimulatorConfig>,
30
42
  ) {
31
43
  super(merkleTree, contractsDB, globalVariables, config);
32
- this.log = createLogger(`simulator:cpp_public_tx_simulator_hinted_dbs`);
44
+ this.log = createLogger(`simulator:cpp_public_tx_simulator`);
33
45
  }
34
46
 
35
47
  /**
36
- * Simulate a transaction's public portion using the C++ vm2 simulator with hinted DBs.
37
- *
38
- * This implementation:
39
- * 1. Runs the full TypeScript simulation to generate AvmCircuitInputs (hints + public inputs)
40
- * 2. Passes the complete AvmCircuitInputs to C++ to run hinted simulation
48
+ * Simulate a transaction's public portion using the C++ avvm simulator.
41
49
  *
42
50
  * @param tx - The transaction to simulate.
43
51
  * @returns The result of the transaction's public execution.
44
52
  */
45
53
  public override async simulate(tx: Tx): Promise<PublicTxResult> {
46
54
  const txHash = this.computeTxHash(tx);
47
- this.log.debug(`C++ hinted DB simulation of ${tx.publicFunctionCalldata.length} public calls for tx ${txHash}`, {
55
+ this.log.debug(`C++ simulation of ${tx.publicFunctionCalldata.length} public calls for tx ${txHash}`, {
48
56
  txHash,
49
57
  });
50
58
 
51
- // First, run TS simulation to generate hints and public inputs
52
- this.log.debug(`Running TS simulation for tx ${txHash}`);
59
+ // Using the "as WorldStateRevisionWithHandle" is a bit of a "trust me bro", hence the assert.
60
+ let wsRevision = this.merkleTree.getRevision();
61
+ assert(
62
+ wsRevision instanceof WorldStateRevisionWithHandle,
63
+ 'CppPublicTxSimulator a real NativeWorldStateInstance with a handle to the C++ WorldState object',
64
+ );
65
+ const wsCppHandle = (wsRevision as WorldStateRevisionWithHandle).handle;
66
+ wsRevision = wsRevision.toWorldStateRevision(); // for msgpack serialization, we don't include the handle in the type
53
67
 
54
- let tsResult: PublicTxResult;
55
- try {
56
- // Run the full TypeScript simulation using the parent class
57
- // This will modify the merkle tree with the transaction's state changes
58
- tsResult = await super.simulate(tx);
59
- this.log.debug(`TS simulation succeeded for tx ${txHash}`);
60
- } catch (error: any) {
61
- // If TS simulation fails, clear any partial contract additions and re-throw the error
62
- this.contractsDB.clearContractsForTx();
63
- throw error;
64
- }
68
+ this.log.trace(`Running C++ simulation with world state revision ${JSON.stringify(wsRevision)}`);
65
69
 
66
- // Extract the full AvmCircuitInputs from the TS result
67
- const avmCircuitInputs = tsResult.avmProvingRequest.inputs;
70
+ // Create the fast simulation inputs
71
+ const txHint = AvmTxHint.fromTx(tx, this.globalVariables.gasFees);
72
+ const protocolContracts = ProtocolContractsList;
73
+ const fastSimInputs = new AvmFastSimulationInputs(
74
+ wsRevision,
75
+ this.config,
76
+ txHint,
77
+ this.globalVariables,
78
+ protocolContracts,
79
+ );
68
80
 
69
- // Second, run C++ simulation with hinted DBs
70
- this.log.debug(`Running C++ simulation with hinted DBs for tx ${txHash}`);
81
+ // Create contract provider for callbacks to TypeScript PublicContractsDB from C++
82
+ const contractProvider = new ContractProviderForCpp(this.contractsDB, this.globalVariables);
71
83
 
72
84
  // Serialize to msgpack and call the C++ simulator
73
- const inputBuffer = avmCircuitInputs.serializeWithMessagePack();
85
+ this.log.trace(`Serializing fast simulation inputs to msgpack...`);
86
+ const inputBuffer = fastSimInputs.serializeWithMessagePack();
74
87
 
75
88
  let resultBuffer: Buffer;
76
89
  try {
77
- resultBuffer = await avmSimulateWithHintedDbs(inputBuffer);
90
+ this.log.debug(`Calling C++ simulator for tx ${txHash}`);
91
+ resultBuffer = await avmSimulate(inputBuffer, contractProvider, wsCppHandle, logLevel);
78
92
  } catch (error: any) {
79
- throw new SimulationError(`C++ hinted simulation failed: ${error.message}`, []);
93
+ throw new SimulationError(`C++ simulation failed: ${error.message}`, []);
80
94
  }
81
95
 
96
+ // If we've reached this point, C++ succeeded during simulation,
97
+
82
98
  // Deserialize the msgpack result
83
- const _success = deserializeFromMessagePack<boolean>(resultBuffer);
99
+ this.log.trace(`Deserializing C++ from buffer (size: ${resultBuffer.length})...`);
100
+ const cppResultJSON: object = deserializeFromMessagePack(resultBuffer);
101
+ this.log.trace(`Deserializing C++ result to PublicTxResult...`);
102
+ const cppResult = PublicTxResult.fromPlainObject(cppResultJSON);
84
103
 
85
- this.log.debug(`C++ hinted simulation completed for tx ${txHash}`, {
104
+ this.log.trace(`C++ simulation completed for tx ${txHash}`, {
86
105
  txHash,
87
- reverted: !tsResult.revertCode.isOK(),
88
- tsGasUsed: tsResult.gasUsed.totalGas.l2Gas,
89
- cppGasUsed: tsResult.gasUsed.totalGas.l2Gas,
106
+ reverted: !cppResult.revertCode.isOK(),
107
+ cppGasUsed: cppResult.gasUsed.totalGas.l2Gas,
90
108
  });
91
109
 
92
- // TODO(dbanks12): C++ should return PublicTxResult (or something similar)
93
- return tsResult;
110
+ return cppResult;
94
111
  }
95
112
  }
96
113
 
97
- /**
98
- * Class to record metrics for simulation.
99
- *
100
- * Note(dbanks12): We might not be able to collect all the same metrics in C++ as we do in TS!
101
- * Unless we move some of the metrics collection to C++, we don't have inner functions exposed
102
- * to TS for tracking.
103
- */
104
- export class MeasuredCppPublicTxSimulatorHintedDbs
105
- extends CppPublicTxSimulatorHintedDbs
106
- implements MeasuredPublicTxSimulatorInterface
107
- {
114
+ export class MeasuredCppPublicTxSimulator extends CppPublicTxSimulator implements MeasuredPublicTxSimulatorInterface {
108
115
  constructor(
109
116
  merkleTree: MerkleTreeWriteOperations,
110
117
  contractsDB: PublicContractsDB,
111
118
  globalVariables: GlobalVariables,
112
119
  protected readonly metrics: ExecutorMetricsInterface,
113
- config?: Partial<PublicTxSimulatorConfig>,
120
+ config?: Partial<PublicSimulatorConfig>,
114
121
  ) {
115
122
  super(merkleTree, contractsDB, globalVariables, config);
116
123
  }
@@ -121,8 +128,28 @@ export class MeasuredCppPublicTxSimulatorHintedDbs
121
128
  try {
122
129
  result = await super.simulate(tx);
123
130
  } finally {
124
- this.metrics.stopRecordingTxSimulation(txLabel, result?.revertCode);
131
+ this.metrics.stopRecordingTxSimulation(txLabel, result?.gasUsed, result?.revertCode);
125
132
  }
126
133
  return result;
127
134
  }
128
135
  }
136
+
137
+ /**
138
+ * A C++ public tx simulator that tracks runtime/production metrics with telemetry.
139
+ */
140
+ export class TelemetryCppPublicTxSimulator extends MeasuredCppPublicTxSimulator {
141
+ /* tracer needed by trackSpans */
142
+ public readonly tracer: Tracer;
143
+
144
+ constructor(
145
+ merkleTree: MerkleTreeWriteOperations,
146
+ contractsDB: PublicContractsDB,
147
+ globalVariables: GlobalVariables,
148
+ telemetryClient: TelemetryClient = getTelemetryClient(),
149
+ config?: Partial<PublicSimulatorConfig>,
150
+ ) {
151
+ const metrics = new ExecutorMetrics(telemetryClient, 'CppPublicTxSimulator');
152
+ super(merkleTree, contractsDB, globalVariables, metrics, config);
153
+ this.tracer = metrics.tracer;
154
+ }
155
+ }