reth_trie_db/
prefix_set.rs1use alloy_primitives::{
2 keccak256,
3 map::{HashMap, HashSet},
4 BlockNumber, B256,
5};
6use core::ops::RangeInclusive;
7use reth_db_api::{
8 cursor::DbCursorRO,
9 models::{AccountBeforeTx, BlockNumberAddress},
10 tables,
11 transaction::DbTx,
12};
13use reth_storage_api::{ChangeSetReader, DBProvider, StorageChangeSetReader};
14use reth_storage_errors::provider::ProviderError;
15use reth_trie::{
16 prefix_set::{PrefixSetMut, TriePrefixSets},
17 Nibbles,
18};
19
20pub fn load_prefix_sets_with_provider<Provider>(
23 provider: &Provider,
24 range: RangeInclusive<BlockNumber>,
25) -> Result<TriePrefixSets, ProviderError>
26where
27 Provider: ChangeSetReader + StorageChangeSetReader + DBProvider,
28{
29 let tx = provider.tx_ref();
30
31 let mut account_prefix_set = PrefixSetMut::default();
33 let mut storage_prefix_sets = HashMap::<B256, PrefixSetMut>::default();
34 let mut destroyed_accounts = HashSet::default();
35
36 let account_changesets = provider.account_changesets_range(*range.start()..*range.end() + 1)?;
38
39 let mut account_hashed_state_cursor = tx.cursor_read::<tables::HashedAccounts>()?;
41
42 for (_, AccountBeforeTx { address, .. }) in account_changesets {
43 let hashed_address = keccak256(address);
44 account_prefix_set.insert(Nibbles::unpack(hashed_address));
45
46 if account_hashed_state_cursor.seek_exact(hashed_address)?.is_none() {
47 destroyed_accounts.insert(hashed_address);
48 }
49 }
50
51 let storage_changesets = provider.storage_changesets_range(range)?;
53 for (BlockNumberAddress((_, address)), storage_entry) in storage_changesets {
54 let hashed_address = keccak256(address);
55 account_prefix_set.insert(Nibbles::unpack(hashed_address));
56 storage_prefix_sets
57 .entry(hashed_address)
58 .or_default()
59 .insert(Nibbles::unpack(keccak256(storage_entry.key)));
60 }
61
62 Ok(TriePrefixSets {
63 account_prefix_set: account_prefix_set.freeze(),
64 storage_prefix_sets: storage_prefix_sets
65 .into_iter()
66 .map(|(k, v)| (k, v.freeze()))
67 .collect(),
68 destroyed_accounts,
69 })
70}