// Copyright (c) 2009-2010 Satoshi Nakamoto // Copyright (c) 2009-2017 The Bitcoin Core developers // Distributed under the MIT software license, see the accompanying // file COPYING or http://www.opensource.org/licenses/mit-license.php. #include #include #include #include #include #include #include extern "C" void cn_slow_hash(const void *data, size_t length, char *hash, int variant, int prehashed, uint64_t height); uint256 CBlockHeader::GetHash() const { CHashWriter hashWriter(SER_GETHASH, PROTOCOL_VERSION); hashWriter.write(BEGIN(nVersion), 80); return hashWriter.GetHash(); } uint256 CBlockHeader::GetPoWHash() const { uint256 thash; if (hashPrevBlock.IsNull()) { // Genesis block cn_slow_hash(BEGIN(nVersion), 80, BEGIN(thash), 2, 0, 0); return thash; } // prev_id of CN header is used to store the kevacoin block hash. // The value of prev_id and block hash must be the same to prove // that PoW has been properly done. if (GetHash() != cnHeader.prev_id) { memset(thash.begin(), 0xff, thash.size()); return thash; } cryptonote::blobdata blob = cryptonote::t_serializable_object_to_blob(cnHeader); cn_slow_hash(blob.data(), blob.size(), BEGIN(thash), 2, 0, 0); return thash; } std::string CBlock::ToString() const { std::stringstream s; s << strprintf("CBlock(hash=%s, ver=0x%08x, hashPrevBlock=%s, hashMerkleRoot=%s, nTime=%u, nBits=%08x, nNonce=%u, vtx=%u)\n", GetHash().ToString(), nVersion, hashPrevBlock.ToString(), hashMerkleRoot.ToString(), nTime, nBits, nNonce, vtx.size()); for (const auto& tx : vtx) { s << " " << tx->ToString() << "\n"; } return s.str(); }