@aztec/simulator 0.0.1-commit.5476d83 → 0.0.1-commit.59e663cd

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 (295) 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/deserialize.d.ts +2 -2
  5. package/dest/private/acvm/deserialize.d.ts.map +1 -1
  6. package/dest/private/acvm/deserialize.js +1 -1
  7. package/dest/private/acvm/serialize.d.ts +2 -2
  8. package/dest/private/acvm/serialize.d.ts.map +1 -1
  9. package/dest/private/acvm/serialize.js +1 -1
  10. package/dest/private/circuit_recording/circuit_recorder.d.ts +1 -1
  11. package/dest/private/circuit_recording/circuit_recorder.d.ts.map +1 -1
  12. package/dest/private/circuit_recording/circuit_recorder.js +16 -15
  13. package/dest/public/avm/avm_context.d.ts +3 -3
  14. package/dest/public/avm/avm_context.d.ts.map +1 -1
  15. package/dest/public/avm/avm_contract_call_result.d.ts +6 -6
  16. package/dest/public/avm/avm_contract_call_result.d.ts.map +1 -1
  17. package/dest/public/avm/avm_contract_call_result.js +3 -3
  18. package/dest/public/avm/avm_execution_environment.d.ts +7 -6
  19. package/dest/public/avm/avm_execution_environment.d.ts.map +1 -1
  20. package/dest/public/avm/avm_execution_environment.js +1 -1
  21. package/dest/public/avm/avm_gas.d.ts +1 -1
  22. package/dest/public/avm/avm_gas.d.ts.map +1 -1
  23. package/dest/public/avm/avm_machine_state.d.ts +7 -6
  24. package/dest/public/avm/avm_machine_state.d.ts.map +1 -1
  25. package/dest/public/avm/avm_machine_state.js +3 -2
  26. package/dest/public/avm/avm_memory_types.d.ts +2 -2
  27. package/dest/public/avm/avm_memory_types.d.ts.map +1 -1
  28. package/dest/public/avm/avm_memory_types.js +4 -1
  29. package/dest/public/avm/avm_simulator.d.ts +4 -3
  30. package/dest/public/avm/avm_simulator.d.ts.map +1 -1
  31. package/dest/public/avm/avm_simulator.js +11 -9
  32. package/dest/public/avm/calldata.d.ts +51 -0
  33. package/dest/public/avm/calldata.d.ts.map +1 -0
  34. package/dest/public/avm/calldata.js +63 -0
  35. package/dest/public/avm/errors.d.ts +8 -2
  36. package/dest/public/avm/errors.d.ts.map +1 -1
  37. package/dest/public/avm/errors.js +14 -2
  38. package/dest/public/avm/fixtures/avm_simulation_tester.d.ts +1 -1
  39. package/dest/public/avm/fixtures/avm_simulation_tester.d.ts.map +1 -1
  40. package/dest/public/avm/fixtures/avm_simulation_tester.js +4 -3
  41. package/dest/public/avm/fixtures/base_avm_simulation_tester.d.ts +2 -2
  42. package/dest/public/avm/fixtures/base_avm_simulation_tester.d.ts.map +1 -1
  43. package/dest/public/avm/fixtures/base_avm_simulation_tester.js +1 -1
  44. package/dest/public/avm/fixtures/initializers.d.ts +2 -2
  45. package/dest/public/avm/fixtures/initializers.d.ts.map +1 -1
  46. package/dest/public/avm/fixtures/initializers.js +5 -4
  47. package/dest/public/avm/fixtures/utils.d.ts +4 -3
  48. package/dest/public/avm/fixtures/utils.d.ts.map +1 -1
  49. package/dest/public/avm/fixtures/utils.js +3 -2
  50. package/dest/public/avm/opcodes/accrued_substate.d.ts +15 -15
  51. package/dest/public/avm/opcodes/accrued_substate.d.ts.map +1 -1
  52. package/dest/public/avm/opcodes/accrued_substate.js +33 -29
  53. package/dest/public/avm/opcodes/addressing_mode.js +2 -2
  54. package/dest/public/avm/opcodes/arithmetic.d.ts +10 -8
  55. package/dest/public/avm/opcodes/arithmetic.d.ts.map +1 -1
  56. package/dest/public/avm/opcodes/arithmetic.js +12 -2
  57. package/dest/public/avm/opcodes/bitwise.d.ts +7 -7
  58. package/dest/public/avm/opcodes/bitwise.d.ts.map +1 -1
  59. package/dest/public/avm/opcodes/bitwise.js +5 -5
  60. package/dest/public/avm/opcodes/comparators.d.ts +4 -4
  61. package/dest/public/avm/opcodes/comparators.d.ts.map +1 -1
  62. package/dest/public/avm/opcodes/comparators.js +1 -1
  63. package/dest/public/avm/opcodes/contract.d.ts +3 -3
  64. package/dest/public/avm/opcodes/contract.d.ts.map +1 -1
  65. package/dest/public/avm/opcodes/contract.js +8 -8
  66. package/dest/public/avm/opcodes/control_flow.d.ts +3 -3
  67. package/dest/public/avm/opcodes/control_flow.d.ts.map +1 -1
  68. package/dest/public/avm/opcodes/control_flow.js +4 -4
  69. package/dest/public/avm/opcodes/conversion.d.ts +3 -3
  70. package/dest/public/avm/opcodes/conversion.d.ts.map +1 -1
  71. package/dest/public/avm/opcodes/conversion.js +4 -4
  72. package/dest/public/avm/opcodes/ec_add.d.ts +4 -4
  73. package/dest/public/avm/opcodes/ec_add.d.ts.map +1 -1
  74. package/dest/public/avm/opcodes/ec_add.js +17 -8
  75. package/dest/public/avm/opcodes/environment_getters.d.ts +5 -5
  76. package/dest/public/avm/opcodes/environment_getters.d.ts.map +1 -1
  77. package/dest/public/avm/opcodes/environment_getters.js +6 -6
  78. package/dest/public/avm/opcodes/external_calls.d.ts +9 -9
  79. package/dest/public/avm/opcodes/external_calls.d.ts.map +1 -1
  80. package/dest/public/avm/opcodes/external_calls.js +23 -22
  81. package/dest/public/avm/opcodes/hashing.d.ts +8 -8
  82. package/dest/public/avm/opcodes/hashing.d.ts.map +1 -1
  83. package/dest/public/avm/opcodes/hashing.js +21 -16
  84. package/dest/public/avm/opcodes/instruction_impl.d.ts +4 -4
  85. package/dest/public/avm/opcodes/instruction_impl.d.ts.map +1 -1
  86. package/dest/public/avm/opcodes/instruction_impl.js +4 -4
  87. package/dest/public/avm/opcodes/memory.d.ts +14 -14
  88. package/dest/public/avm/opcodes/memory.d.ts.map +1 -1
  89. package/dest/public/avm/opcodes/memory.js +26 -26
  90. package/dest/public/avm/opcodes/misc.d.ts +3 -3
  91. package/dest/public/avm/opcodes/misc.d.ts.map +1 -1
  92. package/dest/public/avm/opcodes/misc.js +6 -6
  93. package/dest/public/avm/opcodes/storage.d.ts +16 -15
  94. package/dest/public/avm/opcodes/storage.d.ts.map +1 -1
  95. package/dest/public/avm/opcodes/storage.js +34 -24
  96. package/dest/public/avm/revert_reason.d.ts +2 -2
  97. package/dest/public/avm/revert_reason.d.ts.map +1 -1
  98. package/dest/public/avm/revert_reason.js +3 -2
  99. package/dest/public/avm/serialization/bytecode_serialization.d.ts +1 -1
  100. package/dest/public/avm/serialization/bytecode_serialization.d.ts.map +1 -1
  101. package/dest/public/avm/serialization/bytecode_serialization.js +9 -6
  102. package/dest/public/avm/serialization/instruction_serialization.js +1 -1
  103. package/dest/public/avm/test_utils.d.ts +2 -2
  104. package/dest/public/avm/test_utils.d.ts.map +1 -1
  105. package/dest/public/avm/test_utils.js +1 -1
  106. package/dest/public/contracts_db_checkpoint.d.ts +2 -2
  107. package/dest/public/contracts_db_checkpoint.d.ts.map +1 -1
  108. package/dest/public/db_interfaces.d.ts +2 -2
  109. package/dest/public/db_interfaces.d.ts.map +1 -1
  110. package/dest/public/debug_fn_name.d.ts +16 -3
  111. package/dest/public/debug_fn_name.d.ts.map +1 -1
  112. package/dest/public/debug_fn_name.js +31 -3
  113. package/dest/public/executor_metrics.d.ts +1 -1
  114. package/dest/public/executor_metrics.d.ts.map +1 -1
  115. package/dest/public/executor_metrics.js +8 -34
  116. package/dest/public/fixtures/amm_test.js +2 -2
  117. package/dest/public/fixtures/bulk_test.d.ts +3 -3
  118. package/dest/public/fixtures/bulk_test.d.ts.map +1 -1
  119. package/dest/public/fixtures/bulk_test.js +5 -69
  120. package/dest/public/fixtures/custom_bytecode_tester.d.ts +28 -6
  121. package/dest/public/fixtures/custom_bytecode_tester.d.ts.map +1 -1
  122. package/dest/public/fixtures/custom_bytecode_tester.js +36 -12
  123. package/dest/public/fixtures/custom_bytecode_tests.d.ts +11 -8
  124. package/dest/public/fixtures/custom_bytecode_tests.d.ts.map +1 -1
  125. package/dest/public/fixtures/custom_bytecode_tests.js +83 -18
  126. package/dest/public/fixtures/index.d.ts +4 -2
  127. package/dest/public/fixtures/index.d.ts.map +1 -1
  128. package/dest/public/fixtures/index.js +3 -1
  129. package/dest/public/fixtures/minimal_public_tx.d.ts +2 -7
  130. package/dest/public/fixtures/minimal_public_tx.d.ts.map +1 -1
  131. package/dest/public/fixtures/minimal_public_tx.js +4 -14
  132. package/dest/public/fixtures/opcode_spammer.d.ts +123 -0
  133. package/dest/public/fixtures/opcode_spammer.d.ts.map +1 -0
  134. package/dest/public/fixtures/opcode_spammer.js +1693 -0
  135. package/dest/public/fixtures/public_tx_simulation_tester.d.ts +22 -3
  136. package/dest/public/fixtures/public_tx_simulation_tester.d.ts.map +1 -1
  137. package/dest/public/fixtures/public_tx_simulation_tester.js +50 -13
  138. package/dest/public/fixtures/simple_contract_data_source.d.ts +5 -4
  139. package/dest/public/fixtures/simple_contract_data_source.d.ts.map +1 -1
  140. package/dest/public/fixtures/simple_contract_data_source.js +4 -4
  141. package/dest/public/fixtures/token_test.d.ts +6 -2
  142. package/dest/public/fixtures/token_test.d.ts.map +1 -1
  143. package/dest/public/fixtures/token_test.js +13 -11
  144. package/dest/public/fixtures/utils.d.ts +2 -2
  145. package/dest/public/fixtures/utils.d.ts.map +1 -1
  146. package/dest/public/fixtures/utils.js +4 -3
  147. package/dest/public/fuzzing/avm_fuzzer_simulator.d.ts +60 -0
  148. package/dest/public/fuzzing/avm_fuzzer_simulator.d.ts.map +1 -0
  149. package/dest/public/fuzzing/avm_fuzzer_simulator.js +171 -0
  150. package/dest/public/fuzzing/avm_simulator_bin.d.ts +2 -0
  151. package/dest/public/fuzzing/avm_simulator_bin.d.ts.map +1 -0
  152. package/dest/public/fuzzing/avm_simulator_bin.js +118 -0
  153. package/dest/public/hinting_db_sources.d.ts +5 -3
  154. package/dest/public/hinting_db_sources.d.ts.map +1 -1
  155. package/dest/public/hinting_db_sources.js +7 -2
  156. package/dest/public/index.d.ts +2 -2
  157. package/dest/public/index.d.ts.map +1 -1
  158. package/dest/public/index.js +1 -1
  159. package/dest/public/public_db_sources.d.ts +2 -2
  160. package/dest/public/public_db_sources.d.ts.map +1 -1
  161. package/dest/public/public_db_sources.js +1 -1
  162. package/dest/public/public_processor/guarded_merkle_tree.d.ts +4 -2
  163. package/dest/public/public_processor/guarded_merkle_tree.d.ts.map +1 -1
  164. package/dest/public/public_processor/guarded_merkle_tree.js +5 -0
  165. package/dest/public/public_processor/public_processor.d.ts +6 -6
  166. package/dest/public/public_processor/public_processor.d.ts.map +1 -1
  167. package/dest/public/public_processor/public_processor.js +437 -43
  168. package/dest/public/public_processor/public_processor_metrics.d.ts +1 -1
  169. package/dest/public/public_processor/public_processor_metrics.d.ts.map +1 -1
  170. package/dest/public/public_processor/public_processor_metrics.js +12 -45
  171. package/dest/public/public_tx_simulator/contract_provider_for_cpp.d.ts +1 -13
  172. package/dest/public/public_tx_simulator/contract_provider_for_cpp.d.ts.map +1 -1
  173. package/dest/public/public_tx_simulator/contract_provider_for_cpp.js +18 -53
  174. package/dest/public/public_tx_simulator/cpp_public_tx_simulator.d.ts +21 -34
  175. package/dest/public/public_tx_simulator/cpp_public_tx_simulator.d.ts.map +1 -1
  176. package/dest/public/public_tx_simulator/cpp_public_tx_simulator.js +61 -139
  177. package/dest/public/public_tx_simulator/cpp_public_tx_simulator_with_hinted_dbs.d.ts +42 -0
  178. package/dest/public/public_tx_simulator/cpp_public_tx_simulator_with_hinted_dbs.d.ts.map +1 -0
  179. package/dest/public/public_tx_simulator/cpp_public_tx_simulator_with_hinted_dbs.js +86 -0
  180. package/dest/public/public_tx_simulator/cpp_vs_ts_public_tx_simulator.d.ts +30 -0
  181. package/dest/public/public_tx_simulator/cpp_vs_ts_public_tx_simulator.d.ts.map +1 -0
  182. package/dest/public/public_tx_simulator/cpp_vs_ts_public_tx_simulator.js +171 -0
  183. package/dest/public/public_tx_simulator/dumping_cpp_public_tx_simulator.d.ts +22 -0
  184. package/dest/public/public_tx_simulator/dumping_cpp_public_tx_simulator.d.ts.map +1 -0
  185. package/dest/public/public_tx_simulator/dumping_cpp_public_tx_simulator.js +52 -0
  186. package/dest/public/public_tx_simulator/factories.d.ts +13 -0
  187. package/dest/public/public_tx_simulator/factories.d.ts.map +1 -0
  188. package/dest/public/public_tx_simulator/factories.js +28 -0
  189. package/dest/public/public_tx_simulator/index.d.ts +4 -1
  190. package/dest/public/public_tx_simulator/index.d.ts.map +1 -1
  191. package/dest/public/public_tx_simulator/index.js +3 -0
  192. package/dest/public/public_tx_simulator/measured_public_tx_simulator.d.ts +3 -3
  193. package/dest/public/public_tx_simulator/measured_public_tx_simulator.d.ts.map +1 -1
  194. package/dest/public/public_tx_simulator/public_tx_context.d.ts +2 -2
  195. package/dest/public/public_tx_simulator/public_tx_context.d.ts.map +1 -1
  196. package/dest/public/public_tx_simulator/public_tx_context.js +1 -1
  197. package/dest/public/public_tx_simulator/public_tx_simulator.d.ts +6 -5
  198. package/dest/public/public_tx_simulator/public_tx_simulator.d.ts.map +1 -1
  199. package/dest/public/public_tx_simulator/public_tx_simulator.js +20 -11
  200. package/dest/public/public_tx_simulator/public_tx_simulator_interface.d.ts +24 -1
  201. package/dest/public/public_tx_simulator/public_tx_simulator_interface.d.ts.map +1 -1
  202. package/dest/public/public_tx_simulator/telemetry_public_tx_simulator.d.ts +2 -2
  203. package/dest/public/public_tx_simulator/telemetry_public_tx_simulator.d.ts.map +1 -1
  204. package/dest/public/public_tx_simulator/telemetry_public_tx_simulator.js +395 -19
  205. package/dest/public/side_effect_trace.d.ts +3 -2
  206. package/dest/public/side_effect_trace.d.ts.map +1 -1
  207. package/dest/public/side_effect_trace.js +1 -1
  208. package/dest/public/side_effect_trace_interface.d.ts +2 -2
  209. package/dest/public/side_effect_trace_interface.d.ts.map +1 -1
  210. package/dest/public/state_manager/nullifiers.d.ts +2 -2
  211. package/dest/public/state_manager/nullifiers.d.ts.map +1 -1
  212. package/dest/public/state_manager/public_storage.d.ts +2 -2
  213. package/dest/public/state_manager/public_storage.d.ts.map +1 -1
  214. package/dest/public/state_manager/public_storage.js +1 -1
  215. package/dest/public/state_manager/state_manager.d.ts +7 -2
  216. package/dest/public/state_manager/state_manager.d.ts.map +1 -1
  217. package/dest/public/state_manager/state_manager.js +7 -4
  218. package/package.json +20 -20
  219. package/src/common/errors.ts +1 -1
  220. package/src/private/acvm/deserialize.ts +1 -1
  221. package/src/private/acvm/serialize.ts +1 -1
  222. package/src/private/circuit_recording/circuit_recorder.ts +17 -16
  223. package/src/public/avm/avm_context.ts +2 -2
  224. package/src/public/avm/avm_contract_call_result.ts +8 -6
  225. package/src/public/avm/avm_execution_environment.ts +10 -5
  226. package/src/public/avm/avm_gas.ts +3 -3
  227. package/src/public/avm/avm_machine_state.ts +7 -6
  228. package/src/public/avm/avm_memory_types.ts +5 -1
  229. package/src/public/avm/avm_simulator.ts +16 -10
  230. package/src/public/avm/calldata.ts +100 -0
  231. package/src/public/avm/errors.ts +17 -3
  232. package/src/public/avm/fixtures/avm_simulation_tester.ts +9 -3
  233. package/src/public/avm/fixtures/base_avm_simulation_tester.ts +1 -1
  234. package/src/public/avm/fixtures/initializers.ts +5 -4
  235. package/src/public/avm/fixtures/utils.ts +3 -2
  236. package/src/public/avm/opcodes/accrued_substate.ts +21 -15
  237. package/src/public/avm/opcodes/addressing_mode.ts +2 -2
  238. package/src/public/avm/opcodes/arithmetic.ts +14 -2
  239. package/src/public/avm/opcodes/bitwise.ts +3 -3
  240. package/src/public/avm/opcodes/comparators.ts +1 -1
  241. package/src/public/avm/opcodes/contract.ts +4 -7
  242. package/src/public/avm/opcodes/control_flow.ts +2 -2
  243. package/src/public/avm/opcodes/conversion.ts +3 -3
  244. package/src/public/avm/opcodes/ec_add.ts +15 -6
  245. package/src/public/avm/opcodes/environment_getters.ts +7 -7
  246. package/src/public/avm/opcodes/external_calls.ts +17 -15
  247. package/src/public/avm/opcodes/hashing.ts +16 -10
  248. package/src/public/avm/opcodes/instruction_impl.ts +2 -2
  249. package/src/public/avm/opcodes/memory.ts +20 -20
  250. package/src/public/avm/opcodes/misc.ts +4 -4
  251. package/src/public/avm/opcodes/storage.ts +30 -22
  252. package/src/public/avm/revert_reason.ts +6 -3
  253. package/src/public/avm/serialization/bytecode_serialization.ts +17 -6
  254. package/src/public/avm/serialization/instruction_serialization.ts +1 -1
  255. package/src/public/avm/test_utils.ts +1 -1
  256. package/src/public/contracts_db_checkpoint.ts +1 -1
  257. package/src/public/db_interfaces.ts +1 -1
  258. package/src/public/debug_fn_name.ts +39 -5
  259. package/src/public/executor_metrics.ts +7 -34
  260. package/src/public/fixtures/amm_test.ts +2 -2
  261. package/src/public/fixtures/bulk_test.ts +9 -9
  262. package/src/public/fixtures/custom_bytecode_tester.ts +53 -19
  263. package/src/public/fixtures/custom_bytecode_tests.ts +111 -18
  264. package/src/public/fixtures/index.ts +7 -1
  265. package/src/public/fixtures/minimal_public_tx.ts +6 -15
  266. package/src/public/fixtures/opcode_spammer.ts +1754 -0
  267. package/src/public/fixtures/public_tx_simulation_tester.ts +69 -13
  268. package/src/public/fixtures/simple_contract_data_source.ts +8 -9
  269. package/src/public/fixtures/token_test.ts +18 -9
  270. package/src/public/fixtures/utils.ts +2 -3
  271. package/src/public/fuzzing/avm_fuzzer_simulator.ts +288 -0
  272. package/src/public/fuzzing/avm_simulator_bin.ts +175 -0
  273. package/src/public/hinting_db_sources.ts +8 -3
  274. package/src/public/index.ts +7 -1
  275. package/src/public/public_db_sources.ts +1 -1
  276. package/src/public/public_processor/guarded_merkle_tree.ts +6 -1
  277. package/src/public/public_processor/public_processor.ts +46 -29
  278. package/src/public/public_processor/public_processor_metrics.ts +11 -45
  279. package/src/public/public_tx_simulator/contract_provider_for_cpp.ts +19 -60
  280. package/src/public/public_tx_simulator/cpp_public_tx_simulator.ts +76 -174
  281. package/src/public/public_tx_simulator/cpp_public_tx_simulator_with_hinted_dbs.ts +132 -0
  282. package/src/public/public_tx_simulator/cpp_vs_ts_public_tx_simulator.ts +237 -0
  283. package/src/public/public_tx_simulator/dumping_cpp_public_tx_simulator.ts +81 -0
  284. package/src/public/public_tx_simulator/factories.ts +41 -0
  285. package/src/public/public_tx_simulator/index.ts +3 -0
  286. package/src/public/public_tx_simulator/measured_public_tx_simulator.ts +1 -1
  287. package/src/public/public_tx_simulator/public_tx_context.ts +1 -1
  288. package/src/public/public_tx_simulator/public_tx_simulator.ts +36 -14
  289. package/src/public/public_tx_simulator/public_tx_simulator_interface.ts +23 -0
  290. package/src/public/public_tx_simulator/telemetry_public_tx_simulator.ts +1 -1
  291. package/src/public/side_effect_trace.ts +1 -1
  292. package/src/public/side_effect_trace_interface.ts +1 -1
  293. package/src/public/state_manager/nullifiers.ts +1 -1
  294. package/src/public/state_manager/public_storage.ts +1 -1
  295. package/src/public/state_manager/state_manager.ts +12 -19
