diff options
author | Wladimir J. van der Laan <laanwj@gmail.com> | 2011-06-18 19:05:39 +0200 |
---|---|---|
committer | Wladimir J. van der Laan <laanwj@gmail.com> | 2011-06-19 00:12:02 +0200 |
commit | eade213197db4f5858572babc0a219b6ffad92ec (patch) | |
tree | bbca4251978fcc355165d70301866d025accf4e5 /src | |
parent | eeac8727bc0a951631bdd301ea3344c88fbb0859 (diff) |
add GetTotalBlocksEstimate() function, move magic number to constant
Diffstat (limited to 'src')
-rw-r--r-- | src/main.cpp | 17 | ||||
-rw-r--r-- | src/main.h | 1 |
2 files changed, 17 insertions, 1 deletions
diff --git a/src/main.cpp b/src/main.cpp index 108842f3a1..61426a3ef9 100644 --- a/src/main.cpp +++ b/src/main.cpp @@ -25,6 +25,8 @@ map<COutPoint, CInPoint> mapNextTx; map<uint256, CBlockIndex*> mapBlockIndex; uint256 hashGenesisBlock("0x000000000019d6689c085ae165831e934ff763ae46a2a6c172b3f1b60a8ce26f"); CBigNum bnProofOfWorkLimit(~uint256(0) >> 32); +const int nTotalBlocksEstimate = 131000; // Conservative estimate of total nr of blocks on main chain +const int nInitialBlockThreshold = 10000; // Regard blocks up until N-threshold as "initial download" CBlockIndex* pindexGenesisBlock = NULL; int nBestHeight = -1; CBigNum bnBestChainWork = 0; @@ -1156,9 +1158,22 @@ bool CheckProofOfWork(uint256 hash, unsigned int nBits) return true; } +// Return conservative estimate of total number of blocks, 0 if unknown +int GetTotalBlocksEstimate() +{ + if(fTestNet) + { + return 0; + } + else + { + return nTotalBlocksEstimate; + } +} + bool IsInitialBlockDownload() { - if (pindexBest == NULL || (!fTestNet && nBestHeight < 118000)) + if (pindexBest == NULL || nBestHeight < (GetTotalBlocksEstimate()-nInitialBlockThreshold)) return true; static int64 nLastUpdate; static CBlockIndex* pindexLastBest; diff --git a/src/main.h b/src/main.h index 7aa6d41c30..73935bcee2 100644 --- a/src/main.h +++ b/src/main.h @@ -118,6 +118,7 @@ void FormatHashBuffers(CBlock* pblock, char* pmidstate, char* pdata, char* phash bool CheckWork(CBlock* pblock, CReserveKey& reservekey); void BitcoinMiner(); bool CheckProofOfWork(uint256 hash, unsigned int nBits); +int GetTotalBlocksEstimate(); bool IsInitialBlockDownload(); std::string GetWarnings(std::string strFor); |