aboutsummaryrefslogtreecommitdiff
path: root/src/cryptonote_core
diff options
context:
space:
mode:
authormoneromooo-monero <moneromooo-monero@users.noreply.github.com>2016-12-13 02:13:23 +0000
committermoneromooo-monero <moneromooo-monero@users.noreply.github.com>2016-12-13 02:13:23 +0000
commitdd144b14bcdcd7679d201e762a1165dcdea13c29 (patch)
tree2533a54f5eca3c886e3ef73031361e118f052079 /src/cryptonote_core
parentMerge pull request #1436 (diff)
downloadmonero-dd144b14bcdcd7679d201e762a1165dcdea13c29.tar.xz
blockchain: fix reorganizations past a hard fork boundary
After popping blocks from the old chain, the hard fork object's notion of the current version was not in line with the new height, causing the first blocks from the new chain to be rejected due to a false expection of a newer version.
Diffstat (limited to 'src/cryptonote_core')
-rw-r--r--src/cryptonote_core/blockchain.cpp3
1 files changed, 3 insertions, 0 deletions
diff --git a/src/cryptonote_core/blockchain.cpp b/src/cryptonote_core/blockchain.cpp
index efda3f5cf..70b2ccc79 100644
--- a/src/cryptonote_core/blockchain.cpp
+++ b/src/cryptonote_core/blockchain.cpp
@@ -759,6 +759,9 @@ bool Blockchain::rollback_blockchain_switching(std::list<block>& original_chain,
pop_block_from_blockchain();
}
+ // make sure the hard fork object updates its current version
+ m_hardfork->reorganize_from_chain_height(rollback_height);
+
//return back original chain
for (auto& bl : original_chain)
{