Merge bitcoin/bitcoin#25331: Add HashWriter without ser-type and ser-version and use it where possible

faf9accd66 Use HashWriter where possible (MacroFake)
faa5425629 Add HashWriter without ser-type and ser-version (MacroFake)

Pull request description:

  This was done in the context of https://github.com/bitcoin/bitcoin/pull/25284 , but I think it also makes sense standalone.

  The basic idea is that serialization type should not be initialized when it is not needed. Same for the serialization version.

  So do this here for `HashWriter`. `CHashWriter` remains in places where it is not yet possible.

ACKs for top commit:
  sipa:
    utACK faf9accd66
  Empact:
    utACK faf9accd66

Tree-SHA512: 544cc712436e49f6e608120bcd3ddc5ea72dd236554ce30fb6cfff34a92d7e67b6e6527336ad0f5b6365e2b2884f4c6508aef775953ccd9312f17752729703f2
This commit is contained in:
fanquake 2022-07-22 08:36:00 +01:00
commit 510ac41eac
No known key found for this signature in database
GPG key ID: 2EEB9F5CC09526C1
14 changed files with 65 additions and 53 deletions

View file

@ -352,7 +352,7 @@ public:
consensus.vDeployments[Consensus::DEPLOYMENT_TAPROOT].min_activation_height = 0; // No activation delay consensus.vDeployments[Consensus::DEPLOYMENT_TAPROOT].min_activation_height = 0; // No activation delay
// message start is defined as the first 4 bytes of the sha256d of the block script // message start is defined as the first 4 bytes of the sha256d of the block script
CHashWriter h(SER_DISK, 0); HashWriter h{};
h << consensus.signet_challenge; h << consensus.signet_challenge;
uint256 hash = h.GetHash(); uint256 hash = h.GetHash();
memcpy(pchMessageStart, hash.begin(), 4); memcpy(pchMessageStart, hash.begin(), 4);

View file

