mirror of
https://github.com/bitcoin/bitcoin.git
synced 2025-01-26 11:13:23 -03:00
Merge pull request #1612 from luke-jr/opti_getblkhash
Optimize JSON-RPC getblockhash
This commit is contained in:
commit
8ce7915aad
3 changed files with 21 additions and 4 deletions
|
@ -2047,10 +2047,7 @@ Value getblockhash(const Array& params, bool fHelp)
|
||||||
if (nHeight < 0 || nHeight > nBestHeight)
|
if (nHeight < 0 || nHeight > nBestHeight)
|
||||||
throw runtime_error("Block number out of range.");
|
throw runtime_error("Block number out of range.");
|
||||||
|
|
||||||
CBlock block;
|
CBlockIndex* pblockindex = FindBlockByHeight(nHeight);
|
||||||
CBlockIndex* pblockindex = mapBlockIndex[hashBestChain];
|
|
||||||
while (pblockindex->nHeight > nHeight)
|
|
||||||
pblockindex = pblockindex->pprev;
|
|
||||||
return pblockindex->phashBlock->GetHex();
|
return pblockindex->phashBlock->GetHex();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
19
src/main.cpp
19
src/main.cpp
|
@ -811,6 +811,24 @@ bool GetTransaction(const uint256 &hash, CTransaction &tx, uint256 &hashBlock)
|
||||||
// CBlock and CBlockIndex
|
// CBlock and CBlockIndex
|
||||||
//
|
//
|
||||||
|
|
||||||
|
static CBlockIndex* pblockindexFBBHLast;
|
||||||
|
CBlockIndex* FindBlockByHeight(int nHeight)
|
||||||
|
{
|
||||||
|
CBlockIndex *pblockindex;
|
||||||
|
if (nHeight < nBestHeight / 2)
|
||||||
|
pblockindex = pindexGenesisBlock;
|
||||||
|
else
|
||||||
|
pblockindex = pindexBest;
|
||||||
|
if (pblockindexFBBHLast && abs(nHeight - pblockindex->nHeight) > abs(nHeight - pblockindexFBBHLast->nHeight))
|
||||||
|
pblockindex = pblockindexFBBHLast;
|
||||||
|
while (pblockindex->nHeight > nHeight)
|
||||||
|
pblockindex = pblockindex->pprev;
|
||||||
|
while (pblockindex->nHeight < nHeight)
|
||||||
|
pblockindex = pblockindex->pnext;
|
||||||
|
pblockindexFBBHLast = pblockindex;
|
||||||
|
return pblockindex;
|
||||||
|
}
|
||||||
|
|
||||||
bool CBlock::ReadFromDisk(const CBlockIndex* pindex, bool fReadTransactions)
|
bool CBlock::ReadFromDisk(const CBlockIndex* pindex, bool fReadTransactions)
|
||||||
{
|
{
|
||||||
if (!fReadTransactions)
|
if (!fReadTransactions)
|
||||||
|
@ -1634,6 +1652,7 @@ bool CBlock::SetBestChain(CTxDB& txdb, CBlockIndex* pindexNew)
|
||||||
// New best block
|
// New best block
|
||||||
hashBestChain = hash;
|
hashBestChain = hash;
|
||||||
pindexBest = pindexNew;
|
pindexBest = pindexNew;
|
||||||
|
pblockindexFBBHLast = NULL;
|
||||||
nBestHeight = pindexBest->nHeight;
|
nBestHeight = pindexBest->nHeight;
|
||||||
bnBestChainWork = pindexNew->bnChainWork;
|
bnBestChainWork = pindexNew->bnChainWork;
|
||||||
nTimeBestReceived = GetTime();
|
nTimeBestReceived = GetTime();
|
||||||
|
|
|
@ -88,6 +88,7 @@ FILE* OpenBlockFile(unsigned int nFile, unsigned int nBlockPos, const char* pszM
|
||||||
FILE* AppendBlockFile(unsigned int& nFileRet);
|
FILE* AppendBlockFile(unsigned int& nFileRet);
|
||||||
bool LoadBlockIndex(bool fAllowNew=true);
|
bool LoadBlockIndex(bool fAllowNew=true);
|
||||||
void PrintBlockTree();
|
void PrintBlockTree();
|
||||||
|
CBlockIndex* FindBlockByHeight(int nHeight);
|
||||||
bool ProcessMessages(CNode* pfrom);
|
bool ProcessMessages(CNode* pfrom);
|
||||||
bool SendMessages(CNode* pto, bool fSendTrickle);
|
bool SendMessages(CNode* pto, bool fSendTrickle);
|
||||||
bool LoadExternalBlockFile(FILE* fileIn);
|
bool LoadExternalBlockFile(FILE* fileIn);
|
||||||
|
|
Loading…
Add table
Reference in a new issue