diff options
author | Riccardo Spagni <ric@spagni.net> | 2016-01-15 19:42:16 +0200 |
---|---|---|
committer | Riccardo Spagni <ric@spagni.net> | 2016-01-15 19:42:16 +0200 |
commit | f6a75a4875f186ede7d467ebe7683010d0e09048 (patch) | |
tree | 56cd61f113b9bed7eeef4b84729cb4cab356fc80 /src/blockchain_db/lmdb | |
parent | Merge pull request #612 (diff) | |
parent | Fix hf when import with verify off (diff) | |
download | monero-f6a75a4875f186ede7d467ebe7683010d0e09048.tar.xz |
Merge pull request #613v0.9.1
30f92f5 Fix hf when import with verify off (Howard Chu)
Diffstat (limited to 'src/blockchain_db/lmdb')
-rw-r--r-- | src/blockchain_db/lmdb/db_lmdb.cpp | 21 | ||||
-rw-r--r-- | src/blockchain_db/lmdb/db_lmdb.h | 1 |
2 files changed, 22 insertions, 0 deletions
diff --git a/src/blockchain_db/lmdb/db_lmdb.cpp b/src/blockchain_db/lmdb/db_lmdb.cpp index 7bf5d304b..17a0f9ec2 100644 --- a/src/blockchain_db/lmdb/db_lmdb.cpp +++ b/src/blockchain_db/lmdb/db_lmdb.cpp @@ -2434,6 +2434,27 @@ void BlockchainLMDB::get_output_tx_and_index(const uint64_t& amount, const std:: LOG_PRINT_L3("db3: " << db3); } +void BlockchainLMDB::check_hard_fork_info() +{ + LOG_PRINT_L3("BlockchainLMDB::" << __func__); + check_open(); + + TXN_PREFIX(0); + + MDB_stat db_stat1, db_stat2; + if (mdb_stat(*txn_ptr, m_blocks, &db_stat1)) + throw0(DB_ERROR("Failed to query m_blocks")); + if (mdb_stat(*txn_ptr, m_hf_versions, &db_stat2)) + throw0(DB_ERROR("Failed to query m_hf_starting_heights")); + if (db_stat1.ms_entries != db_stat2.ms_entries) + { + mdb_drop(*txn_ptr, m_hf_starting_heights, 1); + mdb_drop(*txn_ptr, m_hf_versions, 1); + } + + TXN_POSTFIX_SUCCESS(); +} + void BlockchainLMDB::set_hard_fork_starting_height(uint8_t version, uint64_t height) { LOG_PRINT_L3("BlockchainLMDB::" << __func__); diff --git a/src/blockchain_db/lmdb/db_lmdb.h b/src/blockchain_db/lmdb/db_lmdb.h index 3a6f8bbd8..48f4adb41 100644 --- a/src/blockchain_db/lmdb/db_lmdb.h +++ b/src/blockchain_db/lmdb/db_lmdb.h @@ -235,6 +235,7 @@ private: virtual uint64_t get_hard_fork_starting_height(uint8_t version) const; virtual void set_hard_fork_version(uint64_t height, uint8_t version); virtual uint8_t get_hard_fork_version(uint64_t height) const; + virtual void check_hard_fork_info(); /** * @brief convert a tx output to a blob for storage |