mirror of
https://github.com/bitcoin/bitcoin.git
synced 2025-01-10 20:03:34 -03:00
Merge #21114: Deduplicate some block-to-JSON code
fa2c521115
Deduplicate some block-to-JSON code. (Daniel Kraft) Pull request description: Some of the logic converting blocks and block headers to JSON for the blockchain RPC methods (`getblock`, `getlockheader`) was duplicated. Instead of that, the `blockToJSON` RPC method now calls `blockheaderToJSON` first, and then fills in the missing, block-specific bits explicitly. ACKs for top commit: laanwj: Code review ACKfa2c521115
Tree-SHA512: 1b9b269e251d9c8c1056f253cfc2a795170d609f4c26ecc85b1ff9cdd567095a673dd89564e0d587b32dfc152ea01b2682169b018f2c9c3004c511a9998d772e
This commit is contained in:
commit
3c514cfe62
1 changed files with 1 additions and 22 deletions
|
@ -156,21 +156,11 @@ UniValue blockheaderToJSON(const CBlockIndex* tip, const CBlockIndex* blockindex
|
||||||
|
|
||||||
UniValue blockToJSON(const CBlock& block, const CBlockIndex* tip, const CBlockIndex* blockindex, bool txDetails)
|
UniValue blockToJSON(const CBlock& block, const CBlockIndex* tip, const CBlockIndex* blockindex, bool txDetails)
|
||||||
{
|
{
|
||||||
// Serialize passed information without accessing chain state of the active chain!
|
UniValue result = blockheaderToJSON(tip, blockindex);
|
||||||
AssertLockNotHeld(cs_main); // For performance reasons
|
|
||||||
|
|
||||||
UniValue result(UniValue::VOBJ);
|
|
||||||
result.pushKV("hash", blockindex->GetBlockHash().GetHex());
|
|
||||||
const CBlockIndex* pnext;
|
|
||||||
int confirmations = ComputeNextBlockAndDepth(tip, blockindex, pnext);
|
|
||||||
result.pushKV("confirmations", confirmations);
|
|
||||||
result.pushKV("strippedsize", (int)::GetSerializeSize(block, PROTOCOL_VERSION | SERIALIZE_TRANSACTION_NO_WITNESS));
|
result.pushKV("strippedsize", (int)::GetSerializeSize(block, PROTOCOL_VERSION | SERIALIZE_TRANSACTION_NO_WITNESS));
|
||||||
result.pushKV("size", (int)::GetSerializeSize(block, PROTOCOL_VERSION));
|
result.pushKV("size", (int)::GetSerializeSize(block, PROTOCOL_VERSION));
|
||||||
result.pushKV("weight", (int)::GetBlockWeight(block));
|
result.pushKV("weight", (int)::GetBlockWeight(block));
|
||||||
result.pushKV("height", blockindex->nHeight);
|
|
||||||
result.pushKV("version", block.nVersion);
|
|
||||||
result.pushKV("versionHex", strprintf("%08x", block.nVersion));
|
|
||||||
result.pushKV("merkleroot", block.hashMerkleRoot.GetHex());
|
|
||||||
UniValue txs(UniValue::VARR);
|
UniValue txs(UniValue::VARR);
|
||||||
if (txDetails) {
|
if (txDetails) {
|
||||||
CBlockUndo blockUndo;
|
CBlockUndo blockUndo;
|
||||||
|
@ -189,18 +179,7 @@ UniValue blockToJSON(const CBlock& block, const CBlockIndex* tip, const CBlockIn
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
result.pushKV("tx", txs);
|
result.pushKV("tx", txs);
|
||||||
result.pushKV("time", block.GetBlockTime());
|
|
||||||
result.pushKV("mediantime", (int64_t)blockindex->GetMedianTimePast());
|
|
||||||
result.pushKV("nonce", (uint64_t)block.nNonce);
|
|
||||||
result.pushKV("bits", strprintf("%08x", block.nBits));
|
|
||||||
result.pushKV("difficulty", GetDifficulty(blockindex));
|
|
||||||
result.pushKV("chainwork", blockindex->nChainWork.GetHex());
|
|
||||||
result.pushKV("nTx", (uint64_t)blockindex->nTx);
|
|
||||||
|
|
||||||
if (blockindex->pprev)
|
|
||||||
result.pushKV("previousblockhash", blockindex->pprev->GetBlockHash().GetHex());
|
|
||||||
if (pnext)
|
|
||||||
result.pushKV("nextblockhash", pnext->GetBlockHash().GetHex());
|
|
||||||
return result;
|
return result;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue