log timing for rebuild_index (#2607)

This commit is contained in:
Antioch Peverell 2019-02-20 08:16:13 +00:00 committed by GitHub
parent b1c09946cb
commit 2df633b622
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23

View file

@ -1252,18 +1252,29 @@ impl<'a> Extension<'a> {
Ok((output_sum, kernel_sum))
}
/// Rebuild the index of MMR positions to the corresponding Output and
/// kernel by iterating over the whole MMR data. This is a costly operation
/// performed only when we receive a full new chain state.
/// Rebuild the index of MMR positions to the corresponding UTXOs.
/// This is a costly operation performed only when we receive a full new chain state.
pub fn rebuild_index(&self) -> Result<(), Error> {
let now = Instant::now();
let mut count = 0;
for n in 1..self.output_pmmr.unpruned_size() + 1 {
// non-pruned leaves only
if pmmr::bintree_postorder_height(n) == 0 {
if let Some(out) = self.output_pmmr.get_data(n) {
self.batch.save_output_pos(&out.commit, n)?;
count += 1;
}
}
}
debug!(
"txhashset: rebuild_index ({} UTXOs), took {}s",
count,
now.elapsed().as_secs(),
);
Ok(())
}