aboutsummaryrefslogtreecommitdiff
path: root/src/consensus/merkle.cpp
diff options
context:
space:
mode:
authorPieter Wuille <[email protected]>2015-11-06 01:42:38 +0100
committerPieter Wuille <[email protected]>2016-06-22 15:42:59 +0200
commit8b49040854be2e26b66366aeae1cba4716f93d93 (patch)
treeb217f3fb71bc0745c1f74ab239fbe0ebcf52a751 /src/consensus/merkle.cpp
parentBIP141: Witness program (diff)
downloaddiscoin-8b49040854be2e26b66366aeae1cba4716f93d93.tar.xz
discoin-8b49040854be2e26b66366aeae1cba4716f93d93.zip
BIP141: Commitment structure and deployment
Includes a fix by Suhas Daftuar and LongShao007
Diffstat (limited to 'src/consensus/merkle.cpp')
-rw-r--r--src/consensus/merkle.cpp11
1 files changed, 11 insertions, 0 deletions
diff --git a/src/consensus/merkle.cpp b/src/consensus/merkle.cpp
index 22eb7159a..35f7d2e05 100644
--- a/src/consensus/merkle.cpp
+++ b/src/consensus/merkle.cpp
@@ -165,6 +165,17 @@ uint256 BlockMerkleRoot(const CBlock& block, bool* mutated)
return ComputeMerkleRoot(leaves, mutated);
}
+uint256 BlockWitnessMerkleRoot(const CBlock& block, bool* mutated)
+{
+ std::vector<uint256> leaves;
+ leaves.resize(block.vtx.size());
+ leaves[0].SetNull(); // The witness hash of the coinbase is 0.
+ for (size_t s = 1; s < block.vtx.size(); s++) {
+ leaves[s] = block.vtx[s].GetWitnessHash();
+ }
+ return ComputeMerkleRoot(leaves, mutated);
+}
+
std::vector<uint256> BlockMerkleBranch(const CBlock& block, uint32_t position)
{
std::vector<uint256> leaves;