@@ -1,5 +1,5 @@
1
- import { CANONICAL_AUTH_REGISTRY_ADDRESS, CONTRACT_CLASS_REGISTRY_CONTRACT_ADDRESS, CONTRACT_INSTANCE_REGISTRY_CONTRACT_ADDRESS, FEE_JUICE_ADDRESS, MULTI_CALL_ENTRYPOINT_ADDRESS, ROUTER_ADDRESS } from '@aztec/constants';
2
- import { poseidon2Hash } from '@aztec/foundation/crypto';
1
+ import { CONTRACT_INSTANCE_REGISTRY_CONTRACT_ADDRESS, MAX_PROTOCOL_CONTRACTS } from '@aztec/constants';
2
+ import { poseidon2Hash } from '@aztec/foundation/crypto/poseidon';
3
3
  import { jsonStringify } from '@aztec/foundation/json-rpc';
4
4
  import { createLogger } from '@aztec/foundation/log';
5
5
  import { ProtocolContractAddress } from '@aztec/protocol-contracts';
@@ -8,7 +8,7 @@ import { SerializableContractInstance } from '@aztec/stdlib/contract';
8
8
  import { DelayedPublicMutableValues, DelayedPublicMutableValuesWithHash } from '@aztec/stdlib/delayed-public-mutable';
