|
|
|
@ -726,30 +726,7 @@ public:
@@ -726,30 +726,7 @@ public:
|
|
|
|
|
|
|
|
|
|
/** Functions for disk access for blocks */ |
|
|
|
|
bool WriteBlockToDisk(CBlock& block, CDiskBlockPos& pos); |
|
|
|
|
inline bool ReadBlockFromDisk(CBlock& block, const CDiskBlockPos& pos) |
|
|
|
|
{ |
|
|
|
|
block.SetNull(); |
|
|
|
|
|
|
|
|
|
// Open history file to read
|
|
|
|
|
CAutoFile filein = CAutoFile(OpenBlockFile(pos, true), SER_DISK, CLIENT_VERSION); |
|
|
|
|
if (!filein) |
|
|
|
|
return error("ReadBlockFromDisk(CBlock&, CDiskBlockPos&) : OpenBlockFile failed"); |
|
|
|
|
|
|
|
|
|
// Read block
|
|
|
|
|
try { |
|
|
|
|
filein >> block; |
|
|
|
|
} |
|
|
|
|
catch (std::exception &e) { |
|
|
|
|
return error("%s() : deserialize or I/O error", __PRETTY_FUNCTION__); |
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
// Check the header
|
|
|
|
|
if (!CheckProofOfWork(block.GetHash(), block.nBits)) |
|
|
|
|
return error("ReadBlockFromDisk(CBlock&, CDiskBlockPos&) : errors in block header"); |
|
|
|
|
|
|
|
|
|
return true; |
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
bool ReadBlockFromDisk(CBlock& block, const CDiskBlockPos& pos); |
|
|
|
|
bool ReadBlockFromDisk(CBlock& block, const CBlockIndex* pindex); |
|
|
|
|
|
|
|
|
|
|
|
|
|
|