47 bool mutation =
false;
48 while (hashes.size() > 1) {
50 for (
size_t pos = 0; pos + 1 < hashes.size(); pos += 2) {
51 if (hashes[pos] == hashes[pos + 1]) mutation =
true;
54 if (hashes.size() & 1) {
55 hashes.push_back(hashes.back());
57 SHA256D64(hashes[0].begin(), hashes[0].begin(), hashes.size() / 2);
58 hashes.resize(hashes.size() / 2);
60 if (mutated) *mutated = mutation;
61 if (hashes.size() == 0)
return uint256();
68 std::vector<uint256> leaves;
69 leaves.resize(block.
vtx.size());
70 for (
size_t s = 0;
s < block.
vtx.size();
s++) {
71 leaves[
s] = block.
vtx[
s]->GetHash().ToUint256();
78 std::vector<uint256> leaves;
79 leaves.resize(block.
vtx.size());
81 for (
size_t s = 1;
s < block.
vtx.size();
s++) {
82 leaves[
s] = block.
vtx[
s]->GetWitnessHash().ToUint256();
88static void MerkleComputation(
const std::vector<uint256>& leaves, uint32_t leaf_pos, std::vector<uint256>& path)
91 Assume(leaves.size() <= UINT32_MAX);
92 if (leaves.size() == 0) {
106 while (
count < leaves.size()) {
108 bool matchh =
count == leaf_pos;
114 for (level = 0; !(
count & ((uint32_t{1}) << level)); level++) {
116 path.push_back(inner[level]);
117 }
else if (matchlevel == level) {
121 h =
Hash(inner[level], h);
135 while (!(
count & ((uint32_t{1}) << level))) {
139 bool matchh = matchlevel == level;
140 while (
count != ((uint32_t{1}) << level)) {
150 count += ((uint32_t{1}) << level);
153 while (!(
count & ((uint32_t{1}) << level))) {
155 path.push_back(inner[level]);
156 }
else if (matchlevel == level) {
160 h =
Hash(inner[level], h);
166static std::vector<uint256>
ComputeMerklePath(
const std::vector<uint256>& leaves, uint32_t position) {
167 std::vector<uint256>
ret;
174 std::vector<uint256> leaves;
175 leaves.resize(block.
vtx.size());
176 for (
size_t s = 0;
s < block.
vtx.size();
s++) {
177 leaves[
s] = block.
vtx[
s]->GetHash().ToUint256();
#define Assume(val)
Assume is the identity function.
std::vector< CTransactionRef > vtx
uint256 ComputeMerkleRoot(std::vector< uint256 > hashes, bool *mutated)
uint256 BlockMerkleRoot(const CBlock &block, bool *mutated)
static std::vector< uint256 > ComputeMerklePath(const std::vector< uint256 > &leaves, uint32_t position)
static void MerkleComputation(const std::vector< uint256 > &leaves, uint32_t leaf_pos, std::vector< uint256 > &path)
std::vector< uint256 > TransactionMerklePath(const CBlock &block, uint32_t position)
Compute merkle path to the specified transaction.
uint256 BlockWitnessMerkleRoot(const CBlock &block)
uint256 Hash(const T &in1)
Compute the 256-bit hash of an object.
void SHA256D64(unsigned char *out, const unsigned char *in, size_t blocks)
Compute multiple double-SHA256's of 64-byte blobs.