9
9
  import { computeNoteHashNonce, computeUniqueNoteHash, siloNoteHash, siloNullifier } from '@aztec/stdlib/hash';
10
10
  import { strict as assert } from 'assert';
11
- import { getPublicFunctionDebugName } from '../debug_fn_name.js';
11
+ import { getPublicFunctionDebugName, getPublicFunctionSelectorAndName } from '../debug_fn_name.js';
12
12
  import { L1ToL2MessageIndexOutOfRangeError, MaxCallsToUniqueContractClassIdsError, NoteHashIndexOutOfRangeError, NullifierCollisionError } from '../side_effect_errors.js';
13
13
  import { NullifierManager } from './nullifiers.js';
14
14
  import { PublicStorage } from './public_storage.js';
@@ -380,6 +380,9 @@ import { PublicStorage } from './public_storage.js';
380
380
  async getPublicFunctionDebugName(avmEnvironment) {
381
381
  return await getPublicFunctionDebugName(this.contractsDB, avmEnvironment.address, avmEnvironment.calldata);
382
382
  }
383
+ async getPublicFunctionSelectorAndName(avmEnvironment) {
384
+ return await getPublicFunctionSelectorAndName(this.contractsDB, avmEnvironment.address, avmEnvironment.calldata);
385
+ }
383
386
  async padTree(treeId, leavesToInsert) {
384
387
  await this.treesDB.padTree(treeId, leavesToInsert);
385
388
  }
