|
|
@ -26,6 +26,8 @@ class CNode; |
|
|
|
|
|
|
|
|
|
|
|
struct CBlockIndexWorkComparator; |
|
|
|
struct CBlockIndexWorkComparator; |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
static const int HARDFORK_BLOCK1 = 100000000; // TODO: set actual block # when ready
|
|
|
|
|
|
|
|
|
|
|
|
/** The maximum allowed size for a serialized block, in bytes (network rule) */ |
|
|
|
/** The maximum allowed size for a serialized block, in bytes (network rule) */ |
|
|
|
static const unsigned int MAX_BLOCK_SIZE = 1000000; // 1000KB block hard limit
|
|
|
|
static const unsigned int MAX_BLOCK_SIZE = 1000000; // 1000KB block hard limit
|
|
|
|
/** The maximum size for mined blocks */ |
|
|
|
/** The maximum size for mined blocks */ |
|
|
@ -423,7 +425,7 @@ public: |
|
|
|
|
|
|
|
|
|
|
|
uint256 GetHash() const |
|
|
|
uint256 GetHash() const |
|
|
|
{ |
|
|
|
{ |
|
|
|
return SerializeHash(*this); |
|
|
|
return (nBestHeight >= HARDFORK_BLOCK1) ? SerializeHashHF1(*this) : SerializeHash(*this); |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
friend bool operator==(const CTxOut& a, const CTxOut& b) |
|
|
|
friend bool operator==(const CTxOut& a, const CTxOut& b) |
|
|
@ -504,7 +506,7 @@ public: |
|
|
|
|
|
|
|
|
|
|
|
uint256 GetHash() const |
|
|
|
uint256 GetHash() const |
|
|
|
{ |
|
|
|
{ |
|
|
|
return SerializeHash(*this); |
|
|
|
return (nBestHeight >= HARDFORK_BLOCK1) ? SerializeHashHF1(*this) : SerializeHash(*this); |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
bool IsFinal(int nBlockHeight=0, int64 nBlockTime=0) const |
|
|
|
bool IsFinal(int nBlockHeight=0, int64 nBlockTime=0) const |
|
|
@ -794,7 +796,7 @@ public: |
|
|
|
CHashWriter hasher(SER_GETHASH, PROTOCOL_VERSION); |
|
|
|
CHashWriter hasher(SER_GETHASH, PROTOCOL_VERSION); |
|
|
|
hasher << hashBlock; |
|
|
|
hasher << hashBlock; |
|
|
|
hasher << *this; |
|
|
|
hasher << *this; |
|
|
|
fileout << hasher.GetHash(); |
|
|
|
fileout << (nBestHeight >= HARDFORK_BLOCK1) ? hasher.GetHashHF1 () : hasher.GetHash(); |
|
|
|
|
|
|
|
|
|
|
|
// Flush stdio buffers and commit to disk before returning
|
|
|
|
// Flush stdio buffers and commit to disk before returning
|
|
|
|
fflush(fileout); |
|
|
|
fflush(fileout); |
|
|
@ -825,7 +827,7 @@ public: |
|
|
|
CHashWriter hasher(SER_GETHASH, PROTOCOL_VERSION); |
|
|
|
CHashWriter hasher(SER_GETHASH, PROTOCOL_VERSION); |
|
|
|
hasher << hashBlock; |
|
|
|
hasher << hashBlock; |
|
|
|
hasher << *this; |
|
|
|
hasher << *this; |
|
|
|
if (hashChecksum != hasher.GetHash()) |
|
|
|
if (hashChecksum != ((nBestHeight >= HARDFORK_BLOCK1) ? hasher.GetHashHF1 () : hasher.GetHash())) |
|
|
|
return error("CBlockUndo::ReadFromDisk() : checksum mismatch"); |
|
|
|
return error("CBlockUndo::ReadFromDisk() : checksum mismatch"); |
|
|
|
|
|
|
|
|
|
|
|
return true; |
|
|
|
return true; |
|
|
@ -1377,6 +1379,9 @@ public: |
|
|
|
for (int i = 0; i < nSize; i += 2) |
|
|
|
for (int i = 0; i < nSize; i += 2) |
|
|
|
{ |
|
|
|
{ |
|
|
|
int i2 = std::min(i+1, nSize-1); |
|
|
|
int i2 = std::min(i+1, nSize-1); |
|
|
|
|
|
|
|
if (nBestHeight >= HARDFORK_BLOCK1) |
|
|
|
|
|
|
|
vMerkleTree.push_back(Hash (vMerkleTree[j+i], vMerkleTree[j+i2])); |
|
|
|
|
|
|
|
else |
|
|
|
vMerkleTree.push_back(Hash(BEGIN(vMerkleTree[j+i]), END(vMerkleTree[j+i]), |
|
|
|
vMerkleTree.push_back(Hash(BEGIN(vMerkleTree[j+i]), END(vMerkleTree[j+i]), |
|
|
|
BEGIN(vMerkleTree[j+i2]), END(vMerkleTree[j+i2]))); |
|
|
|
BEGIN(vMerkleTree[j+i2]), END(vMerkleTree[j+i2]))); |
|
|
|
} |
|
|
|
} |
|
|
@ -1412,11 +1417,21 @@ public: |
|
|
|
if (nIndex == -1) |
|
|
|
if (nIndex == -1) |
|
|
|
return 0; |
|
|
|
return 0; |
|
|
|
BOOST_FOREACH(const uint256& otherside, vMerkleBranch) |
|
|
|
BOOST_FOREACH(const uint256& otherside, vMerkleBranch) |
|
|
|
|
|
|
|
{ |
|
|
|
|
|
|
|
if (nBestHeight >= HARDFORK_BLOCK1) |
|
|
|
|
|
|
|
{ |
|
|
|
|
|
|
|
if (nIndex & 1) |
|
|
|
|
|
|
|
hash = Hash(otherside, hash); |
|
|
|
|
|
|
|
else |
|
|
|
|
|
|
|
hash = Hash(hash, otherside); |
|
|
|
|
|
|
|
} |
|
|
|
|
|
|
|
else |
|
|
|
{ |
|
|
|
{ |
|
|
|
if (nIndex & 1) |
|
|
|
if (nIndex & 1) |
|
|
|
hash = Hash(BEGIN(otherside), END(otherside), BEGIN(hash), END(hash)); |
|
|
|
hash = Hash(BEGIN(otherside), END(otherside), BEGIN(hash), END(hash)); |
|
|
|
else |
|
|
|
else |
|
|
|
hash = Hash(BEGIN(hash), END(hash), BEGIN(otherside), END(otherside)); |
|
|
|
hash = Hash(BEGIN(hash), END(hash), BEGIN(otherside), END(otherside)); |
|
|
|
|
|
|
|
} |
|
|
|
nIndex >>= 1; |
|
|
|
nIndex >>= 1; |
|
|
|
} |
|
|
|
} |
|
|
|
return hash; |
|
|
|
return hash; |
|
|
|