From 99f398a25e7ac291eb9729cce3662743d7d4207b Mon Sep 17 00:00:00 2001 From: moneromooo-monero Date: Mon, 30 Oct 2017 10:16:54 +0000 Subject: [PATCH] wallet2: avoid growing the short history when refreshing in a loop --- src/wallet/wallet2.cpp | 27 +++++++++++++++++---------- 1 file changed, 17 insertions(+), 10 deletions(-) diff --git a/src/wallet/wallet2.cpp b/src/wallet/wallet2.cpp index a7161ffcb..b641eea34 100644 --- a/src/wallet/wallet2.cpp +++ b/src/wallet/wallet2.cpp @@ -468,6 +468,19 @@ static void emplace_or_replace(std::unordered_multimap &short_chain_history, size_t N) +{ + std::list::iterator right; + // drop early N off, skipping the genesis block + if (short_chain_history.size() > N) { + right = short_chain_history.end(); + std::advance(right,-1); + std::list::iterator left = right; + std::advance(left, -N); + short_chain_history.erase(left, right); + } +} + } //namespace namespace tools @@ -1521,6 +1534,8 @@ void wallet2::pull_next_blocks(uint64_t start_height, uint64_t &blocks_start_hei try { + drop_from_short_history(short_chain_history, 3); + // prepend the last 3 blocks, should be enough to guard against a block or two's reorg cryptonote::block bl; std::list::const_reverse_iterator i = prev_blocks.rbegin(); @@ -1810,16 +1825,8 @@ void wallet2::fast_refresh(uint64_t stop_height, uint64_t &blocks_start_height, if (hashes.size() <= 3) return; if (hashes.size() + current_index < stop_height) { - std::list::iterator right; - // drop early 3 off, skipping the genesis block - if (short_chain_history.size() > 3) { - right = short_chain_history.end(); - std::advance(right,-1); - std::list::iterator left = right; - std::advance(left, -3); - short_chain_history.erase(left, right); - } - right = hashes.end(); + drop_from_short_history(short_chain_history, 3); + std::list::iterator right = hashes.end(); // prepend 3 more for (int i = 0; i<3; i++) { right--;