@@ -388,5 +391,5 @@ import { PublicStorage } from './public_storage.js';
388
391
  }
389
392
  }
390
393
  function contractAddressIsCanonical(contractAddress) {
391
- return contractAddress.equals(AztecAddress.fromNumber(CANONICAL_AUTH_REGISTRY_ADDRESS)) || contractAddress.equals(AztecAddress.fromNumber(CONTRACT_INSTANCE_REGISTRY_CONTRACT_ADDRESS)) || contractAddress.equals(AztecAddress.fromNumber(CONTRACT_CLASS_REGISTRY_CONTRACT_ADDRESS)) || contractAddress.equals(AztecAddress.fromNumber(MULTI_CALL_ENTRYPOINT_ADDRESS)) || contractAddress.equals(AztecAddress.fromNumber(FEE_JUICE_ADDRESS)) || contractAddress.equals(AztecAddress.fromNumber(ROUTER_ADDRESS));
394
+ return contractAddress.toBigInt() >= 1 && contractAddress.toBigInt() <= MAX_PROTOCOL_CONTRACTS;
392
395
  }
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@aztec/simulator",
3
- "version": "0.0.1-commit.5476d83",
3
+ "version": "0.0.1-commit.59e663cd",
4
4
  "type": "module",
5
5
  "exports": {
6
6
  "./server": "./dest/server.js",
@@ -17,11 +17,11 @@
17
17
  "tsconfig": "./tsconfig.json"
18
18
  },
19
19
  "scripts": {
20
- "build": "yarn clean && tsgo -b",
21
- "build:dev": "tsgo -b --watch",
20
+ "build": "yarn clean && ../scripts/tsc.sh",
21
+ "build:dev": "../scripts/tsc.sh --watch",
22
22
  "clean": "rm -rf ./dest .tsbuildinfo",
23
23
  "test": "NODE_NO_WARNINGS=1 node --experimental-vm-modules ../node_modules/.bin/jest --passWithNoTests --maxWorkers=${JEST_MAX_WORKERS:-8}",
24
- "build:fuzzer": "tsgo scripts/fuzzing/avm_simulator_bin.ts --outDir dest/scripts/fuzzing --module commonjs --target es2022 --esModuleInterop --allowSyntheticDefaultImports --resolveJsonModule --skipLibCheck"
24
+ "build:fuzzer": "yarn clean && ../scripts/tsc.sh"
25
25
  },
26
26
  "inherits": [
27
27
  "../package.common.json"
@@ -64,32 +64,32 @@
64
64
  ]
65
65
  },
