Revert "correctly trim and download tips (#531)"

This reverts commit e102bd5e34.
This commit is contained in:
Henry de Valence 2020-06-24 12:22:08 -07:00
parent e102bd5e34
commit 21bf913b48
2 changed files with 14 additions and 26 deletions

View File

@ -30,7 +30,7 @@ use zebra_chain::block::BlockHeaderHash;
mod sync;
// genesis
const GENESIS: BlockHeaderHash = BlockHeaderHash([
static GENESIS: BlockHeaderHash = BlockHeaderHash([
8, 206, 61, 151, 49, 176, 0, 192, 131, 56, 69, 92, 138, 74, 107, 208, 93, 161, 110, 38, 177,
29, 170, 27, 145, 113, 132, 236, 232, 15, 4, 0,
]);

View File

@ -161,13 +161,11 @@ where
})
.await;
match res.map_err::<Report, _>(|e| eyre!(e)) {
Ok(zn::Response::BlockHeaderHashes(mut hashes)) => {
let new_tip = if let Some(tip) = hashes.pop() {
tip
} else {
Ok(zn::Response::BlockHeaderHashes(hashes)) => {
if hashes.is_empty() {
tracing::debug!("skipping empty response");
continue;
};
}
// ExtendTips Step 3
//
@ -176,20 +174,22 @@ where
// It indicates that the remote peer does not have any blocks
// following the prospective tip.
// TODO(jlusby): reject both main and test net genesis blocks
match hashes.first() {
Some(&super::GENESIS) => {
tracing::debug!("skipping response that does not extend the tip");
continue;
}
Some(_) | None => {}
if hashes[0] == super::GENESIS {
tracing::debug!("skipping response that does not extend the tip");
continue;
}
// ExtendTips Step 4
//
// Combine the last elements of the remaining responses into
// a set, and add this set to the set of prospective tips.
let new_tip = *hashes.last().expect("already checked is_empty");
let _ = self.prospective_tips.insert(new_tip);
// ExtendTips Step 5
//
// Combine all elements of the remaining responses into a
// set, and queue download and verification of those blocks
download_set.extend(hashes);
}
Ok(r) => tracing::error!("unexpected response {:?}", r),
@ -198,20 +198,8 @@ where
}
}
self.prospective_tips
.retain(|tip| !download_set.contains(tip));
// ExtendTips Step 5
//
// Combine all elements of the remaining responses into a
// set, and queue download and verification of those blocks
self.request_blocks(
download_set
.into_iter()
.chain(self.prospective_tips.iter().cloned())
.collect(),
)
.await?;
self.request_blocks(download_set.into_iter().collect())
.await?;
Ok(())
}