@aztec/simulator 0.87.1 → 0.87.2-nightly.20250524

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 (103) hide show
  1. package/dest/private/acvm/oracle/oracle.d.ts +1 -1
  2. package/dest/private/acvm/oracle/oracle.d.ts.map +1 -1
  3. package/dest/private/acvm/oracle/oracle.js +2 -2
  4. package/dest/private/acvm/oracle/typed_oracle.d.ts +1 -1
  5. package/dest/private/acvm/oracle/typed_oracle.d.ts.map +1 -1
  6. package/dest/private/acvm/oracle/typed_oracle.js +2 -2
  7. package/dest/private/private_execution_oracle.d.ts +1 -1
  8. package/dest/private/private_execution_oracle.d.ts.map +1 -1
  9. package/dest/private/private_execution_oracle.js +1 -1
  10. package/dest/private/providers/circuit_recording/circuit_recorder.d.ts +1 -1
  11. package/dest/private/providers/circuit_recording/circuit_recorder.js +1 -1
  12. package/dest/private/utility_execution_oracle.d.ts +1 -1
  13. package/dest/private/utility_execution_oracle.d.ts.map +1 -1
  14. package/dest/private/utility_execution_oracle.js +1 -1
  15. package/dest/public/avm/avm_gas.d.ts +4 -5
  16. package/dest/public/avm/avm_gas.d.ts.map +1 -1
  17. package/dest/public/avm/avm_gas.js +28 -18
  18. package/dest/public/avm/fixtures/utils.js +1 -1
  19. package/dest/public/avm/opcodes/accrued_substate.d.ts.map +1 -1
  20. package/dest/public/avm/opcodes/accrued_substate.js +8 -7
  21. package/dest/public/avm/opcodes/addressing_mode.d.ts +2 -0
  22. package/dest/public/avm/opcodes/addressing_mode.d.ts.map +1 -1
  23. package/dest/public/avm/opcodes/addressing_mode.js +6 -0
  24. package/dest/public/avm/opcodes/arithmetic.d.ts.map +1 -1
  25. package/dest/public/avm/opcodes/arithmetic.js +1 -1
  26. package/dest/public/avm/opcodes/bitwise.d.ts +5 -1
  27. package/dest/public/avm/opcodes/bitwise.d.ts.map +1 -1
  28. package/dest/public/avm/opcodes/bitwise.js +17 -2
  29. package/dest/public/avm/opcodes/comparators.d.ts.map +1 -1
  30. package/dest/public/avm/opcodes/comparators.js +1 -1
  31. package/dest/public/avm/opcodes/contract.d.ts.map +1 -1
  32. package/dest/public/avm/opcodes/contract.js +1 -1
  33. package/dest/public/avm/opcodes/control_flow.d.ts.map +1 -1
  34. package/dest/public/avm/opcodes/control_flow.js +4 -4
  35. package/dest/public/avm/opcodes/conversion.d.ts +1 -0
  36. package/dest/public/avm/opcodes/conversion.d.ts.map +1 -1
  37. package/dest/public/avm/opcodes/conversion.js +263 -2
  38. package/dest/public/avm/opcodes/ec_add.d.ts.map +1 -1
  39. package/dest/public/avm/opcodes/ec_add.js +1 -1
  40. package/dest/public/avm/opcodes/environment_getters.d.ts.map +1 -1
  41. package/dest/public/avm/opcodes/environment_getters.js +1 -1
  42. package/dest/public/avm/opcodes/external_calls.d.ts.map +1 -1
  43. package/dest/public/avm/opcodes/external_calls.js +6 -8
  44. package/dest/public/avm/opcodes/hashing.d.ts.map +1 -1
  45. package/dest/public/avm/opcodes/hashing.js +3 -3
  46. package/dest/public/avm/opcodes/instruction.d.ts +9 -3
  47. package/dest/public/avm/opcodes/instruction.d.ts.map +1 -1
  48. package/dest/public/avm/opcodes/instruction.js +12 -7
  49. package/dest/public/avm/opcodes/memory.d.ts.map +1 -1
  50. package/dest/public/avm/opcodes/memory.js +8 -6
  51. package/dest/public/avm/opcodes/misc.js +1 -3
  52. package/dest/public/avm/opcodes/storage.d.ts.map +1 -1
  53. package/dest/public/avm/opcodes/storage.js +5 -3
  54. package/dest/public/fixtures/index.d.ts +1 -0
  55. package/dest/public/fixtures/index.d.ts.map +1 -1
  56. package/dest/public/fixtures/index.js +1 -0
  57. package/dest/public/fixtures/minimal_public_tx.d.ts +9 -0
  58. package/dest/public/fixtures/minimal_public_tx.d.ts.map +1 -0
  59. package/dest/public/fixtures/minimal_public_tx.js +43 -0
  60. package/dest/public/public_tx_simulator/apps_tests/amm_test.d.ts.map +1 -1
  61. package/dest/public/public_tx_simulator/apps_tests/amm_test.js +32 -18
  62. package/dest/public/public_tx_simulator/public_tx_context.d.ts +1 -1
  63. package/dest/public/public_tx_simulator/public_tx_context.d.ts.map +1 -1
  64. package/dest/public/public_tx_simulator/public_tx_context.js +5 -4
  65. package/dest/public/side_effect_trace.d.ts +4 -1
  66. package/dest/public/side_effect_trace.d.ts.map +1 -1
  67. package/dest/public/side_effect_trace.js +13 -2
  68. package/dest/public/side_effect_trace_interface.d.ts +1 -0
  69. package/dest/public/side_effect_trace_interface.d.ts.map +1 -1
  70. package/dest/public/state_manager/state_manager.d.ts +1 -0
  71. package/dest/public/state_manager/state_manager.d.ts.map +1 -1
  72. package/dest/public/state_manager/state_manager.js +3 -0
  73. package/package.json +15 -15
  74. package/src/private/acvm/oracle/oracle.ts +2 -2
  75. package/src/private/acvm/oracle/typed_oracle.ts +2 -2
  76. package/src/private/private_execution_oracle.ts +1 -1
  77. package/src/private/providers/circuit_recording/circuit_recorder.ts +1 -1
  78. package/src/private/utility_execution_oracle.ts +1 -1
  79. package/src/public/avm/avm_gas.ts +20 -14
  80. package/src/public/avm/fixtures/utils.ts +1 -1
  81. package/src/public/avm/opcodes/accrued_substate.ts +23 -7
  82. package/src/public/avm/opcodes/addressing_mode.ts +8 -0
  83. package/src/public/avm/opcodes/arithmetic.ts +3 -1
  84. package/src/public/avm/opcodes/bitwise.ts +26 -2
  85. package/src/public/avm/opcodes/comparators.ts +3 -1
  86. package/src/public/avm/opcodes/contract.ts +3 -1
  87. package/src/public/avm/opcodes/control_flow.ts +6 -4
  88. package/src/public/avm/opcodes/conversion.ts +21 -2
  89. package/src/public/avm/opcodes/ec_add.ts +3 -1
  90. package/src/public/avm/opcodes/environment_getters.ts +3 -1
  91. package/src/public/avm/opcodes/external_calls.ts +16 -8
  92. package/src/public/avm/opcodes/hashing.ts +11 -3
  93. package/src/public/avm/opcodes/instruction.ts +14 -7
  94. package/src/public/avm/opcodes/memory.ts +23 -6
  95. package/src/public/avm/opcodes/misc.ts +4 -4
  96. package/src/public/avm/opcodes/storage.ts +13 -3
  97. package/src/public/fixtures/index.ts +1 -0
  98. package/src/public/fixtures/minimal_public_tx.ts +57 -0
  99. package/src/public/public_tx_simulator/apps_tests/amm_test.ts +51 -20
  100. package/src/public/public_tx_simulator/public_tx_context.ts +26 -5
  101. package/src/public/side_effect_trace.ts +13 -0
  102. package/src/public/side_effect_trace_interface.ts +1 -0
  103. package/src/public/state_manager/state_manager.ts +4 -0