66
66
  "dependencies": {
67
- "@aztec/constants": "0.0.1-commit.5476d83",
68
- "@aztec/foundation": "0.0.1-commit.5476d83",
69
- "@aztec/native": "0.0.1-commit.5476d83",
70
- "@aztec/noir-acvm_js": "0.0.1-commit.5476d83",
71
- "@aztec/noir-noirc_abi": "0.0.1-commit.5476d83",
72
- "@aztec/noir-protocol-circuits-types": "0.0.1-commit.5476d83",
73
- "@aztec/noir-types": "0.0.1-commit.5476d83",
74
- "@aztec/protocol-contracts": "0.0.1-commit.5476d83",
75
- "@aztec/stdlib": "0.0.1-commit.5476d83",
76
- "@aztec/telemetry-client": "0.0.1-commit.5476d83",
77
- "@aztec/world-state": "0.0.1-commit.5476d83",
67
+ "@aztec/constants": "0.0.1-commit.59e663cd",
68
+ "@aztec/foundation": "0.0.1-commit.59e663cd",
69
+ "@aztec/native": "0.0.1-commit.59e663cd",
70
+ "@aztec/noir-acvm_js": "0.0.1-commit.59e663cd",
71
+ "@aztec/noir-noirc_abi": "0.0.1-commit.59e663cd",
72
+ "@aztec/noir-protocol-circuits-types": "0.0.1-commit.59e663cd",
73
+ "@aztec/noir-types": "0.0.1-commit.59e663cd",
74
+ "@aztec/protocol-contracts": "0.0.1-commit.59e663cd",
75
+ "@aztec/stdlib": "0.0.1-commit.59e663cd",
76
+ "@aztec/telemetry-client": "0.0.1-commit.59e663cd",
77
+ "@aztec/world-state": "0.0.1-commit.59e663cd",
78
78
  "lodash.clonedeep": "^4.5.0",
79
79
  "lodash.merge": "^4.6.2",
80
80
  "tslib": "^2.4.0"
81
81
  },
