reth_engine_tree/tree/
persistence_state.rs1use alloy_eips::BlockNumHash;
2use alloy_primitives::B256;
3use std::{collections::VecDeque, time::Instant};
4use tokio::sync::oneshot;
5use tracing::{debug, trace};
6
7#[derive(Default, Debug)]
9pub struct PersistenceState {
10 pub(crate) last_persisted_block: BlockNumHash,
14 pub(crate) rx: Option<(oneshot::Receiver<Option<BlockNumHash>>, Instant)>,
17 pub(crate) remove_above_state: VecDeque<u64>,
20}
21
22impl PersistenceState {
23 pub(crate) const fn in_progress(&self) -> bool {
26 self.rx.is_some()
27 }
28
29 pub(crate) fn start(&mut self, rx: oneshot::Receiver<Option<BlockNumHash>>) {
31 self.rx = Some((rx, Instant::now()));
32 }
33
34 pub(crate) fn schedule_removal(&mut self, new_tip_num: u64) {
37 debug!(target: "engine::tree", ?new_tip_num, prev_remove_state=?self.remove_above_state, last_persisted_block=?self.last_persisted_block, "Scheduling removal");
38 self.remove_above_state.push_back(new_tip_num);
39 }
40
41 pub(crate) fn finish(
43 &mut self,
44 last_persisted_block_hash: B256,
45 last_persisted_block_number: u64,
46 ) {
47 trace!(target: "engine::tree", block= %last_persisted_block_number, hash=%last_persisted_block_hash, "updating persistence state");
48 self.rx = None;
49 self.last_persisted_block =
50 BlockNumHash::new(last_persisted_block_number, last_persisted_block_hash);
51 }
52}