Skip to content

Commit

Permalink
Bug fix update finalized blockhash
Browse files Browse the repository at this point in the history
  • Loading branch information
godmodegalactus committed Mar 22, 2024
1 parent 9fabdab commit 5be4d2e
Showing 1 changed file with 18 additions and 17 deletions.
35 changes: 18 additions & 17 deletions core/src/stores/block_information_store.rs
Original file line number Diff line number Diff line change
Expand Up @@ -114,10 +114,18 @@ impl BlockInformationStore {
std::sync::atomic::Ordering::Relaxed,
);
}
// check if the block has already been added with higher commitment level
match self.blocks.get_mut(&block_info.blockhash) {
Some(mut prev_block_info) => {
let should_update = match prev_block_info.commitment_config.commitment {

// update latest block
{
let latest_block = self.get_latest_block_arc(commitment_config);
if slot > latest_block.read().await.slot {
*latest_block.write().await = block_info.clone();
}
}

match self.blocks.entry(block_info.blockhash.clone()) {
dashmap::mapref::entry::Entry::Occupied(entry) => {
let should_update = match entry.get().commitment_config.commitment {
CommitmentLevel::Finalized => false, // should never update blocks of finalized commitment
CommitmentLevel::Confirmed => {
commitment_config == CommitmentConfig::finalized()
Expand All @@ -127,23 +135,16 @@ impl BlockInformationStore {
|| commitment_config == CommitmentConfig::finalized()
}
};
if !should_update {
return false;
if should_update {
entry.replace_entry(block_info);
}
*prev_block_info = block_info.clone();
should_update
}
None => {
self.blocks
.insert(block_info.blockhash.clone(), block_info.clone());
dashmap::mapref::entry::Entry::Vacant(entry) => {
entry.insert(block_info);
true
}
}

// update latest block
let latest_block = self.get_latest_block_arc(commitment_config);
if slot > latest_block.read().await.slot {
*latest_block.write().await = block_info;
}
true
}

pub async fn clean(&self) {
Expand Down

0 comments on commit 5be4d2e

Please sign in to comment.