82
82
  "devDependencies": {
83
- "@aztec/kv-store": "0.0.1-commit.5476d83",
84
- "@aztec/merkle-tree": "0.0.1-commit.5476d83",
85
- "@aztec/noir-contracts.js": "0.0.1-commit.5476d83",
86
- "@aztec/noir-test-contracts.js": "0.0.1-commit.5476d83",
83
+ "@aztec/kv-store": "0.0.1-commit.59e663cd",
84
+ "@aztec/merkle-tree": "0.0.1-commit.59e663cd",
85
+ "@aztec/noir-contracts.js": "0.0.1-commit.59e663cd",
86
+ "@aztec/noir-test-contracts.js": "0.0.1-commit.59e663cd",
87
87
  "@jest/globals": "^30.0.0",
88
88
  "@types/jest": "^30.0.0",
89
89
  "@types/lodash.clonedeep": "^4.5.7",
90
90
  "@types/lodash.merge": "^4.6.9",
91
91
  "@types/node": "^22.15.17",
92
- "@typescript/native-preview": "7.0.0-dev.20251126.1",
92
+ "@typescript/native-preview": "7.0.0-dev.20260113.1",
93
93
  "istanbul-lib-hook": "^3.0.0",
94
94
  "istanbul-lib-instrument": "^6.0.3",
95
95
  "jest": "^30.0.0",
@@ -1,4 +1,4 @@
1
- import type { Fr } from '@aztec/foundation/fields';
1
+ import type { Fr } from '@aztec/foundation/curves/bn254';
2
2
  import { jsonStringify } from '@aztec/foundation/json-rpc';
3
3
  import type { RawAssertionPayload } from '@aztec/noir-acvm_js';
4
4
  import { abiDecodeError } from '@aztec/noir-noirc_abi';
@@ -1,4 +1,4 @@
1
- import { Fr } from '@aztec/foundation/fields';
1
+ import { Fr } from '@aztec/foundation/curves/bn254';
2
2
  import { hexToBuffer } from '@aztec/foundation/string';
3
3
 
4
4
  import type { ACVMField, ACVMWitness } from './acvm_types.js';
@@ -1,5 +1,5 @@
1
+ import { Fr } from '@aztec/foundation/curves/bn254';
1
2
  import type { EthAddress } from '@aztec/foundation/eth-address';
2
- import { Fr } from '@aztec/foundation/fields';
3
3
  import type { AztecAddress } from '@aztec/stdlib/aztec-address';
4
4
 
5
5
  import type { ACVMField } from './acvm_types.js';
@@ -1,4 +1,4 @@
1
- import { sha512 } from '@aztec/foundation/crypto';
1
+ import { sha512 } from '@aztec/foundation/crypto/sha512';
2
2
  import { createLogger } from '@aztec/foundation/log';
3
3
  import { Timer } from '@aztec/foundation/timer';
4
4
  import type { ForeignCallHandler, ForeignCallInput, ForeignCallOutput } from '@aztec/noir-acvm_js';
@@ -108,16 +108,16 @@ export class CircuitRecorder {
108
108
  * contracts as protocol circuits artifacts always contain a single entrypoint function called 'main'.
109
109
  */
110
110
  start(input: ACVMWitness, circuitBytecode: Buffer, circuitName: string, functionName: string): Promise<void> {
111
- const parentRef = this.recording;
112
111
  if (this.newCircuit) {
112
+ const parentRef = this.recording;
113
113
  this.recording = new CircuitRecording(
114
114
  circuitName,
115
115
  functionName,
116
116
  sha512(circuitBytecode).toString('hex'),
117
117
  Object.fromEntries(input),
118
118
  );
119
+ this.recording.setParent(parentRef);
119
120
  }
120
- this.recording!.setParent(parentRef);
121
121
 
122
122
  return Promise.resolve();
123
123
  }
@@ -173,22 +173,22 @@ export class CircuitRecorder {
173
173
  if (result instanceof Promise) {
174
174
  return result.then(async r => {
175
175
  // Once we leave the nested circuit, we decrease the stack depth and set newCircuit to false
176
- // since we are going back to the "parent" circuit which can never be new
176
+ // so that the parent circuit continues with its existing recording
177
+ // Note: recording restoration is handled by finish()
177
178
  if (isExternalCall) {
178
179
  this.stackDepth--;
179
180
  this.newCircuit = false;
180
- this.recording = this.recording!.parent;
181
181
  }
182
182
  await this.recordCall(name, args, r, timer.ms(), this.stackDepth);
183
183
  return r;
184
184
  }) as ReturnType<typeof fn>;
185
185
  }
186
186
  // Once we leave the nested circuit, we decrease the stack depth and set newCircuit to false
187
- // since we are going back to the "parent" circuit which can never be new
187
+ // so that the parent circuit continues with its existing recording
188
+ // Note: recording restoration is handled by finish()
188
189
  if (isExternalCall) {
189
190
  this.stackDepth--;
190
191
  this.newCircuit = false;
191
- this.recording = this.recording!.parent;
192
192
  }
193
193
  void this.recordCall(name, args, result, timer.ms(), this.stackDepth);
194
194
  return result;
@@ -239,6 +239,12 @@ export class CircuitRecorder {
239
239
  if (!result!.parent) {
240
240
  this.newCircuit = true;
241
241
  this.recording = undefined;
242
+ } else {
243
+ // For nested circuits (utility calls, nested contract calls), restore to parent recording
244
+ // Note: we don't set newCircuit=false here because:
245
+ // - For privateCallPrivateFunction, the callback wrapper will set it to false
246
+ // - For utility calls, we want newCircuit to remain true so the next circuit creates its own recording
247
+ this.recording = result!.parent;
242
248
  }
243
249
  return Promise.resolve(result!);
244
250
  }
@@ -247,14 +253,9 @@ export class CircuitRecorder {
247
253
  * Finalizes the recording by resetting the state and returning the recording object with an attached error.
248
254
  * @param error - The error that occurred during circuit execution
249
255
  */
250
- finishWithError(error: unknown): Promise<CircuitRecording> {
251
- const result = this.recording;
252
- // If this is the top-level circuit recording, we reset the state for the next simulator call
253
- if (!result!.parent) {
254
- this.newCircuit = true;
255
- this.recording = undefined;
256
- }
257
- result!.error = JSON.stringify(error);
258
- return Promise.resolve(result!);
256
+ async finishWithError(error: unknown): Promise<CircuitRecording> {
257
+ const result = await this.finish();
258
+ result.error = JSON.stringify(error);
259
+ return result;
259
260
  }
260
261
  }
@@ -1,4 +1,3 @@
1
- import type { Fr } from '@aztec/foundation/fields';
2
1
  import type { AztecAddress } from '@aztec/stdlib/aztec-address';
3
2
 
4
3
  import type { PublicPersistableStateManager } from '../state_manager/state_manager.js';
@@ -6,6 +5,7 @@ import type { AvmExecutionEnvironment } from './avm_execution_environment.js';
6
5
  import { type Gas, gasToGasLeft } from './avm_gas.js';
7
6
  import { AvmMachineState } from './avm_machine_state.js';
8
7
  import type { AvmSimulatorInterface } from './avm_simulator_interface.js';
8
+ import type { CallData } from './calldata.js';
9
9
 
10
10
  /**
11
11
  * An execution context includes the information necessary to initiate AVM
@@ -45,7 +45,7 @@ export class AvmContext {
45
45
  */
46
46
  public async createNestedContractCallContext(
47
47
  address: AztecAddress,
48
- calldata: Fr[],
48
+ calldata: CallData,
49
49
  allocatedGas: Gas,
50
50
  callType: 'CALL' | 'STATICCALL',
51
51
  ): Promise<AvmContext> {
@@ -1,4 +1,3 @@
1
- import type { Fr } from '@aztec/foundation/fields';
2
1
  import type { SimulationError } from '@aztec/stdlib/errors';
3
2
  import { Gas } from '@aztec/stdlib/gas';
4
3
 
@@ -6,6 +5,7 @@ import { inspect } from 'util';
6
5
 
7
6
  import { createSimulationError } from '../../common/errors.js';
8
7
  import type { Gas as AvmGas } from './avm_gas.js';
8
+ import type { ReturnData } from './calldata.js';
9
9
  import type { AvmRevertReason } from './errors.js';
10
10
 
11
11
  /**
@@ -14,14 +14,14 @@ import type { AvmRevertReason } from './errors.js';
14
14
  export class AvmContractCallResult {
15
15
  constructor(
16
16
  public reverted: boolean,
17
- public output: Fr[],
17
+ public output: ReturnData,
18
18
  public gasLeft: AvmGas,
19
19
  public revertReason?: AvmRevertReason,
20
20
  public totalInstructions: number = 0, // including nested calls
21
21
  ) {}
22
22
 
23
23
  toString(): string {
24
- let resultsStr = `reverted: ${this.reverted}, output: ${this.output}, gasLeft: ${inspect(
24
+ let resultsStr = `reverted: ${this.reverted}, output: ${this.output.bestEffortReadAll(10)}${this.output.length() > 10 ? ' ...' : ''}, gasLeft: ${inspect(
25
25
  this.gasLeft,
26
26
  )}, totalInstructions: ${this.totalInstructions}`;
27
27
  if (this.revertReason) {
@@ -31,7 +31,9 @@ export class AvmContractCallResult {
31
31
  }
32
32
 
33
33
  finalize(): AvmFinalizedCallResult {
34
- const revertReason = this.revertReason ? createSimulationError(this.revertReason, this.output) : undefined;
34
+ const revertReason = this.revertReason
35
+ ? createSimulationError(this.revertReason, this.output.bestEffortReadAll())
36
+ : undefined;
35
37
  return new AvmFinalizedCallResult(
36
38
  this.reverted,
37
39
  this.output,
@@ -49,14 +51,14 @@ export class AvmContractCallResult {
49
51
  export class AvmFinalizedCallResult {
50
52
  constructor(
51
53
  public reverted: boolean,
52
- public output: Fr[],
54
+ public output: ReturnData,
53
55
  public gasLeft: Gas,
54
56
  public revertReason?: SimulationError,
55
57
  public totalInstructions: number = 0, // including nested calls
56
58
  ) {}
57
59
 
58
60
  toString(): string {
59
- let resultsStr = `reverted: ${this.reverted}, output: ${this.output}, gasLeft: ${inspect(
61
+ let resultsStr = `reverted: ${this.reverted}, output: ${this.output.bestEffortReadAll(10)}${this.output.length() > 10 ? ' ...' : ''}, gasLeft: ${inspect(
60
62
  this.gasLeft,
61
63
  )}, totalInstructions: ${this.totalInstructions}`;
62
64
  if (this.revertReason) {
@@ -1,8 +1,10 @@
1
- import { Fr } from '@aztec/foundation/fields';
1
+ import { Fr } from '@aztec/foundation/curves/bn254';
2
2
  import type { PublicSimulatorConfig } from '@aztec/stdlib/avm';
3
3
  import type { AztecAddress } from '@aztec/stdlib/aztec-address';
4
4
  import type { GlobalVariables } from '@aztec/stdlib/tx';
5
5
 
6
+ import type { CallData } from './calldata.js';
7
+
6
8
  /**
7
9
  * Contains variables that remain constant during AVM execution
8
10
  * These variables are provided by the public kernel circuit
@@ -15,13 +17,13 @@ export class AvmExecutionEnvironment {
15
17
  public readonly transactionFee: Fr,
16
18
  public readonly globals: GlobalVariables,
17
19
  public readonly isStaticCall: boolean,
18
- public readonly calldata: Fr[],
20
+ public readonly calldata: CallData,
19
21
  public readonly config: PublicSimulatorConfig,
20
22
  ) {}
21
23
 
22
24
  private deriveEnvironmentForNestedCallInternal(
23
25
  targetAddress: AztecAddress,
24
- calldata: Fr[],
26
+ calldata: CallData,
25
27
  isStaticCall: boolean,
26
28
  ): AvmExecutionEnvironment {
27
29
  return new AvmExecutionEnvironment(
@@ -36,11 +38,14 @@ export class AvmExecutionEnvironment {
36
38
  );
37
39
  }
38
40
 
39
- public deriveEnvironmentForNestedCall(targetAddress: AztecAddress, calldata: Fr[]): AvmExecutionEnvironment {
41
+ public deriveEnvironmentForNestedCall(targetAddress: AztecAddress, calldata: CallData): AvmExecutionEnvironment {
40
42
  return this.deriveEnvironmentForNestedCallInternal(targetAddress, calldata, /*isStaticCall=*/ false);
41
43
  }
42
44
 
43
- public deriveEnvironmentForNestedStaticCall(targetAddress: AztecAddress, calldata: Fr[]): AvmExecutionEnvironment {
45
+ public deriveEnvironmentForNestedStaticCall(
46
+ targetAddress: AztecAddress,
47
+ calldata: CallData,
48
+ ): AvmExecutionEnvironment {
44
49
  return this.deriveEnvironmentForNestedCallInternal(targetAddress, calldata, /*isStaticCall=*/ true);
45
50
  }
46
51
  }
@@ -26,9 +26,9 @@ export function makeGas(gasCost: Partial<Gas>) {
26
26
  }
27
27
 
28
28
  /** Sums together multiple instances of Gas. */
29
- export function sumGas(...gases: Partial<Gas>[]) {
30
- return gases.reduce(
31
- (acc: Gas, gas) => ({
29
+ export function sumGas(...gases: Partial<Gas>[]): Gas {
30
+ return gases.reduce<Gas>(
31
+ (acc, gas) => ({
32
32
  l2Gas: acc.l2Gas + (gas.l2Gas ?? 0),
33
33
  daGas: acc.daGas + (gas.daGas ?? 0),
34
34
  }),
@@ -1,7 +1,8 @@
1
- import type { Fr } from '@aztec/foundation/fields';
1
+ import type { Fr } from '@aztec/foundation/curves/bn254';
2
2
 
3
3
  import type { Gas } from './avm_gas.js';
4
4
  import { TaggedMemory } from './avm_memory_types.js';
5
+ import { type ReturnData, ReturnDataArray } from './calldata.js';
5
6
  import { type AvmRevertReason, OutOfGasError } from './errors.js';
6
7
 
7
8
  /**
@@ -39,7 +40,7 @@ export class AvmMachineState {
39
40
  /** program counter of the next instruction, byte based */
40
41
  public nextPc: number = 0;
41
42
  /** return/revertdata of the last nested call. */
42
- public nestedReturndata: Fr[] = [];
43
+ public nestedReturndata: ReturnData = new ReturnDataArray([]);
43
44
  /** Tracks whether the last external call was successful */
44
45
  public nestedCallSuccess: boolean = false;
45
46
  /**
@@ -66,7 +67,7 @@ export class AvmMachineState {
66
67
  /** Signals that execution has reverted normally (this does not cover exceptional halts) */
67
68
  private reverted: boolean = false;
68
69
  /** Output data must NOT be modified once it is set */
69
- private output: Fr[] = [];
70
+ private output: ReturnData = new ReturnDataArray([]);
70
71
 
71
72
  // Metrics only - not needed for execution
72
73
  /** instruction counter, including nested calls */
@@ -129,7 +130,7 @@ export class AvmMachineState {
129
130
  * Output data must NOT be modified once it is set
130
131
  * @param output
131
132
  */
132
- public return(output: Fr[]) {
133
+ public return(output: ReturnData) {
133
134
  this.halted = true;
134
135
  this.output = output;
135
136
  }
@@ -139,7 +140,7 @@ export class AvmMachineState {
139
140
  * Output data must NOT be modified once it is set
140
141
  * @param output
141
142
  */
142
- public revert(output: Fr[]) {
143
+ public revert(output: ReturnData) {
143
144
  this.halted = true;
144
145
  this.reverted = true;
145
146
  this.output = output;
@@ -153,7 +154,7 @@ export class AvmMachineState {
153
154
  return this.reverted;
154
155
  }
155
156
 
156
- public getOutput(): Fr[] {
157
+ public getOutput(): ReturnData {
157
158
  return this.output;
158
159
  }
159
160
 
@@ -8,7 +8,7 @@ import {
8
8
  MEM_TAG_U128,
9
9
  } from '@aztec/constants';
10
10
  import { toBufferBE } from '@aztec/foundation/bigint-buffer';
11
- import { Fr } from '@aztec/foundation/fields';
11
+ import { Fr } from '@aztec/foundation/curves/bn254';
12
12
  import { type Logger, createLogger } from '@aztec/foundation/log';
13
13
  import type { FunctionsOf } from '@aztec/foundation/types';
14
14
  import { AztecAddress } from '@aztec/stdlib/aztec-address';
@@ -369,6 +369,10 @@ export class TaggedMemory implements TaggedMemoryInterface {
369
369
  * Check tags for all memory in the specified range.
370
370
  */
371
371
  public checkTagsRange(tag: TypeTag, startOffset: number, size: number) {
372
+ if (startOffset + size > TaggedMemory.MAX_MEMORY_SIZE) {
373
+ throw new MemorySliceOutOfRangeError(startOffset, size);
374
+ }
375
+
372
376
  for (let offset = startOffset; offset < startOffset + size; offset++) {
373
377
  this.checkTag(tag, offset);
374
378
  }
@@ -1,4 +1,4 @@
1
- import { Fr } from '@aztec/foundation/fields';
1
+ import { Fr } from '@aztec/foundation/curves/bn254';
2
2
  import { type Logger, createLogger } from '@aztec/foundation/log';
3
3
  import { Timer } from '@aztec/foundation/timer';
4
4
  import type { PublicSimulatorConfig } from '@aztec/stdlib/avm';
@@ -15,6 +15,7 @@ import { AvmExecutionEnvironment } from './avm_execution_environment.js';
15
15
  import type { Gas } from './avm_gas.js';
16
16
  import { AvmMachineState } from './avm_machine_state.js';
17
17
  import type { AvmSimulatorInterface } from './avm_simulator_interface.js';
18
+ import { type CallData, ReturnDataArray } from './calldata.js';
18
19
  import { AvmRevertReason, InvalidProgramCounterError } from './errors.js';
19
20
  import type { Instruction } from './opcodes/instruction.js';
20
21
  import { revertReasonFromExceptionalHalt, revertReasonFromExplicitRevert } from './revert_reason.js';
@@ -49,7 +50,7 @@ export class AvmSimulator implements AvmSimulatorInterface {
49
50
  // This will be used by the CALL opcode to create a new simulator. It is required to
50
51
  // avoid a dependency cycle.
51
52
  context.provideSimulator = AvmSimulator.build;
52
- this.log = createLogger(`simulator:avm(calldata[0]: ${context.environment.calldata[0]})`);
53
+ this.log = createLogger(`simulator:avm(calldata[0]: ${context.environment.calldata.read(0)})`);
53
54
  // Turn on tallying if explicitly enabled or if trace logging
54
55
  if (enableTallying || this.log.isLevelEnabled('trace')) {
55
56
  this.tallyPrintFunction = this.printOpcodeTallies;
@@ -74,7 +75,7 @@ export class AvmSimulator implements AvmSimulatorInterface {
74
75
  transactionFee: Fr,
75
76
  globals: GlobalVariables,
76
77
  isStaticCall: boolean,
77
- calldata: Fr[],
78
+ calldata: CallData,
78
79
  allocatedGas: Gas,
79
80
  config: PublicSimulatorConfig,
80
81
  ) {
@@ -104,7 +105,7 @@ export class AvmSimulator implements AvmSimulatorInterface {
104
105
 
105
106
  if (!bytecode) {
106
107
  return await this.handleFailureToRetrieveBytecode(
107
- `No bytecode found, or limit encountered for max calls to unique contract class IDs. Contract address: ${this.context.environment.address}. Reverting...`,
108
+ `No bytecode found. Contract is not deployed, or limit encountered for max calls to unique contract class IDs. Contract address: ${this.context.environment.address}. Reverting...`,
108
109
  );
109
110
  }
110
111
 
@@ -177,13 +178,15 @@ export class AvmSimulator implements AvmSimulatorInterface {
177
178
 
178
179
  if (machineState.pc >= bytecode.length) {
179
180
  this.log.warn('Passed end of program');
180
- throw new InvalidProgramCounterError(machineState.pc, /*max=*/ bytecode.length);
181
+ throw new InvalidProgramCounterError(machineState.pc, /*max=*/ bytecode.length - 1);
181
182
  }
182
183
  }
183
184
 
184
185
  const output = machineState.getOutput();
185
186
  const reverted = machineState.getReverted();
186
- const revertReason = reverted ? await revertReasonFromExplicitRevert(output, this.context) : undefined;
187
+ const revertReason = reverted
188
+ ? await revertReasonFromExplicitRevert(output.bestEffortReadAll(), this.context)
189
+ : undefined;
187
190
  const results = new AvmContractCallResult(
188
191
  reverted,
189
192
  output,
@@ -220,7 +223,7 @@ export class AvmSimulator implements AvmSimulatorInterface {
220
223
  // Note: "exceptional halts" cannot return data, hence [].
221
224
  const results = new AvmContractCallResult(
222
225
  /*reverted=*/ true,
223
- /*output=*/ [],
226
+ /*output=*/ new ReturnDataArray([]),
224
227
  noGasLeft,
225
228
  revertReason,
226
229
  machineState.instrCounter,
@@ -235,19 +238,22 @@ export class AvmSimulator implements AvmSimulatorInterface {
235
238
 
236
239
  private async handleFailureToRetrieveBytecode(message: string): Promise<AvmContractCallResult> {
237
240
  // revert, consuming all gas
238
- const fnName = await this.context.persistableState.getPublicFunctionDebugName(this.context.environment);
241
+ const { functionSelector, functionName } = await this.context.persistableState.getPublicFunctionSelectorAndName(
242
+ this.context.environment,
243
+ );
239
244
  const revertReason = new AvmRevertReason(
240
245
  message,
241
246
  /*failingFunction=*/ {
242
247
  contractAddress: this.context.environment.address,
243
- functionName: fnName,
248
+ functionSelector,
249
+ functionName,
244
250
  },
245
251
  /*noirCallStack=*/ [],
246
252
  );
247
253
  this.log.warn(message);
248
254
  return new AvmContractCallResult(
249
255
  /*reverted=*/ true,
250
- /*output=*/ [],
256
+ /*output=*/ new ReturnDataArray([]),
251
257
  /*gasLeft=*/ { l2Gas: 0, daGas: 0 }, // consumes all allocated gas
252
258
  revertReason,
253
259
  );
@@ -0,0 +1,100 @@
1
+ import type { Fr } from '@aztec/foundation/schemas';
2
+
3
+ import { TaggedMemory } from './avm_memory_types.js';
4
+
5
+ // Allow reading up to 300 kB of return data when unspecified.
6
+ const DEFAULT_BEST_EFFORT_READ_CAP = 10000;
7
+
8
+ export interface LazyReader {
9
+ bestEffortReadAll(readCap?: number): Fr[];
10
+ readAll(): Fr[];
11
+ read(idx: number): Fr | undefined;
12
+ slice(start: number, end: number): Fr[];
13
+ length(): number;
14
+ }
15
+
16
+ export class LazyReaderMemory implements LazyReader {
17
+ constructor(
18
+ private memory: TaggedMemory,
19
+ private offset: number,
20
+ private size: number,
21
+ ) {}
22
+
23
+ public bestEffortReadAll(readCap = DEFAULT_BEST_EFFORT_READ_CAP): Fr[] {
24
+ const size = Math.min(this.size, readCap, TaggedMemory.MAX_MEMORY_SIZE - this.offset);
25
+ return this.memory.getSlice(this.offset, size).map(word => word.toFr());
26
+ }
27
+
28
+ public read(idx: number): Fr | undefined {
29
+ if (idx >= this.size) {
30
+ return undefined;
31
+ }
32
+ return this.memory.get(this.offset + idx).toFr();
33
+ }
34
+
35
+ public slice(start: number, end: number): Fr[] {
36
+ const clampedEnd = Math.min(end, this.size);
37
+ const length = Math.max(0, clampedEnd - start);
38
+ return this.memory.getSlice(this.offset + start, length).map(word => word.toFr());
39
+ }
40
+
41
+ public readAll(): Fr[] {
42
+ return this.memory.getSlice(this.offset, this.size).map(word => word.toFr());
43
+ }
44
+
45
+ public length(): number {
46
+ return this.size;
47
+ }
48
+ }
49
+
50
+ export class LazyReaderArray implements LazyReader {
51
+ constructor(private array: Fr[]) {}
52
+
53
+ public bestEffortReadAll(readCap = DEFAULT_BEST_EFFORT_READ_CAP): Fr[] {
54
+ return this.array.slice(0, readCap);
55
+ }
56
+
57
+ public read(idx: number): Fr | undefined {
58
+ return this.array[idx];
59
+ }
60
+
61
+ public slice(start: number, end: number): Fr[] {
62
+ return this.array.slice(start, end);
63
+ }
64
+
65
+ public readAll(): Fr[] {
66
+ return this.array;
67
+ }
68
+
69
+ public length(): number {
70
+ return this.array.length;
71
+ }
72
+ }
73
+
74
+ // Compile time branding to avoid swapping CallData and ReturnData by accident.
75
+ declare const CallDataBrand: unique symbol;
76
+ declare const ReturnDataBrand: unique symbol;
77
+
78
+ export type CallData = LazyReader & {
79
+ readonly [CallDataBrand]: true;
80
+ };
81
+
82
+ export type ReturnData = LazyReader & {
83
+ readonly [ReturnDataBrand]: true;
84
+ };
85
+
86
+ export class CallDataArray extends LazyReaderArray implements CallData {
87
+ declare readonly [CallDataBrand]: true;
88
+ }
89
+
90
+ export class CallDataMemory extends LazyReaderMemory implements CallData {
91
+ declare readonly [CallDataBrand]: true;
92
+ }
93
+
94
+ export class ReturnDataArray extends LazyReaderArray implements ReturnData {
95
+ declare readonly [ReturnDataBrand]: true;
96
+ }
97
+
98
+ export class ReturnDataMemory extends LazyReaderMemory implements ReturnData {
99
+ declare readonly [ReturnDataBrand]: true;
100
+ }