@ -298,7 +298,7 @@ void Num3072::ToBytes(unsigned char (&out)[BYTE_SIZE]) {
Num3072 MuHash3072::ToNum3072(Span<const unsigned char> in) { Num3072 MuHash3072::ToNum3072(Span<const unsigned char> in) {
unsigned char tmp[Num3072::BYTE_SIZE]; unsigned char tmp[Num3072::BYTE_SIZE];
uint256 hashed_in = (CHashWriter(SER_DISK, 0) << in).GetSHA256(); uint256 hashed_in{(HashWriter{} << in).GetSHA256()};
ChaCha20(hashed_in.data(), hashed_in.size()).Keystream(tmp, Num3072::BYTE_SIZE); ChaCha20(hashed_in.data(), hashed_in.size()).Keystream(tmp, Num3072::BYTE_SIZE);
Num3072 out{tmp}; Num3072 out{tmp};
@ -318,7 +318,7 @@ void MuHash3072::Finalize(uint256& out) noexcept
unsigned char data[Num3072::BYTE_SIZE]; unsigned char data[Num3072::BYTE_SIZE];
m_numerator.ToBytes(data); m_numerator.ToBytes(data);
out = (CHashWriter(SER_DISK, 0) << data).GetSHA256(); out = (HashWriter{} << data).GetSHA256();
} }
MuHash3072& MuHash3072::operator*=(const MuHash3072& mul) noexcept MuHash3072& MuHash3072::operator*=(const MuHash3072& mul) noexcept

View file

@ -86,9 +86,9 @@ uint256 SHA256Uint256(const uint256& input)
return result; return result;
} }
CHashWriter TaggedHash(const std::string& tag) HashWriter TaggedHash(const std::string& tag)
{ {
CHashWriter writer(SER_GETHASH, 0); HashWriter writer{};
uint256 taghash; uint256 taghash;
CSHA256().Write((const unsigned char*)tag.data(), tag.size()).Finalize(taghash.begin()); CSHA256().Write((const unsigned char*)tag.data(), tag.size()).Finalize(taghash.begin());
writer << taghash << taghash; writer << taghash << taghash;

View file

@ -96,20 +96,12 @@ inline uint160 Hash160(const T1& in1)
} }
/** A writer stream (for serialization) that computes a 256-bit hash. */ /** A writer stream (for serialization) that computes a 256-bit hash. */
class CHashWriter class HashWriter
{ {
private: private:
CSHA256 ctx; CSHA256 ctx;
const int nType;
const int nVersion;
public: public:
CHashWriter(int nTypeIn, int nVersionIn) : nType(nTypeIn), nVersion(nVersionIn) {}
int GetType() const { return nType; }
int GetVersion() const { return nVersion; }
void write(Span<const std::byte> src) void write(Span<const std::byte> src)
{ {
ctx.Write(UCharCast(src.data()), src.size()); ctx.Write(UCharCast(src.data()), src.size());
@ -144,6 +136,26 @@ public:
return ReadLE64(result.begin()); return ReadLE64(result.begin());
} }
template <typename T>
HashWriter& operator<<(const T& obj)
{
::Serialize(*this, obj);
return *this;
}
};
class CHashWriter : public HashWriter
{
private:
const int nType;
const int nVersion;
public:
CHashWriter(int nTypeIn, int nVersionIn) : nType(nTypeIn), nVersion(nVersionIn) {}
int GetType() const { return nType; }
int GetVersion() const { return nVersion; }
template<typename T> template<typename T>
CHashWriter& operator<<(const T& obj) { CHashWriter& operator<<(const T& obj) {
// Serialize to this stream // Serialize to this stream
@ -203,12 +215,12 @@ unsigned int MurmurHash3(unsigned int nHashSeed, Span<const unsigned char> vData
void BIP32Hash(const ChainCode &chainCode, unsigned int nChild, unsigned char header, const unsigned char data[32], unsigned char output[64]); void BIP32Hash(const ChainCode &chainCode, unsigned int nChild, unsigned char header, const unsigned char data[32], unsigned char output[64]);
/** Return a CHashWriter primed for tagged hashes (as specified in BIP 340). /** Return a HashWriter primed for tagged hashes (as specified in BIP 340).
* *
* The returned object will have SHA256(tag) written to it twice (= 64 bytes). * The returned object will have SHA256(tag) written to it twice (= 64 bytes).
* A tagged hash can be computed by feeding the message into this object, and * A tagged hash can be computed by feeding the message into this object, and
* then calling CHashWriter::GetSHA256(). * then calling HashWriter::GetSHA256().
*/ */
CHashWriter TaggedHash(const std::string& tag); HashWriter TaggedHash(const std::string& tag);
#endif // BITCOIN_HASH_H #endif // BITCOIN_HASH_H

View file

@ -68,7 +68,7 @@ CDataStream TxOutSer(const COutPoint& outpoint, const Coin& coin) {
//! It is also possible, though very unlikely, that a change in this //! It is also possible, though very unlikely, that a change in this
//! construction could cause a previously invalid (and potentially malicious) //! construction could cause a previously invalid (and potentially malicious)
//! UTXO snapshot to be considered valid. //! UTXO snapshot to be considered valid.
static void ApplyHash(CHashWriter& ss, const uint256& hash, const std::map<uint32_t, Coin>& outputs) static void ApplyHash(HashWriter& ss, const uint256& hash, const std::map<uint32_t, Coin>& outputs)
{ {
for (auto it = outputs.begin(); it != outputs.end(); ++it) { for (auto it = outputs.begin(); it != outputs.end(); ++it) {
if (it == outputs.begin()) { if (it == outputs.begin()) {
@ -159,7 +159,7 @@ std::optional<CCoinsStats> ComputeUTXOStats(CoinStatsHashType hash_type, CCoinsV
bool success = [&]() -> bool { bool success = [&]() -> bool {
switch (hash_type) { switch (hash_type) {
case(CoinStatsHashType::HASH_SERIALIZED): { case(CoinStatsHashType::HASH_SERIALIZED): {
CHashWriter ss(SER_GETHASH, PROTOCOL_VERSION); HashWriter ss{};
return ComputeUTXOStats(view, stats, ss, interruption_point); return ComputeUTXOStats(view, stats, ss, interruption_point);
} }
case(CoinStatsHashType::MUHASH): { case(CoinStatsHashType::MUHASH): {
@ -180,7 +180,7 @@ std::optional<CCoinsStats> ComputeUTXOStats(CoinStatsHashType hash_type, CCoinsV
} }
// The legacy hash serializes the hashBlock // The legacy hash serializes the hashBlock
static void PrepareHash(CHashWriter& ss, const CCoinsStats& stats) static void PrepareHash(HashWriter& ss, const CCoinsStats& stats)
{ {
ss << stats.hashBlock; ss << stats.hashBlock;
} }
@ -188,7 +188,7 @@ static void PrepareHash(CHashWriter& ss, const CCoinsStats& stats)
static void PrepareHash(MuHash3072& muhash, CCoinsStats& stats) {} static void PrepareHash(MuHash3072& muhash, CCoinsStats& stats) {}
static void PrepareHash(std::nullptr_t, CCoinsStats& stats) {} static void PrepareHash(std::nullptr_t, CCoinsStats& stats) {}
static void FinalizeHash(CHashWriter& ss, CCoinsStats& stats) static void FinalizeHash(HashWriter& ss, CCoinsStats& stats)
{ {
stats.hashSerialized = ss.GetHash(); stats.hashSerialized = ss.GetHash();
} }

View file

@ -471,7 +471,7 @@ static bool UndoWriteToDisk(const CBlockUndo& blockundo, FlatFilePos& pos, const
fileout << blockundo; fileout << blockundo;
// calculate & write checksum // calculate & write checksum
CHashWriter hasher(SER_GETHASH, PROTOCOL_VERSION); HashWriter hasher{};
hasher << hashBlock; hasher << hashBlock;
hasher << blockundo; hasher << blockundo;
fileout << hasher.GetHash(); fileout << hasher.GetHash();

View file

@ -211,16 +211,16 @@ bool XOnlyPubKey::VerifySchnorr(const uint256& msg, Span<const unsigned char> si
return secp256k1_schnorrsig_verify(secp256k1_context_verify, sigbytes.data(), msg.begin(), 32, &pubkey); return secp256k1_schnorrsig_verify(secp256k1_context_verify, sigbytes.data(), msg.begin(), 32, &pubkey);
} }
static const CHashWriter HASHER_TAPTWEAK = TaggedHash("TapTweak"); static const HashWriter HASHER_TAPTWEAK{TaggedHash("TapTweak")};
uint256 XOnlyPubKey::ComputeTapTweakHash(const uint256* merkle_root) const uint256 XOnlyPubKey::ComputeTapTweakHash(const uint256* merkle_root) const
{ {
if (merkle_root == nullptr) { if (merkle_root == nullptr) {
// We have no scripts. The actual tweak does not matter, but follow BIP341 here to // We have no scripts. The actual tweak does not matter, but follow BIP341 here to
// allow for reproducible tweaking. // allow for reproducible tweaking.
return (CHashWriter(HASHER_TAPTWEAK) << m_keydata).GetSHA256(); return (HashWriter{HASHER_TAPTWEAK} << m_keydata).GetSHA256();
} else { } else {
return (CHashWriter(HASHER_TAPTWEAK) << m_keydata << *merkle_root).GetSHA256(); return (HashWriter{HASHER_TAPTWEAK} << m_keydata << *merkle_root).GetSHA256();
} }
} }

View file

@ -1342,7 +1342,7 @@ public:
template <class T> template <class T>
uint256 GetPrevoutsSHA256(const T& txTo) uint256 GetPrevoutsSHA256(const T& txTo)
{ {
CHashWriter ss(SER_GETHASH, 0); HashWriter ss{};
for (const auto& txin : txTo.vin) { for (const auto& txin : txTo.vin) {
ss << txin.prevout; ss << txin.prevout;
} }
@ -1353,7 +1353,7 @@ uint256 GetPrevoutsSHA256(const T& txTo)
template <class T> template <class T>
uint256 GetSequencesSHA256(const T& txTo) uint256 GetSequencesSHA256(const T& txTo)
{ {
CHashWriter ss(SER_GETHASH, 0); HashWriter ss{};
for (const auto& txin : txTo.vin) { for (const auto& txin : txTo.vin) {
ss << txin.nSequence; ss << txin.nSequence;
} }
@ -1364,7 +1364,7 @@ uint256 GetSequencesSHA256(const T& txTo)
template <class T> template <class T>
uint256 GetOutputsSHA256(const T& txTo) uint256 GetOutputsSHA256(const T& txTo)
{ {
CHashWriter ss(SER_GETHASH, 0); HashWriter ss{};
for (const auto& txout : txTo.vout) { for (const auto& txout : txTo.vout) {
ss << txout; ss << txout;
} }
@ -1374,7 +1374,7 @@ uint256 GetOutputsSHA256(const T& txTo)
/** Compute the (single) SHA256 of the concatenation of all amounts spent by a tx. */ /** Compute the (single) SHA256 of the concatenation of all amounts spent by a tx. */
uint256 GetSpentAmountsSHA256(const std::vector<CTxOut>& outputs_spent) uint256 GetSpentAmountsSHA256(const std::vector<CTxOut>& outputs_spent)
{ {
CHashWriter ss(SER_GETHASH, 0); HashWriter ss{};
for (const auto& txout : outputs_spent) { for (const auto& txout : outputs_spent) {
ss << txout.nValue; ss << txout.nValue;
} }
@ -1384,7 +1384,7 @@ uint256 GetSpentAmountsSHA256(const std::vector<CTxOut>& outputs_spent)
/** Compute the (single) SHA256 of the concatenation of all scriptPubKeys spent by a tx. */ /** Compute the (single) SHA256 of the concatenation of all scriptPubKeys spent by a tx. */
uint256 GetSpentScriptsSHA256(const std::vector<CTxOut>& outputs_spent) uint256 GetSpentScriptsSHA256(const std::vector<CTxOut>& outputs_spent)
{ {
CHashWriter ss(SER_GETHASH, 0); HashWriter ss{};
for (const auto& txout : outputs_spent) { for (const auto& txout : outputs_spent) {
ss << txout.scriptPubKey; ss << txout.scriptPubKey;
} }
@ -1458,9 +1458,9 @@ template void PrecomputedTransactionData::Init(const CMutableTransaction& txTo,
template PrecomputedTransactionData::PrecomputedTransactionData(const CTransaction& txTo); template PrecomputedTransactionData::PrecomputedTransactionData(const CTransaction& txTo);
template PrecomputedTransactionData::PrecomputedTransactionData(const CMutableTransaction& txTo); template PrecomputedTransactionData::PrecomputedTransactionData(const CMutableTransaction& txTo);
const CHashWriter HASHER_TAPSIGHASH = TaggedHash("TapSighash"); const HashWriter HASHER_TAPSIGHASH{TaggedHash("TapSighash")};
const CHashWriter HASHER_TAPLEAF = TaggedHash("TapLeaf"); const HashWriter HASHER_TAPLEAF{TaggedHash("TapLeaf")};
const CHashWriter HASHER_TAPBRANCH = TaggedHash("TapBranch"); const HashWriter HASHER_TAPBRANCH{TaggedHash("TapBranch")};
static bool HandleMissingData(MissingDataBehavior mdb) static bool HandleMissingData(MissingDataBehavior mdb)
{ {
@ -1499,7 +1499,7 @@ bool SignatureHashSchnorr(uint256& hash_out, ScriptExecutionData& execdata, cons
return HandleMissingData(mdb); return HandleMissingData(mdb);
} }
CHashWriter ss = HASHER_TAPSIGHASH; HashWriter ss{HASHER_TAPSIGHASH};
// Epoch // Epoch
static constexpr uint8_t EPOCH = 0; static constexpr uint8_t EPOCH = 0;
@ -1544,7 +1544,7 @@ bool SignatureHashSchnorr(uint256& hash_out, ScriptExecutionData& execdata, cons
if (output_type == SIGHASH_SINGLE) { if (output_type == SIGHASH_SINGLE) {
if (in_pos >= tx_to.vout.size()) return false; if (in_pos >= tx_to.vout.size()) return false;
if (!execdata.m_output_hash) { if (!execdata.m_output_hash) {
CHashWriter sha_single_output(SER_GETHASH, 0); HashWriter sha_single_output{};
sha_single_output << tx_to.vout[in_pos]; sha_single_output << tx_to.vout[in_pos];
execdata.m_output_hash = sha_single_output.GetSHA256(); execdata.m_output_hash = sha_single_output.GetSHA256();
} }
@ -1587,12 +1587,12 @@ uint256 SignatureHash(const CScript& scriptCode, const T& txTo, unsigned int nIn
if ((nHashType & 0x1f) != SIGHASH_SINGLE && (nHashType & 0x1f) != SIGHASH_NONE) { if ((nHashType & 0x1f) != SIGHASH_SINGLE && (nHashType & 0x1f) != SIGHASH_NONE) {
hashOutputs = cacheready ? cache->hashOutputs : SHA256Uint256(GetOutputsSHA256(txTo)); hashOutputs = cacheready ? cache->hashOutputs : SHA256Uint256(GetOutputsSHA256(txTo));
} else if ((nHashType & 0x1f) == SIGHASH_SINGLE && nIn < txTo.vout.size()) { } else if ((nHashType & 0x1f) == SIGHASH_SINGLE && nIn < txTo.vout.size()) {
CHashWriter ss(SER_GETHASH, 0); HashWriter ss{};
ss << txTo.vout[nIn]; ss << txTo.vout[nIn];
hashOutputs = ss.GetHash(); hashOutputs = ss.GetHash();
} }
CHashWriter ss(SER_GETHASH, 0); HashWriter ss{};
// Version // Version
ss << txTo.nVersion; ss << txTo.nVersion;
// Input prevouts/nSequence (none/all, depending on flags) // Input prevouts/nSequence (none/all, depending on flags)
@ -1627,7 +1627,7 @@ uint256 SignatureHash(const CScript& scriptCode, const T& txTo, unsigned int nIn
CTransactionSignatureSerializer<T> txTmp(txTo, scriptCode, nIn, nHashType); CTransactionSignatureSerializer<T> txTmp(txTo, scriptCode, nIn, nHashType);
// Serialize and hash // Serialize and hash
CHashWriter ss(SER_GETHASH, 0); HashWriter ss{};
ss << txTmp << nHashType; ss << txTmp << nHashType;
return ss.GetHash(); return ss.GetHash();
} }
@ -1827,7 +1827,7 @@ static bool ExecuteWitnessScript(const Span<const valtype>& stack_span, const CS
uint256 ComputeTapleafHash(uint8_t leaf_version, const CScript& script) uint256 ComputeTapleafHash(uint8_t leaf_version, const CScript& script)
{ {
return (CHashWriter(HASHER_TAPLEAF) << leaf_version << script).GetSHA256(); return (HashWriter{HASHER_TAPLEAF} << leaf_version << script).GetSHA256();
} }
uint256 ComputeTaprootMerkleRoot(Span<const unsigned char> control, const uint256& tapleaf_hash) uint256 ComputeTaprootMerkleRoot(Span<const unsigned char> control, const uint256& tapleaf_hash)
@ -1839,7 +1839,7 @@ uint256 ComputeTaprootMerkleRoot(Span<const unsigned char> control, const uint25
const int path_len = (control.size() - TAPROOT_CONTROL_BASE_SIZE) / TAPROOT_CONTROL_NODE_SIZE; const int path_len = (control.size() - TAPROOT_CONTROL_BASE_SIZE) / TAPROOT_CONTROL_NODE_SIZE;
uint256 k = tapleaf_hash; uint256 k = tapleaf_hash;
for (int i = 0; i < path_len; ++i) { for (int i = 0; i < path_len; ++i) {
CHashWriter ss_branch{HASHER_TAPBRANCH}; HashWriter ss_branch{HASHER_TAPBRANCH};
Span node{Span{control}.subspan(TAPROOT_CONTROL_BASE_SIZE + TAPROOT_CONTROL_NODE_SIZE * i, TAPROOT_CONTROL_NODE_SIZE)}; Span node{Span{control}.subspan(TAPROOT_CONTROL_BASE_SIZE + TAPROOT_CONTROL_NODE_SIZE * i, TAPROOT_CONTROL_NODE_SIZE)};
if (std::lexicographical_compare(k.begin(), k.end(), node.begin(), node.end())) { if (std::lexicographical_compare(k.begin(), k.end(), node.begin(), node.end())) {
ss_branch << k << node; ss_branch << k << node;
@ -1902,7 +1902,7 @@ static bool VerifyWitnessProgram(const CScriptWitness& witness, int witversion,
if (stack.size() >= 2 && !stack.back().empty() && stack.back()[0] == ANNEX_TAG) { if (stack.size() >= 2 && !stack.back().empty() && stack.back()[0] == ANNEX_TAG) {
// Drop annex (this is non-standard; see IsWitnessStandard) // Drop annex (this is non-standard; see IsWitnessStandard)
const valtype& annex = SpanPopBack(stack); const valtype& annex = SpanPopBack(stack);
execdata.m_annex_hash = (CHashWriter(SER_GETHASH, 0) << annex).GetSHA256(); execdata.m_annex_hash = (HashWriter{} << annex).GetSHA256();
execdata.m_annex_present = true; execdata.m_annex_present = true;
} else { } else {
execdata.m_annex_present = false; execdata.m_annex_present = false;

View file

@ -233,9 +233,9 @@ static constexpr size_t TAPROOT_CONTROL_NODE_SIZE = 32;
static constexpr size_t TAPROOT_CONTROL_MAX_NODE_COUNT = 128; static constexpr size_t TAPROOT_CONTROL_MAX_NODE_COUNT = 128;
static constexpr size_t TAPROOT_CONTROL_MAX_SIZE = TAPROOT_CONTROL_BASE_SIZE + TAPROOT_CONTROL_NODE_SIZE * TAPROOT_CONTROL_MAX_NODE_COUNT; static constexpr size_t TAPROOT_CONTROL_MAX_SIZE = TAPROOT_CONTROL_BASE_SIZE + TAPROOT_CONTROL_NODE_SIZE * TAPROOT_CONTROL_MAX_NODE_COUNT;
extern const CHashWriter HASHER_TAPSIGHASH; //!< Hasher with tag "TapSighash" pre-fed to it. extern const HashWriter HASHER_TAPSIGHASH; //!< Hasher with tag "TapSighash" pre-fed to it.
extern const CHashWriter HASHER_TAPLEAF; //!< Hasher with tag "TapLeaf" pre-fed to it. extern const HashWriter HASHER_TAPLEAF; //!< Hasher with tag "TapLeaf" pre-fed to it.
extern const CHashWriter HASHER_TAPBRANCH; //!< Hasher with tag "TapBranch" pre-fed to it. extern const HashWriter HASHER_TAPBRANCH; //!< Hasher with tag "TapBranch" pre-fed to it.
template <class T> template <class T>
uint256 SignatureHash(const CScript& scriptCode, const T& txTo, unsigned int nIn, int nHashType, const CAmount& amount, SigVersion sigversion, const PrecomputedTransactionData* cache = nullptr); uint256 SignatureHash(const CScript& scriptCode, const T& txTo, unsigned int nIn, int nHashType, const CAmount& amount, SigVersion sigversion, const PrecomputedTransactionData* cache = nullptr);

View file

@ -165,7 +165,7 @@ static bool SignTaprootScript(const SigningProvider& provider, const BaseSignatu
if (leaf_version != TAPROOT_LEAF_TAPSCRIPT) return false; if (leaf_version != TAPROOT_LEAF_TAPSCRIPT) return false;
SigVersion sigversion = SigVersion::TAPSCRIPT; SigVersion sigversion = SigVersion::TAPSCRIPT;
uint256 leaf_hash = (CHashWriter(HASHER_TAPLEAF) << uint8_t(leaf_version) << script).GetSHA256(); uint256 leaf_hash = (HashWriter{HASHER_TAPLEAF} << uint8_t(leaf_version) << script).GetSHA256();
// <xonly pubkey> OP_CHECKSIG // <xonly pubkey> OP_CHECKSIG
if (script.size() == 34 && script[33] == OP_CHECKSIG && script[0] == 0x20) { if (script.size() == 34 && script[33] == OP_CHECKSIG && script[0] == 0x20) {

View file

@ -375,9 +375,9 @@ bool IsValidDestination(const CTxDestination& dest) {
} }
/* Lexicographically sort a and b's hash, and compute parent hash. */ /* Lexicographically sort a and b's hash, and compute parent hash. */
if (a.hash < b.hash) { if (a.hash < b.hash) {
ret.hash = (CHashWriter(HASHER_TAPBRANCH) << a.hash << b.hash).GetSHA256(); ret.hash = (HashWriter{HASHER_TAPBRANCH} << a.hash << b.hash).GetSHA256();
} else { } else {
ret.hash = (CHashWriter(HASHER_TAPBRANCH) << b.hash << a.hash).GetSHA256(); ret.hash = (HashWriter{HASHER_TAPBRANCH} << b.hash << a.hash).GetSHA256();
} }
return ret; return ret;
} }
@ -452,7 +452,7 @@ TaprootBuilder& TaprootBuilder::Add(int depth, const CScript& script, int leaf_v
if (!IsValid()) return *this; if (!IsValid()) return *this;
/* Construct NodeInfo object with leaf hash and (if track is true) also leaf information. */ /* Construct NodeInfo object with leaf hash and (if track is true) also leaf information. */
NodeInfo node; NodeInfo node;
node.hash = (CHashWriter{HASHER_TAPLEAF} << uint8_t(leaf_version) << script).GetSHA256(); node.hash = (HashWriter{HASHER_TAPLEAF} << uint8_t(leaf_version) << script).GetSHA256();
if (track) node.leaves.emplace_back(LeafInfo{script, leaf_version, {}}); if (track) node.leaves.emplace_back(LeafInfo{script, leaf_version, {}});
/* Insert into the branch. */ /* Insert into the branch. */
Insert(std::move(node), depth); Insert(std::move(node), depth);
@ -610,7 +610,7 @@ std::optional<std::vector<std::tuple<int, CScript, int>>> InferTaprootTree(const
node.done = true; node.done = true;
stack.pop_back(); stack.pop_back();
} else if (node.sub[0]->done && !node.sub[1]->done && !node.sub[1]->explored && !node.sub[1]->hash.IsNull() && } else if (node.sub[0]->done && !node.sub[1]->done && !node.sub[1]->explored && !node.sub[1]->hash.IsNull() &&
(CHashWriter{HASHER_TAPBRANCH} << node.sub[1]->hash << node.sub[1]->hash).GetSHA256() == node.hash) { (HashWriter{HASHER_TAPBRANCH} << node.sub[1]->hash << node.sub[1]->hash).GetSHA256() == node.hash) {
// Whenever there are nodes with two identical subtrees under it, we run into a problem: // Whenever there are nodes with two identical subtrees under it, we run into a problem:
// the control blocks for the leaves underneath those will be identical as well, and thus // the control blocks for the leaves underneath those will be identical as well, and thus
// they will all be matched to the same path in the tree. The result is that at the location // they will all be matched to the same path in the tree. The result is that at the location

View file

@ -1813,7 +1813,7 @@ BOOST_AUTO_TEST_CASE(bip341_keypath_test_vectors)
BOOST_CHECK_EQUAL(HexStr(sighash), input["intermediary"]["sigHash"].get_str()); BOOST_CHECK_EQUAL(HexStr(sighash), input["intermediary"]["sigHash"].get_str());
// To verify the sigmsg, hash the expected sigmsg, and compare it with the (expected) sighash. // To verify the sigmsg, hash the expected sigmsg, and compare it with the (expected) sighash.
BOOST_CHECK_EQUAL(HexStr((CHashWriter(HASHER_TAPSIGHASH) << Span{ParseHex(input["intermediary"]["sigMsg"].get_str())}).GetSHA256()), input["intermediary"]["sigHash"].get_str()); BOOST_CHECK_EQUAL(HexStr((HashWriter{HASHER_TAPSIGHASH} << Span{ParseHex(input["intermediary"]["sigMsg"].get_str())}).GetSHA256()), input["intermediary"]["sigHash"].get_str());
} }
} }

View file

@ -74,7 +74,7 @@ bool MessageSign(
uint256 MessageHash(const std::string& message) uint256 MessageHash(const std::string& message)
{ {
CHashWriter hasher(SER_GETHASH, 0); HashWriter hasher{};
hasher << MESSAGE_MAGIC << message; hasher << MESSAGE_MAGIC << message;
return hasher.GetHash(); return hasher.GetHash();

View file

@ -41,7 +41,7 @@ bool DumpWallet(const ArgsManager& args, CWallet& wallet, bilingual_str& error)
return false; return false;
} }
CHashWriter hasher(0, 0); HashWriter hasher{};
WalletDatabase& db = wallet.GetDatabase(); WalletDatabase& db = wallet.GetDatabase();
std::unique_ptr<DatabaseBatch> batch = db.MakeBatch(); std::unique_ptr<DatabaseBatch> batch = db.MakeBatch();
@ -132,7 +132,7 @@ bool CreateFromDump(const ArgsManager& args, const std::string& name, const fs::
std::ifstream dump_file{dump_path}; std::ifstream dump_file{dump_path};
// Compute the checksum // Compute the checksum
CHashWriter hasher(0, 0); HashWriter hasher{};
uint256 checksum; uint256 checksum;
// Check the magic and version // Check the magic and version