Skip to content

Commit

Permalink
update head when node caught up
Browse files Browse the repository at this point in the history
  • Loading branch information
shekhirin committed Sep 16, 2024
1 parent 34ab299 commit 67e9f66
Showing 1 changed file with 7 additions and 7 deletions.
14 changes: 7 additions & 7 deletions crates/exex/exex/src/manager.rs
Original file line number Diff line number Diff line change
Expand Up @@ -253,7 +253,6 @@ impl<Node: Unpin> Stream for ExExNotifications<Node> {
/// committed or reverted after the given head.
#[derive(Debug)]
pub struct ExExNotificationsWithHead<Node: FullNodeComponents> {
#[allow(dead_code)]
node_head: Head,
components: Node,
notifications: Receiver<ExExNotification>,
Expand Down Expand Up @@ -302,12 +301,12 @@ impl<Node: FullNodeComponents> ExExNotificationsWithHead<Node> {
/// backfill from the node database.
/// - ExEx is ahead of the node head (`node_head.number > exex_head.number`). Wait until the
/// node head catches up to the ExEx head, and then repeat the synchronization process.
fn synchronize(&mut self, node_head: Head) -> eyre::Result<()> {
fn synchronize(&mut self) -> eyre::Result<()> {
let backfill_job_factory = BackfillJobFactory::new(
self.components.block_executor().clone(),
self.components.provider().clone(),
);
match self.exex_head.block.number.cmp(&node_head.number) {
match self.exex_head.block.number.cmp(&self.node_head.number) {
std::cmp::Ordering::Less => {
// ExEx is behind the node head

Expand All @@ -322,7 +321,7 @@ impl<Node: FullNodeComponents> ExExNotificationsWithHead<Node> {

// ExEx is on the canonical chain, start backfill
let backfill = backfill_job_factory
.backfill(self.exex_head.block.number + 1..=node_head.number)
.backfill(self.exex_head.block.number + 1..=self.node_head.number)
.into_stream();
self.backfill_job = Some(backfill);
} else {
Expand Down Expand Up @@ -375,7 +374,7 @@ impl<Node: FullNodeComponents + Unpin> Stream for ExExNotificationsWithHead<Node
let this = self.get_mut();

if this.pending_sync {
this.synchronize(this.node_head)?;
this.synchronize()?;
this.pending_sync = false;
}

Expand Down Expand Up @@ -431,13 +430,14 @@ impl<Node: FullNodeComponents + Unpin> Stream for ExExNotificationsWithHead<Node
.provider()
.sealed_header(tip)?
.ok_or_eyre("node head not found")?;
this.synchronize(Head::new(
this.node_head = Head::new(
tip.number,
tip.hash(),
tip.difficulty,
U256::MAX,
tip.timestamp,
))?;
);
this.synchronize()?;
}
}
}
Expand Down

0 comments on commit 67e9f66

Please sign in to comment.