aboutsummaryrefslogtreecommitdiff
path: root/src
diff options
context:
space:
mode:
authorGavin Andresen <gavinandresen@gmail.com>2011-06-24 11:17:22 -0400
committerGavin Andresen <gavinandresen@gmail.com>2011-06-24 11:17:22 -0400
commitc774b1697690c3f94ccd79c5de660b6050ac6409 (patch)
tree0bcc76e794bd82097c9fdda1da3c38835ab590ee /src
parent77ba3ab99c0803ef1f7d03b7884c75588b6e09de (diff)
parenteade213197db4f5858572babc0a219b6ffad92ec (diff)
downloadbitcoin-c774b1697690c3f94ccd79c5de660b6050ac6409.tar.xz
Merge branch 'totalblocksestimate1' of https://github.com/laanwj/bitcoin
Diffstat (limited to 'src')
-rw-r--r--src/main.cpp17
-rw-r--r--src/main.h1
2 files changed, 17 insertions, 1 deletions
diff --git a/src/main.cpp b/src/main.cpp
index 731402194d..54902e82eb 100644
--- a/src/main.cpp
+++ b/src/main.cpp
@@ -32,6 +32,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;
@@ -704,9 +706,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 3b35387c98..aa74ac5ab3 100644
--- a/src/main.h
+++ b/src/main.h
@@ -98,6 +98,7 @@ void IncrementExtraNonce(CBlock* pblock, CBlockIndex* pindexPrev, unsigned int&
void FormatHashBuffers(CBlock* pblock, char* pmidstate, char* pdata, char* phash1);
bool CheckWork(CBlock* pblock, CWallet& wallet, CReserveKey& reservekey);
bool CheckProofOfWork(uint256 hash, unsigned int nBits);
+int GetTotalBlocksEstimate();
bool IsInitialBlockDownload();
std::string GetWarnings(std::string strFor);