BSHA3  0.17.99
P2P Blockchain, based on Bitcoin
merkle.h
Go to the documentation of this file.
1 // Copyright (c) 2015-2018 The Bitcoin Core developers
2 // Distributed under the MIT software license, see the accompanying
3 // file COPYING or http://www.opensource.org/licenses/mit-license.php.
4 
5 #ifndef BITCOIN_CONSENSUS_MERKLE_H
6 #define BITCOIN_CONSENSUS_MERKLE_H
7 
8 #include <stdint.h>
9 #include <vector>
10 
11 #include <primitives/transaction.h>
12 #include <primitives/block.h>
13 #include <uint256.h>
14 
15 uint256 ComputeMerkleRoot(std::vector<uint256> hashes, bool* mutated = nullptr);
16 
17 /*
18  * Compute the Merkle root of the transactions in a block.
19  * *mutated is set to true if a duplicated subtree was found.
20  */
21 uint256 BlockMerkleRoot(const CBlock& block, bool* mutated = nullptr);
22 
23 /*
24  * Compute the Merkle root of the witness transactions in a block.
25  * *mutated is set to true if a duplicated subtree was found.
26  */
27 uint256 BlockWitnessMerkleRoot(const CBlock& block, bool* mutated = nullptr);
28 
29 #endif // BITCOIN_CONSENSUS_MERKLE_H
Definition: block.h:74
uint256 BlockWitnessMerkleRoot(const CBlock &block, bool *mutated=nullptr)
Definition: merkle.cpp:76
uint256 BlockMerkleRoot(const CBlock &block, bool *mutated=nullptr)
Definition: merkle.cpp:66
256-bit opaque blob.
Definition: uint256.h:122
uint256 ComputeMerkleRoot(std::vector< uint256 > hashes, bool *mutated=nullptr)
Definition: merkle.cpp:46