|
|
@ -2016,7 +2016,7 @@ static CBlockIndex* FindMostWorkChain() { |
|
|
|
CBlockIndex *pindexTest = pindexNew; |
|
|
|
CBlockIndex *pindexTest = pindexNew; |
|
|
|
bool fInvalidAncestor = false; |
|
|
|
bool fInvalidAncestor = false; |
|
|
|
while (pindexTest && !chainActive.Contains(pindexTest)) { |
|
|
|
while (pindexTest && !chainActive.Contains(pindexTest)) { |
|
|
|
if (!pindexTest->IsValid(BLOCK_VALID_TRANSACTIONS) || !(pindexTest->nStatus & BLOCK_HAVE_DATA)) { |
|
|
|
if (pindexTest->nStatus & BLOCK_FAILED_MASK) { |
|
|
|
// Candidate has an invalid ancestor, remove entire chain from the set.
|
|
|
|
// Candidate has an invalid ancestor, remove entire chain from the set.
|
|
|
|
if (pindexBestInvalid == NULL || pindexNew->nChainWork > pindexBestInvalid->nChainWork) |
|
|
|
if (pindexBestInvalid == NULL || pindexNew->nChainWork > pindexBestInvalid->nChainWork) |
|
|
|
pindexBestInvalid = pindexNew; |
|
|
|
pindexBestInvalid = pindexNew; |
|
|
@ -2026,6 +2026,7 @@ static CBlockIndex* FindMostWorkChain() { |
|
|
|
setBlockIndexValid.erase(pindexFailed); |
|
|
|
setBlockIndexValid.erase(pindexFailed); |
|
|
|
pindexFailed = pindexFailed->pprev; |
|
|
|
pindexFailed = pindexFailed->pprev; |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
setBlockIndexValid.erase(pindexTest); |
|
|
|
fInvalidAncestor = true; |
|
|
|
fInvalidAncestor = true; |
|
|
|
break; |
|
|
|
break; |
|
|
|
} |
|
|
|
} |
|
|
|