|
|
@ -2632,25 +2632,21 @@ bool static ProcessMessage(CNode* pfrom, string strCommand, CDataStream& vRecv) |
|
|
|
// Send the rest of the chain
|
|
|
|
// Send the rest of the chain
|
|
|
|
if (pindex) |
|
|
|
if (pindex) |
|
|
|
pindex = pindex->pnext; |
|
|
|
pindex = pindex->pnext; |
|
|
|
int nLimit = 500 + locator.GetDistanceBack(); |
|
|
|
int nLimit = 500; |
|
|
|
unsigned int nBytes = 0; |
|
|
|
|
|
|
|
printf("getblocks %d to %s limit %d\n", (pindex ? pindex->nHeight : -1), hashStop.ToString().substr(0,20).c_str(), nLimit); |
|
|
|
printf("getblocks %d to %s limit %d\n", (pindex ? pindex->nHeight : -1), hashStop.ToString().substr(0,20).c_str(), nLimit); |
|
|
|
for (; pindex; pindex = pindex->pnext) |
|
|
|
for (; pindex; pindex = pindex->pnext) |
|
|
|
{ |
|
|
|
{ |
|
|
|
if (pindex->GetBlockHash() == hashStop) |
|
|
|
if (pindex->GetBlockHash() == hashStop) |
|
|
|
{ |
|
|
|
{ |
|
|
|
printf(" getblocks stopping at %d %s (%u bytes)\n", pindex->nHeight, pindex->GetBlockHash().ToString().substr(0,20).c_str(), nBytes); |
|
|
|
printf(" getblocks stopping at %d %s\n", pindex->nHeight, pindex->GetBlockHash().ToString().substr(0,20).c_str()); |
|
|
|
break; |
|
|
|
break; |
|
|
|
} |
|
|
|
} |
|
|
|
pfrom->PushInventory(CInv(MSG_BLOCK, pindex->GetBlockHash())); |
|
|
|
pfrom->PushInventory(CInv(MSG_BLOCK, pindex->GetBlockHash())); |
|
|
|
CBlock block; |
|
|
|
if (--nLimit <= 0) |
|
|
|
block.ReadFromDisk(pindex, true); |
|
|
|
|
|
|
|
nBytes += block.GetSerializeSize(SER_NETWORK, PROTOCOL_VERSION); |
|
|
|
|
|
|
|
if (--nLimit <= 0 || nBytes >= SendBufferSize()/2) |
|
|
|
|
|
|
|
{ |
|
|
|
{ |
|
|
|
// When this block is requested, we'll send an inv that'll make them
|
|
|
|
// When this block is requested, we'll send an inv that'll make them
|
|
|
|
// getblocks the next batch of inventory.
|
|
|
|
// getblocks the next batch of inventory.
|
|
|
|
printf(" getblocks stopping at limit %d %s (%u bytes)\n", pindex->nHeight, pindex->GetBlockHash().ToString().substr(0,20).c_str(), nBytes); |
|
|
|
printf(" getblocks stopping at limit %d %s\n", pindex->nHeight, pindex->GetBlockHash().ToString().substr(0,20).c_str()); |
|
|
|
pfrom->hashContinue = pindex->GetBlockHash(); |
|
|
|
pfrom->hashContinue = pindex->GetBlockHash(); |
|
|
|
break; |
|
|
|
break; |
|
|
|
} |
|
|
|
} |
|
|
@ -2910,6 +2906,10 @@ bool ProcessMessages(CNode* pfrom) |
|
|
|
|
|
|
|
|
|
|
|
loop |
|
|
|
loop |
|
|
|
{ |
|
|
|
{ |
|
|
|
|
|
|
|
// Don't bother if send buffer is too full to respond anyway
|
|
|
|
|
|
|
|
if (pfrom->vSend.size() >= SendBufferSize()) |
|
|
|
|
|
|
|
break; |
|
|
|
|
|
|
|
|
|
|
|
// Scan for message start
|
|
|
|
// Scan for message start
|
|
|
|
CDataStream::iterator pstart = search(vRecv.begin(), vRecv.end(), BEGIN(pchMessageStart), END(pchMessageStart)); |
|
|
|
CDataStream::iterator pstart = search(vRecv.begin(), vRecv.end(), BEGIN(pchMessageStart), END(pchMessageStart)); |
|
|
|
int nHeaderSize = vRecv.GetSerializeSize(CMessageHeader()); |
|
|
|
int nHeaderSize = vRecv.GetSerializeSize(CMessageHeader()); |
|
|
|