16 throw std::runtime_error(
"Low leaf slot is GTE leaf slot");
20 throw std::runtime_error(
"Leaf slot is GTE low leaf next slot");
28 uint64_t low_leaf_index,
35 merkle_check.assert_membership(low_leaf_hash, low_leaf_index, sibling_path, snapshot.
root);
41 throw std::runtime_error(
"Leaf value does not match value");
47 throw std::runtime_error(
"Value is nonzero for a non existing slot");
55 .leaf_slot = leaf_slot,
56 .prev_snapshot = snapshot,
57 .low_leaf_preimage = low_leaf_preimage,
58 .low_leaf_hash = low_leaf_hash,
59 .low_leaf_index = low_leaf_index,
67 uint64_t low_leaf_index,
71 bool is_protocol_write)
90 updated_low_leaf_preimage.
nextKey = leaf_slot;
96 low_leaf_hash, updated_low_leaf_hash, low_leaf_index, low_leaf_sibling_path, prev_snapshot.
root);
99 .
root = intermediate_root,
102 FF new_leaf_hash = 0;
116 uint32_t execution_id =
123 .leaf_slot = leaf_slot,
124 .prev_snapshot = prev_snapshot,
125 .low_leaf_preimage = low_leaf_preimage,
126 .low_leaf_hash = low_leaf_hash,
127 .low_leaf_index = low_leaf_index,
129 .updated_low_leaf_hash = updated_low_leaf_hash,
130 .new_leaf_hash = new_leaf_hash,
131 .intermediate_root = intermediate_root,
132 .next_snapshot = next_snapshot },
133 .execution_id = execution_id,
136 return next_snapshot;
162 std::vector<FF> sorted_written_leaf_slots = written_leaf_slots;
165 std::ranges::sort(sorted_written_leaf_slots,
168 if (sorted_written_leaf_slots.size() > 1) {
169 for (
size_t i = 0; i < sorted_written_leaf_slots.size() - 1; i++) {
170 field_gt.
ff_gt(sorted_written_leaf_slots.at(i + 1), sorted_written_leaf_slots.at(i));
#define GENERATOR_INDEX__PUBLIC_LEAF_INDEX
virtual void emit(Event &&event)=0
virtual uint32_t get_execution_id() const =0
virtual bool ff_gt(const FF &a, const FF &b)=0
void on_checkpoint_created() override
FF compute_leaf_slot(const AztecAddress &contract_address, const FF &slot)
void validate_low_leaf_jumps_over_slot(const PublicDataTreeLeafPreimage &low_leaf_preimage, const FF &leaf_slot)
AppendOnlyTreeSnapshot write(const FF &slot, const AztecAddress &contract_address, const FF &value, const PublicDataTreeLeafPreimage &low_leaf_preimage, uint64_t low_leaf_index, std::span< const FF > low_leaf_sibling_path, const AppendOnlyTreeSnapshot &prev_snapshot, std::span< const FF > insertion_sibling_path, bool is_protocol_write) override
void on_checkpoint_committed() override
ExecutionIdGetterInterface & execution_id_manager
FieldGreaterThanInterface & field_gt
void generate_ff_gt_events_for_squashing(const std::vector< FF > &written_leaf_slots)
Generates ff_gt events for squashing.
void on_checkpoint_reverted() override
void assert_read(const FF &slot, const AztecAddress &contract_address, const FF &value, const PublicDataTreeLeafPreimage &low_leaf_preimage, uint64_t low_leaf_index, std::span< const FF > sibling_path, const AppendOnlyTreeSnapshot &snapshot) override
EventEmitterInterface< PublicDataTreeCheckEvent > & events
static FF hash(const std::vector< FF > &input)
Hashes a vector of field elements.
AztecAddress contract_address
IndexedLeaf< PublicDataLeafValue > PublicDataTreeLeafPreimage
::bb::crypto::merkle_tree::PublicDataLeafValue PublicDataLeafValue
constexpr decltype(auto) get(::tuplet::tuple< T... > &&t) noexcept
uint64_t next_available_leaf_index
AztecAddress contract_address
PublicDataTreeLeafPreimage updated_low_leaf_preimage
static IndexedLeaf< PublicDataLeafValue > empty()
std::vector< fr > get_hash_inputs() const