|
|
|
@ -1807,6 +1807,7 @@ enum FlushStateMode {
@@ -1807,6 +1807,7 @@ enum FlushStateMode {
|
|
|
|
|
bool static FlushStateToDisk(CValidationState &state, FlushStateMode mode) { |
|
|
|
|
LOCK(cs_main); |
|
|
|
|
static int64_t nLastWrite = 0; |
|
|
|
|
try { |
|
|
|
|
if ((mode == FLUSH_STATE_ALWAYS) || |
|
|
|
|
((mode == FLUSH_STATE_PERIODIC || mode == FLUSH_STATE_IF_NEEDED) && pcoinsTip->GetCacheSize() > nCoinCacheSize) || |
|
|
|
|
(mode == FLUSH_STATE_PERIODIC && GetTimeMicros() > nLastWrite + DATABASE_WRITE_INTERVAL * 1000000)) { |
|
|
|
@ -1846,6 +1847,9 @@ bool static FlushStateToDisk(CValidationState &state, FlushStateMode mode) {
@@ -1846,6 +1847,9 @@ bool static FlushStateToDisk(CValidationState &state, FlushStateMode mode) {
|
|
|
|
|
} |
|
|
|
|
nLastWrite = GetTimeMicros(); |
|
|
|
|
} |
|
|
|
|
} catch (const std::runtime_error& e) { |
|
|
|
|
return state.Abort(std::string("System error while flushing: ") + e.what()); |
|
|
|
|
} |
|
|
|
|
return true; |
|
|
|
|
} |
|
|
|
|
|
|
|
|
|