@@ -60,7 +60,7 @@ export class Set extends Instruction {
60
60
  const res = TaggedMemory.buildFromTagTruncating(this.value, this.inTag);
61
61
  const memory = context.machineState.memory;
62
62
  const addressing = Addressing.fromWire(this.indirect);
63
- context.machineState.consumeGas(this.gasCost());
63
+ context.machineState.consumeGas(this.baseGasCost(addressing.indirectOperandsCount(), addressing.relativeOperandsCount()));
64
64
  const operands = [
65
65
  this.dstOffset
66
66
  ];
@@ -95,7 +95,7 @@ export class Cast extends Instruction {
95
95
  async execute(context) {
96
96
  const memory = context.machineState.memory;
97
97
  const addressing = Addressing.fromWire(this.indirect);
98
- context.machineState.consumeGas(this.gasCost());
98
+ context.machineState.consumeGas(this.baseGasCost(addressing.indirectOperandsCount(), addressing.relativeOperandsCount()));
99
99
  const operands = [
100
100
  this.srcOffset,
101
101
  this.dstOffset
@@ -132,7 +132,7 @@ export class Mov extends Instruction {
132
132
  async execute(context) {
133
133
  const memory = context.machineState.memory;
134
134
  const addressing = Addressing.fromWire(this.indirect);
135
- context.machineState.consumeGas(this.gasCost());
135
+ context.machineState.consumeGas(this.baseGasCost(addressing.indirectOperandsCount(), addressing.relativeOperandsCount()));
136
136
  const operands = [
137
137
  this.srcOffset,
138
138
  this.dstOffset
@@ -163,6 +163,7 @@ export class CalldataCopy extends Instruction {
163
163
  async execute(context) {
164
164
  const memory = context.machineState.memory;
165
165
  const addressing = Addressing.fromWire(this.indirect);
166
+ context.machineState.consumeGas(this.baseGasCost(addressing.indirectOperandsCount(), addressing.relativeOperandsCount()));
166
167
  const operands = [
167
168
  this.copySizeOffset,
168
169
  this.cdStartOffset,
@@ -172,7 +173,7 @@ export class CalldataCopy extends Instruction {
172
173
  memory.checkTags(TypeTag.UINT32, cdStartOffset, copySizeOffset);
173
174
  const cdStart = memory.get(cdStartOffset).toNumber();
174
175
  const copySize = memory.get(copySizeOffset).toNumber();
175
- context.machineState.consumeGas(this.gasCost(copySize));
176
+ context.machineState.consumeGas(this.dynamicGasCost(copySize));
176
177
  // Values which are out-of-range of the calldata array will be set with Field(0);
177
178
  const slice = context.environment.calldata.slice(cdStart, cdStart + copySize).map((f)=>new Field(f));
178
179
  // slice has size = MIN(copySize, calldata.length - cdStart) as TS truncates out-of-range portion
@@ -200,11 +201,11 @@ export class ReturndataSize extends Instruction {
200
201
  async execute(context) {
201
202
  const memory = context.machineState.memory;
202
203
  const addressing = Addressing.fromWire(this.indirect);
204
+ context.machineState.consumeGas(this.baseGasCost(addressing.indirectOperandsCount(), addressing.relativeOperandsCount()));
203
205
  const operands = [
204
206
  this.dstOffset
205
207
  ];
206
208
  const [dstOffset] = addressing.resolve(operands, memory);
207
- context.machineState.consumeGas(this.gasCost());
208
209
  memory.set(dstOffset, new Uint32(context.machineState.nestedReturndata.length));
209
210
  }
210
211
  }
@@ -229,6 +230,7 @@ export class ReturndataCopy extends Instruction {
229
230
  async execute(context) {
230
231
  const memory = context.machineState.memory;
231
232
  const addressing = Addressing.fromWire(this.indirect);
233
+ context.machineState.consumeGas(this.baseGasCost(addressing.indirectOperandsCount(), addressing.relativeOperandsCount()));
232
234
  const operands = [
233
235
  this.copySizeOffset,
234
236
  this.rdStartOffset,
@@ -238,7 +240,7 @@ export class ReturndataCopy extends Instruction {
238
240
  memory.checkTags(TypeTag.UINT32, rdStartOffset, copySizeOffset);
239
241
  const rdStart = memory.get(rdStartOffset).toNumber();
240
242
  const copySize = memory.get(copySizeOffset).toNumber();
241
- context.machineState.consumeGas(this.gasCost(copySize));
243
+ context.machineState.consumeGas(this.dynamicGasCost(copySize));
242
244
  // Values which are out-of-range of the returndata array will be set with Field(0);
243
245
  const slice = context.machineState.nestedReturndata.slice(rdStart, rdStart + copySize).map((f)=>new Field(f));
244
246
  // slice has size = MIN(copySize, returndata.length - rdStart) as TS truncates out-of-range portion
@@ -27,6 +27,7 @@ export class DebugLog extends Instruction {
27
27
  async execute(context) {
28
28
  const memory = context.machineState.memory;
29
29
  const addressing = Addressing.fromWire(this.indirect);
30
+ context.machineState.consumeGas(this.baseGasCost(addressing.indirectOperandsCount(), addressing.relativeOperandsCount()));
30
31
  const operands = [
31
32
  this.messageOffset,
32
33
  this.fieldsOffset,
@@ -48,8 +49,5 @@ export class DebugLog extends Instruction {
48
49
  const formattedStr = applyStringFormatting(messageAsStr, fields.map((field)=>field.toFr()));
49
50
  DebugLog.logger.verbose(formattedStr);
50
51
  }
51
- // Despite having dynamic "size" operands, the gas cost is fixed because
52
- // this opcode is a no-op except during client-initiated simulation
53
- context.machineState.consumeGas(this.gasCost());
54
52
  }
55
53
  }
@@ -1 +1 @@
1
- {"version":3,"file":"storage.d.ts","sourceRoot":"","sources":["../../../../src/public/avm/opcodes/storage.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,UAAU,EAAE,MAAM,mBAAmB,CAAC;AAGpD,OAAO,EAAE,MAAM,EAAE,WAAW,EAAE,MAAM,+CAA+C,CAAC;AAEpF,OAAO,EAAE,WAAW,EAAE,MAAM,kBAAkB,CAAC;AAE/C,uBAAe,sBAAuB,SAAQ,WAAW;IAUrD,SAAS,CAAC,QAAQ,EAAE,MAAM;IAC1B,SAAS,CAAC,OAAO,EAAE,MAAM;IACzB,SAAS,CAAC,OAAO,EAAE,MAAM;IAV3B,gBAAuB,UAAU,EAAE,WAAW,EAAE,CAK9C;gBAGU,QAAQ,EAAE,MAAM,EAChB,OAAO,EAAE,MAAM,EACf,OAAO,EAAE,MAAM;CAI5B;AAED,qBAAa,MAAO,SAAQ,sBAAsB;IAChD,MAAM,CAAC,QAAQ,CAAC,IAAI,EAAE,MAAM,CAAY;IACxC,MAAM,CAAC,QAAQ,CAAC,MAAM,iBAAiB;gBAE3B,QAAQ,EAAE,MAAM,EAAE,SAAS,EAAE,MAAM,EAAE,UAAU,EAAE,MAAM;IAItD,OAAO,CAAC,OAAO,EAAE,UAAU,GAAG,OAAO,CAAC,IAAI,CAAC;CAmBzD;AAED,qBAAa,KAAM,SAAQ,sBAAsB;IAC/C,MAAM,CAAC,QAAQ,CAAC,IAAI,EAAE,MAAM,CAAW;IACvC,MAAM,CAAC,QAAQ,CAAC,MAAM,gBAAgB;gBAE1B,QAAQ,EAAE,MAAM,EAAE,UAAU,EAAE,MAAM,EAAE,SAAS,EAAE,MAAM;IAItD,OAAO,CAAC,OAAO,EAAE,UAAU,GAAG,OAAO,CAAC,IAAI,CAAC;CAczD"}
1
+ {"version":3,"file":"storage.d.ts","sourceRoot":"","sources":["../../../../src/public/avm/opcodes/storage.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,UAAU,EAAE,MAAM,mBAAmB,CAAC;AAGpD,OAAO,EAAE,MAAM,EAAE,WAAW,EAAE,MAAM,+CAA+C,CAAC;AAEpF,OAAO,EAAE,WAAW,EAAE,MAAM,kBAAkB,CAAC;AAE/C,uBAAe,sBAAuB,SAAQ,WAAW;IAUrD,SAAS,CAAC,QAAQ,EAAE,MAAM;IAC1B,SAAS,CAAC,OAAO,EAAE,MAAM;IACzB,SAAS,CAAC,OAAO,EAAE,MAAM;IAV3B,gBAAuB,UAAU,EAAE,WAAW,EAAE,CAK9C;gBAGU,QAAQ,EAAE,MAAM,EAChB,OAAO,EAAE,MAAM,EACf,OAAO,EAAE,MAAM;CAI5B;AAED,qBAAa,MAAO,SAAQ,sBAAsB;IAChD,MAAM,CAAC,QAAQ,CAAC,IAAI,EAAE,MAAM,CAAY;IACxC,MAAM,CAAC,QAAQ,CAAC,MAAM,iBAAiB;gBAE3B,QAAQ,EAAE,MAAM,EAAE,SAAS,EAAE,MAAM,EAAE,UAAU,EAAE,MAAM;IAItD,OAAO,CAAC,OAAO,EAAE,UAAU,GAAG,OAAO,CAAC,IAAI,CAAC;CA2BzD;AAED,qBAAa,KAAM,SAAQ,sBAAsB;IAC/C,MAAM,CAAC,QAAQ,CAAC,IAAI,EAAE,MAAM,CAAW;IACvC,MAAM,CAAC,QAAQ,CAAC,MAAM,gBAAgB;gBAE1B,QAAQ,EAAE,MAAM,EAAE,UAAU,EAAE,MAAM,EAAE,SAAS,EAAE,MAAM;IAItD,OAAO,CAAC,OAAO,EAAE,UAAU,GAAG,OAAO,CAAC,IAAI,CAAC;CAgBzD"}
@@ -30,15 +30,17 @@ export class SStore extends BaseStorageInstruction {
30
30
  }
31
31
  const memory = context.machineState.memory;
32
32
  const addressing = Addressing.fromWire(this.indirect);
33
- context.machineState.consumeGas(this.gasCost());
33
+ context.machineState.consumeGas(this.baseGasCost(addressing.indirectOperandsCount(), addressing.relativeOperandsCount()));
34
34
  const operands = [
35
35
  this.aOffset,
36
36
  this.bOffset
37
37
  ];
38
38
  const [srcOffset, slotOffset] = addressing.resolve(operands, memory);
39
+ // We read before tag checking since it's needed for gas cost calculation
40
+ const slot = memory.get(slotOffset).toFr();
41
+ context.machineState.consumeGas(this.dynamicGasCost(Number(context.persistableState.isStorageCold(context.environment.address, slot))));
39
42
  memory.checkTag(TypeTag.FIELD, slotOffset);
40
43
  memory.checkTag(TypeTag.FIELD, srcOffset);
41
- const slot = memory.get(slotOffset).toFr();
42
44
  const value = memory.get(srcOffset).toFr();
43
45
  await context.persistableState.writeStorage(context.environment.address, slot, value);
44
46
  }
@@ -52,7 +54,7 @@ export class SLoad extends BaseStorageInstruction {
52
54
  async execute(context) {
53
55
  const memory = context.machineState.memory;
54
56
  const addressing = Addressing.fromWire(this.indirect);
55
- context.machineState.consumeGas(this.gasCost());
57
+ context.machineState.consumeGas(this.baseGasCost(addressing.indirectOperandsCount(), addressing.relativeOperandsCount()));
56
58
  const operands = [
57
59
  this.aOffset,
58
60
  this.bOffset
@@ -1,4 +1,5 @@
1
1
  export * from './public_tx_simulation_tester.js';
2
2
  export * from './utils.js';
3
3
  export * from './simple_contract_data_source.js';
4
+ export { readAvmMinimalPublicTxInputsFromFile, createAvmMinimalPublicTx } from './minimal_public_tx.js';
4
5
  //# sourceMappingURL=index.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/public/fixtures/index.ts"],"names":[],"mappings":"AAAA,cAAc,kCAAkC,CAAC;AACjD,cAAc,YAAY,CAAC;AAC3B,cAAc,kCAAkC,CAAC"}
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/public/fixtures/index.ts"],"names":[],"mappings":"AAAA,cAAc,kCAAkC,CAAC;AACjD,cAAc,YAAY,CAAC;AAC3B,cAAc,kCAAkC,CAAC;AACjD,OAAO,EAAE,oCAAoC,EAAE,wBAAwB,EAAE,MAAM,wBAAwB,CAAC"}
@@ -1,3 +1,4 @@
1
1
  export * from './public_tx_simulation_tester.js';
2
2
  export * from './utils.js';
3
3
  export * from './simple_contract_data_source.js';
4
+ export { readAvmMinimalPublicTxInputsFromFile, createAvmMinimalPublicTx } from './minimal_public_tx.js';
@@ -0,0 +1,9 @@
1
+ import { AvmCircuitInputs } from '@aztec/stdlib/avm';
2
+ import type { PublicTxResult } from '../public_tx_simulator/public_tx_simulator.js';
3
+ export declare function createAvmMinimalPublicTx(): Promise<PublicTxResult>;
4
+ /**
5
+ * Reads the AVM circuit inputs for the minimal public tx from a pre-generated JSON file.
6
+ * @returns The AvmCircuitInputs for the minimal public tx.
7
+ */
8
+ export declare function readAvmMinimalPublicTxInputsFromFile(): AvmCircuitInputs;
9
+ //# sourceMappingURL=minimal_public_tx.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"minimal_public_tx.d.ts","sourceRoot":"","sources":["../../../src/public/fixtures/minimal_public_tx.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,gBAAgB,EAAE,MAAM,mBAAmB,CAAC;AAQrD,OAAO,KAAK,EAAE,cAAc,EAAE,MAAM,+CAA+C,CAAC;AAGpF,wBAAsB,wBAAwB,IAAI,OAAO,CAAC,cAAc,CAAC,CAoCxE;AAED;;;GAGG;AACH,wBAAgB,oCAAoC,IAAI,gBAAgB,CAEvE"}
@@ -0,0 +1,43 @@
1
+ import { FunctionType, emptyContractArtifact, emptyFunctionArtifact } from '@aztec/stdlib/abi';
2
+ import { AvmCircuitInputs } from '@aztec/stdlib/avm';
3
+ import { AztecAddress } from '@aztec/stdlib/aztec-address';
4
+ import avmMinimalCircuitInputsJson from '../../../artifacts/avm_minimal_inputs.json' with {
5
+ type: 'json'
6
+ };
7
+ import { TypeTag } from '../avm/avm_memory_types.js';
8
+ import { Add, Return, Set } from '../avm/opcodes/index.js';
9
+ import { encodeToBytecode } from '../avm/serialization/bytecode_serialization.js';
10
+ import { Opcode } from '../avm/serialization/instruction_serialization.js';
11
+ import { PublicTxSimulationTester } from './public_tx_simulation_tester.js';
12
+ export async function createAvmMinimalPublicTx() {
13
+ const deployer = AztecAddress.fromNumber(42);
14
+ const simTester = await PublicTxSimulationTester.create();
15
+ const minimalBytecode = encodeToBytecode([
16
+ new Set(/*indirect*/ 0, /*dstOffset*/ 0, TypeTag.UINT32, /*value*/ 1).as(Opcode.SET_8, Set.wireFormat8),
17
+ new Set(/*indirect*/ 0, /*dstOffset*/ 1, TypeTag.UINT32, /*value*/ 2).as(Opcode.SET_8, Set.wireFormat8),
18
+ new Add(/*indirect=*/ 0, /*aOffset=*/ 0, /*bOffset=*/ 1, /*dstOffset=*/ 2).as(Opcode.ADD_8, Add.wireFormat8),
19
+ new Return(/*indirect=*/ 0, /*copySizeOffset=*/ 0, /*returnOffset=*/ 2)
20
+ ]);
21
+ const minimalContractArtifact = emptyContractArtifact();
22
+ minimalContractArtifact.name = 'MinimalContract';
23
+ minimalContractArtifact.functions = [
24
+ emptyFunctionArtifact()
25
+ ];
26
+ minimalContractArtifact.functions[0].name = 'public_dispatch';
27
+ minimalContractArtifact.functions[0].functionType = FunctionType.PUBLIC;
28
+ minimalContractArtifact.functions[0].bytecode = minimalBytecode;
29
+ const minimalTestContract = await simTester.registerAndDeployContract(/*constructorArgs=*/ [], deployer, /*contractArtifact=*/ minimalContractArtifact);
30
+ return await simTester.simulateTx(/*sender=*/ deployer, /*setupCalls=*/ [], /*appCalls=*/ [
31
+ {
32
+ address: minimalTestContract.address,
33
+ fnName: 'public_dispatch',
34
+ args: []
35
+ }
36
+ ]);
37
+ }
38
+ /**
39
+ * Reads the AVM circuit inputs for the minimal public tx from a pre-generated JSON file.
40
+ * @returns The AvmCircuitInputs for the minimal public tx.
41
+ */ export function readAvmMinimalPublicTxInputsFromFile() {
42
+ return AvmCircuitInputs.schema.parse(avmMinimalCircuitInputsJson);
43
+ }
@@ -1 +1 @@
1
- {"version":3,"file":"amm_test.d.ts","sourceRoot":"","sources":["../../../../src/public/public_tx_simulator/apps_tests/amm_test.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,MAAM,EAAE,MAAM,uBAAuB,CAAC;AAKpD,OAAO,EAAE,wBAAwB,EAAE,MAAM,+CAA+C,CAAC;AAIzF;;;;GAIG;AACH,wBAAsB,OAAO,CAAC,MAAM,EAAE,wBAAwB,EAAE,MAAM,EAAE,MAAM,iBAoG7E"}
1
+ {"version":3,"file":"amm_test.d.ts","sourceRoot":"","sources":["../../../../src/public/public_tx_simulator/apps_tests/amm_test.ts"],"names":[],"mappings":"AAGA,OAAO,KAAK,EAAE,MAAM,EAAE,MAAM,uBAAuB,CAAC;AAKpD,OAAO,EAAE,wBAAwB,EAAE,MAAM,+CAA+C,CAAC;AAIzF;;;;GAIG;AACH,wBAAsB,OAAO,CAAC,MAAM,EAAE,wBAAwB,EAAE,MAAM,EAAE,MAAM,iBAoG7E"}
@@ -1,3 +1,5 @@
1
+ import { GeneratorIndex } from '@aztec/constants';
2
+ import { poseidon2HashWithSeparator } from '@aztec/foundation/crypto';
1
3
  import { Fr } from '@aztec/foundation/fields';
2
4
  import { AMMContractArtifact } from '@aztec/noir-contracts.js/AMM';
3
5
  import { AztecAddress } from '@aztec/stdlib/aztec-address';
@@ -69,6 +71,9 @@ async function addLiquidity(tester, sender, amm, token0, token1, liquidityToken,
69
71
  const liquidityPartialNote = {
70
72
  commitment: new Fr(99)
71
73
  };
74
+ const refundToken0PartialNoteValidityCommitment = await computePartialNoteValidityCommitment(refundToken0PartialNote, amm.address);
75
+ const refundToken1PartialNoteValidityCommitment = await computePartialNoteValidityCommitment(refundToken1PartialNote, amm.address);
76
+ const liquidityPartialNoteValidityCommitment = await computePartialNoteValidityCommitment(liquidityPartialNote, amm.address);
72
77
  return await tester.simulateTxWithLabel(/*txLabel=*/ 'AMM/add_liquidity', /*sender=*/ sender, /*setupCalls=*/ [], /*appCalls=*/ [
73
78
  // token0.transfer_to_public enqueues a call to _increase_public_balance
74
79
  {
@@ -80,12 +85,12 @@ async function addLiquidity(tester, sender, amm, token0, token1, liquidityToken,
80
85
  ],
81
86
  address: token0.address
82
87
  },
83
- // token0.prepare_private_balance_increase enqueues a call to _store_balances_set_partial_note
88
+ // token0.prepare_private_balance_increase enqueues a call to _set_uint_partial_note_validity
84
89
  {
85
90
  sender: token0.address,
86
- fnName: '_store_balances_set_partial_note',
91
+ fnName: '_set_uint_partial_note_validity',
87
92
  args: [
88
- refundToken0PartialNote
93
+ refundToken0PartialNoteValidityCommitment
89
94
  ],
90
95
  address: token0.address
91
96
  },
@@ -99,21 +104,21 @@ async function addLiquidity(tester, sender, amm, token0, token1, liquidityToken,
99
104
  ],
100
105
  address: token1.address
101
106
  },
102
- // token1.prepare_private_balance_increase enqueues a call to _store_balances_set_partial_note
107
+ // token1.prepare_private_balance_increase enqueues a call to _set_uint_partial_note_validity
103
108
  {
104
109
  sender: token1.address,
105
- fnName: '_store_balances_set_partial_note',
110
+ fnName: '_set_uint_partial_note_validity',
106
111
  args: [
107
- refundToken1PartialNote
112
+ refundToken1PartialNoteValidityCommitment
108
113
  ],
109
114
  address: token1.address
110
115
  },
111
- // liquidityToken.prepare_private_balance_increase enqueues a call to _store_balances_set_partial_note
116
+ // liquidityToken.prepare_private_balance_increase enqueues a call to _set_uint_partial_note_validity
112
117
  {
113
118
  sender: liquidityToken.address,
114
- fnName: '_store_balances_set_partial_note',
119
+ fnName: '_set_uint_partial_note_validity',
115
120
  args: [
116
- liquidityPartialNote
121
+ liquidityPartialNoteValidityCommitment
117
122
  ],
118
123
  address: liquidityToken.address
119
124
  },
@@ -144,6 +149,7 @@ async function swapExactTokensForTokens(tester, sender, amm, tokenIn, tokenOut,
144
149
  const tokenOutPartialNote = {
145
150
  commitment: new Fr(66)
146
151
  };
152
+ const tokenOutPartialNoteValidityCommitment = await computePartialNoteValidityCommitment(tokenOutPartialNote, amm.address);
147
153
  return await tester.simulateTxWithLabel(/*txLabel=*/ 'AMM/swap_exact_tokens_for_tokens', /*sender=*/ sender, /*setupCalls=*/ [], /*appCalls=*/ [
148
154
  // tokenIn.transfer_to_public enqueues a call to _increase_public_balance
149
155
  {
@@ -155,12 +161,12 @@ async function swapExactTokensForTokens(tester, sender, amm, tokenIn, tokenOut,
155
161
  ],
156
162
  address: tokenIn.address
157
163
  },
158
- // tokenOut.prepare_private_balance_increase enqueues a call to _store_balances_set_partial_note
164
+ // tokenOut.prepare_private_balance_increase enqueues a call to _set_uint_partial_note_validity
159
165
  {
160
166
  sender: tokenOut.address,
161
- fnName: '_store_balances_set_partial_note',
167
+ fnName: '_set_uint_partial_note_validity',
162
168
  args: [
163
- tokenOutPartialNote
169
+ tokenOutPartialNoteValidityCommitment
164
170
  ],
165
171
  address: tokenOut.address
166
172
  },
@@ -185,6 +191,8 @@ async function removeLiquidity(tester, sender, amm, token0, token1, liquidityTok
185
191
  const token1PartialNote = {
186
192
  commitment: new Fr(222)
187
193
  };
194
+ const token0PartialNoteValidityCommitment = await computePartialNoteValidityCommitment(token0PartialNote, amm.address);
195
+ const token1PartialNoteValidityCommitment = await computePartialNoteValidityCommitment(token1PartialNote, amm.address);
188
196
  return await tester.simulateTxWithLabel(/*txLabel=*/ 'AMM/remove_liquidity', /*sender=*/ sender, /*setupCalls=*/ [], /*appCalls=*/ [
189
197
  // liquidityToken.transfer_to_public enqueues a call to _increase_public_balance
190
198
  {
@@ -196,21 +204,21 @@ async function removeLiquidity(tester, sender, amm, token0, token1, liquidityTok
196
204
  ],
197
205
  address: liquidityToken.address
198
206
  },
199
- // token0.prepare_private_balance_increase enqueues a call to _store_balances_set_partial_note
207
+ // token0.prepare_private_balance_increase enqueues a call to _set_uint_partial_note_validity
200
208
  {
201
209
  sender: token0.address,
202
- fnName: '_store_balances_set_partial_note',
210
+ fnName: '_set_uint_partial_note_validity',
203
211
  args: [
204
- token0PartialNote
212
+ token0PartialNoteValidityCommitment
205
213
  ],
206
214
  address: token0.address
207
215
  },
208
- // token1.prepare_private_balance_increase enqueues a call to _store_balances_set_partial_note
216
+ // token1.prepare_private_balance_increase enqueues a call to _set_uint_partial_note_validity
209
217
  {
210
218
  sender: token1.address,
211
- fnName: '_store_balances_set_partial_note',
219
+ fnName: '_set_uint_partial_note_validity',
212
220
  args: [
213
- token1PartialNote
221
+ token1PartialNoteValidityCommitment
214
222
  ],
215
223
  address: token1.address
216
224
  },
@@ -235,3 +243,9 @@ async function removeLiquidity(tester, sender, amm, token0, token1, liquidityTok
235
243
  }
236
244
  ]);
237
245
  }
246
+ async function computePartialNoteValidityCommitment(partialNote, completer) {
247
+ return await poseidon2HashWithSeparator([
248
+ partialNote.commitment,
249
+ completer
250
+ ], GeneratorIndex.PARTIAL_NOTE_VALIDITY_COMMITMENT);
251
+ }
@@ -3,7 +3,7 @@ import { AvmCircuitPublicInputs, RevertCode } from '@aztec/stdlib/avm';
3
3
  import type { AztecAddress } from '@aztec/stdlib/aztec-address';
4
4
  import type { SimulationError } from '@aztec/stdlib/errors';
5
5
  import { Gas } from '@aztec/stdlib/gas';
6
- import { type PrivateToPublicAccumulatedData } from '@aztec/stdlib/kernel';
6
+ import { PrivateToPublicAccumulatedData } from '@aztec/stdlib/kernel';
7
7
  import { type GlobalVariables, PublicCallRequestWithCalldata, type Tx, TxExecutionPhase, type TxHash } from '@aztec/stdlib/tx';
8
8
  import type { PublicContractsDBInterface } from '../db_interfaces.js';
9
9
  import type { PublicTreesDB } from '../public_db_sources.js';
@@ -1 +1 @@
1
- {"version":3,"file":"public_tx_context.d.ts","sourceRoot":"","sources":["../../../src/public/public_tx_simulator/public_tx_context.ts"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"public_tx_context.d.ts","sourceRoot":"","sources":["../../../src/public/public_tx_simulator/public_tx_context.ts"],"names":[],"mappings":"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"}
@@ -2,10 +2,10 @@ import { MAX_ENQUEUED_CALLS_PER_TX, MAX_L2_GAS_PER_TX_PUBLIC_PORTION, MAX_L2_TO_
2
2
  import { padArrayEnd } from '@aztec/foundation/collection';
3
3
  import { Fr } from '@aztec/foundation/fields';
4
4
  import { createLogger } from '@aztec/foundation/log';
5
- import { AvmAccumulatedData, AvmCircuitPublicInputs, PublicDataWrite, RevertCode } from '@aztec/stdlib/avm';
5
+ import { AvmAccumulatedData, AvmAccumulatedDataArrayLengths, AvmCircuitPublicInputs, PublicDataWrite, RevertCode } from '@aztec/stdlib/avm';
6
6
  import { computeTransactionFee } from '@aztec/stdlib/fees';
7
7
  import { Gas } from '@aztec/stdlib/gas';
8
- import { PrivateToAvmAccumulatedData, PrivateToAvmAccumulatedDataArrayLengths, PublicCallRequest, countAccumulatedItems } from '@aztec/stdlib/kernel';
8
+ import { PrivateToAvmAccumulatedData, PrivateToAvmAccumulatedDataArrayLengths, PublicCallRequest, PublicCallRequestArrayLengths, countAccumulatedItems } from '@aztec/stdlib/kernel';
9
9
  import { PublicLog } from '@aztec/stdlib/logs';
10
10
  import { ScopedL2ToL1Message } from '@aztec/stdlib/messaging';
11
11
  import { MerkleTreeId } from '@aztec/stdlib/trees';
@@ -241,8 +241,9 @@ import { getCallRequestsWithCalldataByPhase } from '../utils.js';
241
241
  const endTreeSnapshots = await stateManager.getTreeSnapshots();
242
242
  // This converts the private accumulated data to the avm accumulated data format.
243
243
  const convertAccumulatedData = (from)=>new PrivateToAvmAccumulatedData(from.noteHashes, from.nullifiers, from.l2ToL1Msgs);
244
- const getArrayLengths = (from)=>new PrivateToAvmAccumulatedDataArrayLengths(countAccumulatedItems(from.noteHashes), countAccumulatedItems(from.nullifiers), countAccumulatedItems(from.l2ToL1Msgs));
245
- return new AvmCircuitPublicInputs(this.globalVariables, this.startTreeSnapshots, /*startGasUsed=*/ this.gasUsedByPrivate, this.gasSettings, this.feePayer, /*publicSetupCallRequests=*/ padArrayEnd(this.setupCallRequests.map((r)=>r.request), PublicCallRequest.empty(), MAX_ENQUEUED_CALLS_PER_TX), /*publicAppLogicCallRequests=*/ padArrayEnd(this.appLogicCallRequests.map((r)=>r.request), PublicCallRequest.empty(), MAX_ENQUEUED_CALLS_PER_TX), /*publicTeardownCallRequests=*/ this.teardownCallRequests.length > 0 ? this.teardownCallRequests[0].request : PublicCallRequest.empty(), getArrayLengths(this.nonRevertibleAccumulatedDataFromPrivate), getArrayLengths(this.revertibleAccumulatedDataFromPrivate), convertAccumulatedData(this.nonRevertibleAccumulatedDataFromPrivate), convertAccumulatedData(this.revertibleAccumulatedDataFromPrivate), endTreeSnapshots, this.getTotalGasUsed(), accumulatedData, /*transactionFee=*/ this.getTransactionFeeUnsafe(), /*isReverted=*/ !this.revertCode.isOK());
244
+ const getPreviousAccumulatedDataArrayLengths = (from)=>new PrivateToAvmAccumulatedDataArrayLengths(countAccumulatedItems(from.noteHashes), countAccumulatedItems(from.nullifiers), countAccumulatedItems(from.l2ToL1Msgs));
245
+ const getAvmAccumulatedDataArrayLengths = (from)=>new AvmAccumulatedDataArrayLengths(from.noteHashes.length, from.nullifiers.length, from.l2ToL1Msgs.length, from.publicLogs.length, from.publicDataWrites.length);
246
+ return new AvmCircuitPublicInputs(this.globalVariables, this.startTreeSnapshots, /*startGasUsed=*/ this.gasUsedByPrivate, this.gasSettings, this.feePayer, /*publicCallRequestArrayLengths=*/ new PublicCallRequestArrayLengths(this.setupCallRequests.length, this.appLogicCallRequests.length, this.teardownCallRequests.length > 0), /*publicSetupCallRequests=*/ padArrayEnd(this.setupCallRequests.map((r)=>r.request), PublicCallRequest.empty(), MAX_ENQUEUED_CALLS_PER_TX), /*publicAppLogicCallRequests=*/ padArrayEnd(this.appLogicCallRequests.map((r)=>r.request), PublicCallRequest.empty(), MAX_ENQUEUED_CALLS_PER_TX), /*publicTeardownCallRequests=*/ this.teardownCallRequests.length > 0 ? this.teardownCallRequests[0].request : PublicCallRequest.empty(), getPreviousAccumulatedDataArrayLengths(this.nonRevertibleAccumulatedDataFromPrivate), getPreviousAccumulatedDataArrayLengths(this.revertibleAccumulatedDataFromPrivate), convertAccumulatedData(this.nonRevertibleAccumulatedDataFromPrivate), convertAccumulatedData(this.revertibleAccumulatedDataFromPrivate), endTreeSnapshots, this.getTotalGasUsed(), getAvmAccumulatedDataArrayLengths(accumulatedData), accumulatedData, /*transactionFee=*/ this.getTransactionFeeUnsafe(), /*isReverted=*/ !this.revertCode.isOK());
246
247
  }
247
248
  }
248
249
  /**
@@ -40,6 +40,7 @@ export declare class SideEffectTrace implements PublicSideEffectTraceInterface {
40
40
  private readonly previousSideEffectArrayLengths;
41
41
  /** We need to track the set of class IDs used, to enforce limits. */
42
42
  private uniqueClassIds;
43
+ private writtenPublicDataSlots;
43
44
  log: import("@aztec/foundation/log").Logger;
44
45
  /** The side effect counter increments with every call to the trace. */
45
46
  private sideEffectCounter;
@@ -60,13 +61,15 @@ export declare class SideEffectTrace implements PublicSideEffectTraceInterface {
60
61
  */
61
62
  previousSideEffectArrayLengths?: SideEffectArrayLengths,
62
63
  /** We need to track the set of class IDs used, to enforce limits. */
63
- uniqueClassIds?: UniqueClassIds);
64
+ uniqueClassIds?: UniqueClassIds, writtenPublicDataSlots?: Set<string>);
64
65
  fork(): SideEffectTrace;
65
66
  merge(forkedTrace: this, reverted?: boolean): void;
66
67
  getCounter(): number;
67
68
  private incrementSideEffectCounter;
68
69
  getNoteHashCount(): number;
69
70
  tracePublicStorageWrite(contractAddress: AztecAddress, slot: Fr, value: Fr, protocolWrite: boolean): Promise<void>;
71
+ private computePublicDataSlotKey;
72
+ isStorageCold(contractAddress: AztecAddress, slot: Fr): boolean;
70
73
  traceNewNoteHash(noteHash: Fr): void;
71
74
  traceNewNullifier(siloedNullifier: Fr): void;
72
75
  traceNewL2ToL1Message(contractAddress: AztecAddress, recipient: Fr, content: Fr): void;
@@ -1 +1 @@
1
- {"version":3,"file":"side_effect_trace.d.ts","sourceRoot":"","sources":["../../src/public/side_effect_trace.ts"],"names":[],"mappings":"AAYA,OAAO,EAAE,EAAE,EAAE,MAAM,0BAA0B,CAAC;AAE9C,OAAO,EAAE,uBAAuB,EAAE,MAAM,mBAAmB,CAAC;AAC5D,OAAO,KAAK,EAAE,YAAY,EAAE,MAAM,6BAA6B,CAAC;AAEhE,OAAO,EAAE,QAAQ,EAAE,SAAS,EAAE,MAAM,sBAAsB,CAAC;AAC3D,OAAO,EAAE,SAAS,EAAE,MAAM,oBAAoB,CAAC;AAC/C,OAAO,EAAiB,mBAAmB,EAAE,MAAM,yBAAyB,CAAC;AAK7E,OAAO,KAAK,EAAE,8BAA8B,EAAE,MAAM,kCAAkC,CAAC;AACvF,OAAO,EAAE,cAAc,EAAE,MAAM,uBAAuB,CAAC;AAEvD;;;;IAII;AACJ,MAAM,MAAM,WAAW,GAAG;IACxB,gBAAgB,EAAE,uBAAuB,EAAE,CAAC;IAC5C,UAAU,EAAE,QAAQ,EAAE,CAAC;IACvB,UAAU,EAAE,SAAS,EAAE,CAAC;IACxB,UAAU,EAAE,mBAAmB,EAAE,CAAC;IAClC,UAAU,EAAE,SAAS,EAAE,CAAC;CACzB,CAAC;AAEF,qBAAa,sBAAsB;aAEf,gBAAgB,EAAE,MAAM;aACxB,wBAAwB,EAAE,MAAM;aAChC,UAAU,EAAE,MAAM;aAClB,UAAU,EAAE,MAAM;aAClB,UAAU,EAAE,MAAM;aAClB,UAAU,EAAE,MAAM;gBALlB,gBAAgB,EAAE,MAAM,EACxB,wBAAwB,EAAE,MAAM,EAChC,UAAU,EAAE,MAAM,EAClB,UAAU,EAAE,MAAM,EAClB,UAAU,EAAE,MAAM,EAClB,UAAU,EAAE,MAAM;IAGpC,MAAM,CAAC,KAAK;CAGb;AAED;;GAEG;AACH,qBAAa,eAAgB,YAAW,8BAA8B;IAkBlE,qDAAqD;aACrC,sBAAsB,EAAE,MAAM;IAC9C;;OAEG;IACH,OAAO,CAAC,QAAQ,CAAC,8BAA8B;IAC/C,qEAAqE;IACrE,OAAO,CAAC,cAAc;IAxBjB,GAAG,yCAA+C;IAEzD,uEAAuE;IACvE,OAAO,CAAC,iBAAiB,CAAS;IAElC,OAAO,CAAC,gBAAgB,CAAiC;IACzD,OAAO,CAAC,8BAA8B,CAAa;IACnD,OAAO,CAAC,0BAA0B,CAAa;IAC/C,OAAO,CAAC,UAAU,CAAkB;IACpC,OAAO,CAAC,UAAU,CAAmB;IACrC,OAAO,CAAC,cAAc,CAA6B;IACnD,OAAO,CAAC,UAAU,CAAmB;IAErC,sDAAsD;IACtD,OAAO,CAAC,uBAAuB,CAAS;;IAGtC,qDAAqD;IACrC,sBAAsB,GAAE,MAAU;IAClD;;OAEG;IACc,8BAA8B,GAAE,sBAAuD;IACxG,qEAAqE;IAC7D,cAAc,GAAE,cAAqC;IAKxD,IAAI;IAeJ,KAAK,CAAC,WAAW,EAAE,IAAI,EAAE,QAAQ,GAAE,OAAe;IAoBlD,UAAU;IAIjB,OAAO,CAAC,0BAA0B;IAI3B,gBAAgB;IAIV,uBAAuB,CAClC,eAAe,EAAE,YAAY,EAC7B,IAAI,EAAE,EAAE,EACR,KAAK,EAAE,EAAE,EACT,aAAa,EAAE,OAAO,GACrB,OAAO,CAAC,IAAI,CAAC;IAkCT,gBAAgB,CAAC,QAAQ,EAAE,EAAE;IAU7B,iBAAiB,CAAC,eAAe,EAAE,EAAE;IAWrC,qBAAqB,CAAC,eAAe,EAAE,YAAY,EAAE,SAAS,EAAE,EAAE,EAAE,OAAO,EAAE,EAAE;IAW/E,cAAc,CAAC,eAAe,EAAE,YAAY,EAAE,GAAG,EAAE,EAAE,EAAE;IAcvD,qBAAqB,CAAC,eAAe,EAAE,EAAE,EAAE,MAAM,EAAE,OAAO;IAgB1D,cAAc,IAAI,WAAW;CASrC"}
1
+ {"version":3,"file":"side_effect_trace.d.ts","sourceRoot":"","sources":["../../src/public/side_effect_trace.ts"],"names":[],"mappings":"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"}
@@ -36,6 +36,7 @@ export class SideEffectArrayLengths {
36
36
  startSideEffectCounter;
37
37
  previousSideEffectArrayLengths;
38
38
  uniqueClassIds;
39
+ writtenPublicDataSlots;
39
40
  log;
40
41
  /** The side effect counter increments with every call to the trace. */ sideEffectCounter;
41
42
  publicDataWrites;
@@ -48,10 +49,11 @@ export class SideEffectArrayLengths {
48
49
  /** Make sure a forked trace is never merged twice. */ alreadyMergedIntoParent;
49
50
  constructor(/** The counter of this trace's first side effect. */ startSideEffectCounter = 0, /** Track parent's (or previous kernel's) lengths so the AVM can properly enforce TX-wide limits,
50
51
  * otherwise the public kernel can fail to prove because TX limits are breached.
51
- */ previousSideEffectArrayLengths = SideEffectArrayLengths.empty(), /** We need to track the set of class IDs used, to enforce limits. */ uniqueClassIds = new UniqueClassIds()){
52
+ */ previousSideEffectArrayLengths = SideEffectArrayLengths.empty(), /** We need to track the set of class IDs used, to enforce limits. */ uniqueClassIds = new UniqueClassIds(), writtenPublicDataSlots = new Set()){
52
53
  this.startSideEffectCounter = startSideEffectCounter;
53
54
  this.previousSideEffectArrayLengths = previousSideEffectArrayLengths;
54
55
  this.uniqueClassIds = uniqueClassIds;
56
+ this.writtenPublicDataSlots = writtenPublicDataSlots;
55
57
  this.log = createLogger('simulator:side_effect_trace');
56
58
  this.publicDataWrites = [];
57
59
  this.protocolPublicDataWritesLength = 0;
@@ -64,7 +66,7 @@ export class SideEffectArrayLengths {
64
66
  this.sideEffectCounter = startSideEffectCounter;
65
67
  }
66
68
  fork() {
67
- return new SideEffectTrace(this.sideEffectCounter, new SideEffectArrayLengths(this.previousSideEffectArrayLengths.publicDataWrites + this.userPublicDataWritesLength, this.previousSideEffectArrayLengths.protocolPublicDataWrites + this.protocolPublicDataWritesLength, this.previousSideEffectArrayLengths.noteHashes + this.noteHashes.length, this.previousSideEffectArrayLengths.nullifiers + this.nullifiers.length, this.previousSideEffectArrayLengths.l2ToL1Msgs + this.l2ToL1Messages.length, this.previousSideEffectArrayLengths.publicLogs + this.publicLogs.length), this.uniqueClassIds.fork());
69
+ return new SideEffectTrace(this.sideEffectCounter, new SideEffectArrayLengths(this.previousSideEffectArrayLengths.publicDataWrites + this.userPublicDataWritesLength, this.previousSideEffectArrayLengths.protocolPublicDataWrites + this.protocolPublicDataWritesLength, this.previousSideEffectArrayLengths.noteHashes + this.noteHashes.length, this.previousSideEffectArrayLengths.nullifiers + this.nullifiers.length, this.previousSideEffectArrayLengths.l2ToL1Msgs + this.l2ToL1Messages.length, this.previousSideEffectArrayLengths.publicLogs + this.publicLogs.length), this.uniqueClassIds.fork(), new Set(this.writtenPublicDataSlots));
68
70
  }
69
71
  merge(forkedTrace, reverted = false) {
70
72
  // sanity check to avoid merging the same forked trace twice
@@ -72,6 +74,8 @@ export class SideEffectArrayLengths {
72
74
  forkedTrace.alreadyMergedIntoParent = true;
73
75
  this.sideEffectCounter = forkedTrace.sideEffectCounter;
74
76
  this.uniqueClassIds.acceptAndMerge(forkedTrace.uniqueClassIds);
77
+ // Accept even if reverted, since the user already paid for the writes
78
+ this.writtenPublicDataSlots = new Set(forkedTrace.writtenPublicDataSlots);
75
79
  if (!reverted) {
76
80
  this.publicDataWrites.push(...forkedTrace.publicDataWrites);
77
81
  this.noteHashes.push(...forkedTrace.noteHashes);
@@ -105,6 +109,13 @@ export class SideEffectArrayLengths {
105
109
  this.publicDataWrites.push(new PublicDataUpdateRequest(leafSlot, value, this.sideEffectCounter));
106
110
  this.log.trace(`Traced public data write (address=${contractAddress}, slot=${slot}): value=${value} (counter=${this.sideEffectCounter}, isProtocol:${protocolWrite})`);
107
111
  this.incrementSideEffectCounter();
112
+ this.writtenPublicDataSlots.add(this.computePublicDataSlotKey(contractAddress, slot));
113
+ }
114
+ computePublicDataSlotKey(contractAddress, slot) {
115
+ return `${contractAddress.toString()}:${slot.toString()}`;
116
+ }
117
+ isStorageCold(contractAddress, slot) {
118
+ return !this.writtenPublicDataSlots.has(this.computePublicDataSlotKey(contractAddress, slot));
108
119
  }
109
120
  traceNewNoteHash(noteHash) {
110
121
  if (this.noteHashes.length + this.previousSideEffectArrayLengths.noteHashes >= MAX_NOTE_HASHES_PER_TX) {
@@ -6,6 +6,7 @@ export interface PublicSideEffectTraceInterface {
6
6
  getCounter(): number;
7
7
  tracePublicStorageWrite(contractAddress: AztecAddress, slot: Fr, // This is the storage slot not the computed leaf slot
8
8
  value: Fr, protocolWrite: boolean): Promise<void>;
9
+ isStorageCold(contractAddress: AztecAddress, slot: Fr): boolean;
9
10
  traceNewNoteHash(uniqueNoteHash: Fr): void;
10
11
  getNoteHashCount(): number;
11
12
  traceNewNullifier(siloedNullifier: Fr): void;
@@ -1 +1 @@
1
- {"version":3,"file":"side_effect_trace_interface.d.ts","sourceRoot":"","sources":["../../src/public/side_effect_trace_interface.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,EAAE,EAAE,MAAM,0BAA0B,CAAC;AACnD,OAAO,KAAK,EAAE,YAAY,EAAE,MAAM,6BAA6B,CAAC;AAEhE,MAAM,WAAW,8BAA8B;IAC7C,IAAI,IAAI,8BAA8B,CAAC;IACvC,KAAK,CAAC,WAAW,EAAE,8BAA8B,EAAE,QAAQ,CAAC,EAAE,OAAO,GAAG,IAAI,CAAC;IAC7E,UAAU,IAAI,MAAM,CAAC;IAErB,uBAAuB,CACrB,eAAe,EAAE,YAAY,EAC7B,IAAI,EAAE,EAAE,EAAE,sDAAsD;IAChE,KAAK,EAAE,EAAE,EACT,aAAa,EAAE,OAAO,GACrB,OAAO,CAAC,IAAI,CAAC,CAAC;IACjB,gBAAgB,CAAC,cAAc,EAAE,EAAE,GAAG,IAAI,CAAC;IAC3C,gBAAgB,IAAI,MAAM,CAAC;IAC3B,iBAAiB,CAAC,eAAe,EAAE,EAAE,GAAG,IAAI,CAAC;IAC7C,qBAAqB,CAAC,eAAe,EAAE,YAAY,EAAE,SAAS,EAAE,EAAE,EAAE,OAAO,EAAE,EAAE,GAAG,IAAI,CAAC;IACvF,cAAc,CAAC,eAAe,EAAE,YAAY,EAAE,GAAG,EAAE,EAAE,EAAE,GAAG,IAAI,CAAC;IAC/D,qBAAqB,CAAC,eAAe,EAAE,EAAE,EAAE,MAAM,EAAE,OAAO,GAAG,IAAI,CAAC;CACnE"}
1
+ {"version":3,"file":"side_effect_trace_interface.d.ts","sourceRoot":"","sources":["../../src/public/side_effect_trace_interface.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,EAAE,EAAE,MAAM,0BAA0B,CAAC;AACnD,OAAO,KAAK,EAAE,YAAY,EAAE,MAAM,6BAA6B,CAAC;AAEhE,MAAM,WAAW,8BAA8B;IAC7C,IAAI,IAAI,8BAA8B,CAAC;IACvC,KAAK,CAAC,WAAW,EAAE,8BAA8B,EAAE,QAAQ,CAAC,EAAE,OAAO,GAAG,IAAI,CAAC;IAC7E,UAAU,IAAI,MAAM,CAAC;IAErB,uBAAuB,CACrB,eAAe,EAAE,YAAY,EAC7B,IAAI,EAAE,EAAE,EAAE,sDAAsD;IAChE,KAAK,EAAE,EAAE,EACT,aAAa,EAAE,OAAO,GACrB,OAAO,CAAC,IAAI,CAAC,CAAC;IACjB,aAAa,CAAC,eAAe,EAAE,YAAY,EAAE,IAAI,EAAE,EAAE,GAAG,OAAO,CAAC;IAChE,gBAAgB,CAAC,cAAc,EAAE,EAAE,GAAG,IAAI,CAAC;IAC3C,gBAAgB,IAAI,MAAM,CAAC;IAC3B,iBAAiB,CAAC,eAAe,EAAE,EAAE,GAAG,IAAI,CAAC;IAC7C,qBAAqB,CAAC,eAAe,EAAE,YAAY,EAAE,SAAS,EAAE,EAAE,EAAE,OAAO,EAAE,EAAE,GAAG,IAAI,CAAC;IACvF,cAAc,CAAC,eAAe,EAAE,YAAY,EAAE,GAAG,EAAE,EAAE,EAAE,GAAG,IAAI,CAAC;IAC/D,qBAAqB,CAAC,eAAe,EAAE,EAAE,EAAE,MAAM,EAAE,OAAO,GAAG,IAAI,CAAC;CACnE"}
@@ -60,6 +60,7 @@ export declare class PublicPersistableStateManager {
60
60
  * @param value - the value being written to the slot
61
61
  */
62
62
  writeStorage(contractAddress: AztecAddress, slot: Fr, value: Fr, protocolWrite?: boolean): Promise<void>;
63
+ isStorageCold(contractAddress: AztecAddress, slot: Fr): boolean;
63
64
  /**
64
65
  * Read from public storage.
65
66
  *
@@ -1 +1 @@
1
- {"version":3,"file":"state_manager.d.ts","sourceRoot":"","sources":["../../../src/public/state_manager/state_manager.ts"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"state_manager.d.ts","sourceRoot":"","sources":["../../../src/public/state_manager/state_manager.ts"],"names":[],"mappings":"AASA,OAAO,EAAE,EAAE,EAAE,MAAM,0BAA0B,CAAC;AAI9C,OAAO,EAAE,YAAY,EAAE,MAAM,6BAA6B,CAAC;AAC3D,OAAO,KAAK,EAAE,iCAAiC,EAA+B,MAAM,wBAAwB,CAAC;AAC7G,OAAO,EAAE,4BAA4B,EAAE,MAAM,wBAAwB,CAAC;AAEtE,OAAO,EAAE,mBAAmB,EAAE,MAAM,yBAAyB,CAAC;AAE9D,OAAO,EAAE,YAAY,EAAE,MAAM,qBAAqB,CAAC;AACnD,OAAO,KAAK,EAAE,aAAa,EAAE,MAAM,kBAAkB,CAAC;AAItD,OAAO,KAAK,EAAE,uBAAuB,EAAE,MAAM,qCAAqC,CAAC;AACnF,OAAO,KAAK,EAAE,0BAA0B,EAAE,MAAM,qBAAqB,CAAC;AAEtE,OAAO,KAAK,EAAE,aAAa,EAAE,MAAM,yBAAyB,CAAC;AAC7D,OAAO,KAAK,EAAE,8BAA8B,EAAE,MAAM,mCAAmC,CAAC;AACxF,OAAO,EAA2B,gBAAgB,EAAE,MAAM,iBAAiB,CAAC;AAC5E,OAAO,EAAE,aAAa,EAAE,MAAM,qBAAqB,CAAC;AAEpD;;;;;;;;GAQG;AACH,qBAAa,6BAA6B;IAOtC,OAAO,CAAC,QAAQ,CAAC,OAAO;IACxB,OAAO,CAAC,QAAQ,CAAC,WAAW;IAC5B,OAAO,CAAC,QAAQ,CAAC,KAAK;IACtB,OAAO,CAAC,QAAQ,CAAC,cAAc;IAC/B,OAAO,CAAC,QAAQ,CAAC,WAAW;IAC5B,OAAO,CAAC,QAAQ,CAAC,kBAAkB;IACnC,OAAO,CAAC,QAAQ,CAAC,aAAa;IAC9B,OAAO,CAAC,QAAQ,CAAC,UAAU;IAb7B,OAAO,CAAC,QAAQ,CAAC,GAAG,CAA2C;IAE/D,sDAAsD;IACtD,OAAO,CAAC,uBAAuB,CAAS;gBAGrB,OAAO,EAAE,aAAa,EACtB,WAAW,EAAE,0BAA0B,EACvC,KAAK,EAAE,8BAA8B,EACrC,cAAc,EAAE,EAAE,EAAE,0BAA0B;IAC9C,WAAW,EAAE,MAAM,EAAE,+BAA+B;IACpD,kBAAkB,GAAE,OAAe,EACnC,aAAa,GAAE,aAA0C,EACzD,UAAU,GAAE,gBAAgD;IAG/E;;OAEG;WACW,MAAM,CAClB,OAAO,EAAE,aAAa,EACtB,WAAW,EAAE,0BAA0B,EACvC,KAAK,EAAE,8BAA8B,EACrC,kBAAkB,EAAE,OAAO,YAAQ,EACnC,cAAc,EAAE,EAAE,EAClB,WAAW,EAAE,MAAM,GAClB,6BAA6B;IAWhC;;OAEG;IACU,IAAI;IAcjB;;OAEG;IACU,KAAK,CAAC,WAAW,EAAE,6BAA6B;IAI7D;;OAEG;IACU,MAAM,CAAC,WAAW,EAAE,6BAA6B;YAIhD,MAAM;IAmBpB;;;;;;OAMG;IACU,YAAY,CAAC,eAAe,EAAE,YAAY,EAAE,IAAI,EAAE,EAAE,EAAE,KAAK,EAAE,EAAE,EAAE,aAAa,UAAQ,GAAG,OAAO,CAAC,IAAI,CAAC;IAc5G,aAAa,CAAC,eAAe,EAAE,YAAY,EAAE,IAAI,EAAE,EAAE,GAAG,OAAO;IAItE;;;;;;OAMG;IACU,WAAW,CAAC,eAAe,EAAE,YAAY,EAAE,IAAI,EAAE,EAAE,GAAG,OAAO,CAAC,EAAE,CAAC;IAc9E;;;;;;;OAOG;IACU,mBAAmB,CAAC,eAAe,EAAE,YAAY,EAAE,QAAQ,EAAE,EAAE,EAAE,SAAS,EAAE,EAAE,GAAG,OAAO,CAAC,OAAO,CAAC;IAS9G;;;OAGG;IACU,aAAa,CAAC,eAAe,EAAE,YAAY,EAAE,QAAQ,EAAE,EAAE,GAAG,OAAO,CAAC,IAAI,CAAC;IAMtF;;;OAGG;IACU,mBAAmB,CAAC,cAAc,EAAE,EAAE,GAAG,OAAO,CAAC,IAAI,CAAC;IAMnE;;;OAGG;IACU,mBAAmB,CAAC,cAAc,EAAE,EAAE,GAAG,OAAO,CAAC,IAAI,CAAC;IAQnE;;;;;OAKG;IACU,oBAAoB,CAAC,eAAe,EAAE,YAAY,EAAE,SAAS,EAAE,EAAE,GAAG,OAAO,CAAC,OAAO,CAAC;IAejG;;;;OAIG;IACU,cAAc,CAAC,eAAe,EAAE,YAAY,EAAE,SAAS,EAAE,EAAE;IAMxE;;;OAGG;IACU,oBAAoB,CAAC,eAAe,EAAE,EAAE;IAsBrD;;;;;OAKG;IACU,wBAAwB,CAAC,OAAO,EAAE,EAAE,EAAE,YAAY,EAAE,EAAE,GAAG,OAAO,CAAC,OAAO,CAAC;IAStF;;;;;OAKG;IACI,kBAAkB,CAAC,eAAe,EAAE,YAAY,EAAE,SAAS,EAAE,EAAE,EAAE,OAAO,EAAE,EAAE;IAKnF;;;OAGG;IACI,wBAAwB,CAAC,aAAa,EAAE,mBAAmB;IAQlE;;;;OAIG;IACI,cAAc,CAAC,eAAe,EAAE,YAAY,EAAE,GAAG,EAAE,EAAE,EAAE;IAK9D;;;;OAIG;IACU,mBAAmB,CAAC,eAAe,EAAE,YAAY,GAAG,OAAO,CAAC,4BAA4B,GAAG,SAAS,CAAC;YAkCpG,8BAA8B;IAwD5C;;;;OAIG;IACU,gBAAgB,CAAC,OAAO,EAAE,EAAE,GAAG,OAAO,CAAC,iCAAiC,GAAG,SAAS,CAAC;IA4BlG;;OAEG;IACU,WAAW,CAAC,eAAe,EAAE,YAAY,GAAG,OAAO,CAAC,MAAM,GAAG,SAAS,CAAC;IAiBvE,0BAA0B,CAAC,cAAc,EAAE,uBAAuB,GAAG,OAAO,CAAC,MAAM,CAAC;IAIpF,OAAO,CAAC,MAAM,EAAE,YAAY,EAAE,cAAc,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC;IAIpE,gBAAgB,IAAI,OAAO,CAAC,aAAa,CAAC;CAGxD"}
@@ -95,6 +95,9 @@ import { PublicStorage } from './public_storage.js';
95
95
  }
96
96
  await this.trace.tracePublicStorageWrite(contractAddress, slot, value, protocolWrite);
97
97
  }
98
+ isStorageCold(contractAddress, slot) {
99
+ return this.trace.isStorageCold(contractAddress, slot);
100
+ }
98
101
  /**
99
102
  * Read from public storage.
100
103
  *
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@aztec/simulator",
3
- "version": "0.87.1",
3
+ "version": "0.87.2-nightly.20250524",
4
4
  "type": "module",
5
5
  "exports": {
6
6
  "./server": "./dest/server.js",
@@ -58,25 +58,25 @@
58
58
  ]
59
59
  },
60
60
  "dependencies": {
61
- "@aztec/constants": "0.87.1",
62
- "@aztec/foundation": "0.87.1",
63
- "@aztec/noir-acvm_js": "0.87.1",
64
- "@aztec/noir-noirc_abi": "0.87.1",
65
- "@aztec/noir-protocol-circuits-types": "0.87.1",
66
- "@aztec/noir-types": "0.87.1",
67
- "@aztec/protocol-contracts": "0.87.1",
68
- "@aztec/stdlib": "0.87.1",
69
- "@aztec/telemetry-client": "0.87.1",
70
- "@aztec/world-state": "0.87.1",
61
+ "@aztec/constants": "0.87.2-nightly.20250524",
62
+ "@aztec/foundation": "0.87.2-nightly.20250524",
63
+ "@aztec/noir-acvm_js": "0.87.2-nightly.20250524",
64
+ "@aztec/noir-noirc_abi": "0.87.2-nightly.20250524",
65
+ "@aztec/noir-protocol-circuits-types": "0.87.2-nightly.20250524",
66
+ "@aztec/noir-types": "0.87.2-nightly.20250524",
67
+ "@aztec/protocol-contracts": "0.87.2-nightly.20250524",
68
+ "@aztec/stdlib": "0.87.2-nightly.20250524",
69
+ "@aztec/telemetry-client": "0.87.2-nightly.20250524",
70
+ "@aztec/world-state": "0.87.2-nightly.20250524",
71
71
  "lodash.clonedeep": "^4.5.0",
72
72
  "lodash.merge": "^4.6.2",
73
73
  "tslib": "^2.4.0"
74
74
  },
75
75
  "devDependencies": {
76
- "@aztec/kv-store": "0.87.1",
77
- "@aztec/merkle-tree": "0.87.1",
78
- "@aztec/noir-contracts.js": "0.87.1",
79
- "@aztec/noir-test-contracts.js": "0.87.1",
76
+ "@aztec/kv-store": "0.87.2-nightly.20250524",
77
+ "@aztec/merkle-tree": "0.87.2-nightly.20250524",
78
+ "@aztec/noir-contracts.js": "0.87.2-nightly.20250524",
79
+ "@aztec/noir-test-contracts.js": "0.87.2-nightly.20250524",
80
80
  "@jest/globals": "^29.5.0",
81
81
  "@types/jest": "^29.5.0",
82
82
  "@types/lodash.clonedeep": "^4.5.7",
@@ -379,8 +379,8 @@ export class Oracle {
379
379
  return [];
380
380
  }
381
381
 
382
- async syncNotes([pendingTaggedLogArrayBaseSlot]: ACVMField[]): Promise<ACVMField[]> {
383
- await this.typedOracle.syncNotes(Fr.fromString(pendingTaggedLogArrayBaseSlot));
382
+ async fetchTaggedLogs([pendingTaggedLogArrayBaseSlot]: ACVMField[]): Promise<ACVMField[]> {
383
+ await this.typedOracle.fetchTaggedLogs(Fr.fromString(pendingTaggedLogArrayBaseSlot));
384
384
  return [];
385
385
  }
386
386
 
@@ -214,8 +214,8 @@ export abstract class TypedOracle {
214
214
  return Promise.reject(new OracleMethodNotAvailableError('incrementAppTaggingSecretIndexAsSender'));
215
215
  }
216
216
 
217
- syncNotes(_pendingTaggedLogArrayBaseSlot: Fr): Promise<void> {
218
- return Promise.reject(new OracleMethodNotAvailableError('syncNotes'));
217
+ fetchTaggedLogs(_pendingTaggedLogArrayBaseSlot: Fr): Promise<void> {
218
+ return Promise.reject(new OracleMethodNotAvailableError('fetchTaggedLogs'));
219
219
  }
220
220
 
221
221
  deliverNote(