521d4ae08f
* Let Commit() return void
The boolean return value will loose its meaning in the next commit
* Implement 2-stage commits for CDBTransaction and CScopedDBTransaction
CDBTransaction is changed to allow CDBBatch, CDBWrapper and other
CDBTransactions as parent instead of just CDBWrapper. This in turn allows
to implement multi-staged commits in CEvoDB.
We now have the "current transaction" which is started and ended (commit
or rollback) for each call to Connect-/DisconnectBlock. When the current
transaction is committed, it moves its contents into the "root transaction"
instead of directly writing to CDBWrapper.
CommitRootTransaction() then handles the final commitment to CDBWrapper. It
is called at the same time when the chainstate is flushed to disk, which
guarantees consistency between chainstate and CEvoDB.
* Allow to efficiently move values into parent transactions to avoid copies
When CDBTransaction<CDBTransaction<...>>::Commit() is called, we can avoid
copying values from this transaction to the parent transaction and instead
pass values by rvalue and let the contents be moved.
* Revert "Force FlushStateToDisk on ConnectTip/DisconnectTip while not in IBD (#2560)"
This reverts commit 6dfceaba5a
.
80 lines
1.8 KiB
C++
80 lines
1.8 KiB
C++
// Copyright (c) 2018 The Dash Core developers
|
|
// Distributed under the MIT software license, see the accompanying
|
|
// file COPYING or http://www.opensource.org/licenses/mit-license.php.
|
|
|
|
#ifndef DASH_EVODB_H
|
|
#define DASH_EVODB_H
|
|
|
|
#include "dbwrapper.h"
|
|
#include "sync.h"
|
|
#include "uint256.h"
|
|
|
|
static const std::string EVODB_BEST_BLOCK = "b_b";
|
|
|
|
class CEvoDB
|
|
{
|
|
private:
|
|
CCriticalSection cs;
|
|
CDBWrapper db;
|
|
|
|
typedef CDBTransaction<CDBWrapper, CDBBatch> RootTransaction;
|
|
typedef CDBTransaction<RootTransaction, RootTransaction> CurTransaction;
|
|
typedef CScopedDBTransaction<RootTransaction, RootTransaction> ScopedTransaction;
|
|
|
|
CDBBatch rootBatch;
|
|
RootTransaction rootDBTransaction;
|
|
CurTransaction curDBTransaction;
|
|
|
|
public:
|
|
CEvoDB(size_t nCacheSize, bool fMemory = false, bool fWipe = false);
|
|
|
|
std::unique_ptr<ScopedTransaction> BeginTransaction()
|
|
{
|
|
LOCK(cs);
|
|
auto t = ScopedTransaction::Begin(curDBTransaction);
|
|
return t;
|
|
}
|
|
|
|
template <typename K, typename V>
|
|
bool Read(const K& key, V& value)
|
|
{
|
|
LOCK(cs);
|
|
return curDBTransaction.Read(key, value);
|
|
}
|
|
|
|
template <typename K, typename V>
|
|
void Write(const K& key, const V& value)
|
|
{
|
|
LOCK(cs);
|
|
curDBTransaction.Write(key, value);
|
|
}
|
|
|
|
template <typename K>
|
|
bool Exists(const K& key)
|
|
{
|
|
LOCK(cs);
|
|
return curDBTransaction.Exists(key);
|
|
}
|
|
|
|
template <typename K>
|
|
void Erase(const K& key)
|
|
{
|
|
LOCK(cs);
|
|
curDBTransaction.Erase(key);
|
|
}
|
|
|
|
CDBWrapper& GetRawDB()
|
|
{
|
|
return db;
|
|
}
|
|
|
|
bool CommitRootTransaction();
|
|
|
|
bool VerifyBestBlock(const uint256& hash);
|
|
void WriteBestBlock(const uint256& hash);
|
|
};
|
|
|
|
extern CEvoDB* evoDb;
|
|
|
|
#endif //DASH_EVODB_H
|