mirror of
https://github.com/bitcoin/bitcoin.git
synced 2026-04-01 11:26:03 +02:00
Merge bitcoin/bitcoin#25877: refactor: Do not use CScript for tapleaf scripts until the tapleaf version is known
dee89438b8Abstract out ComputeTapbranchHash (Russell O'Connor)8e3fc99427Do not use CScript for tapleaf scripts until the tapleaf version is known (Russell O'Connor) Pull request description: While BIP-341 calls the contents of tapleaf a "script", only in the case that the tapleaf version is `0xc0` is this script known to be a tapscript. Otherwise the tapleaf "script" is simply an uninterpreted string of bytes. This PR corrects the issue where the type `CScript` is used prior to the tapleaf version being known to be a tapscript. This prevents `CScript` methods from erroneously being called on non-tapscript data. A second commit abstracts out the TapBranch hash computation in the same manner that the TapLeaf computation is already abstracted. These two abstractions ensure that the TapLeaf and TapBranch tagged hashes are always constructed properly. ACKs for top commit: ajtowns: ACKdee89438b8instagibbs: ACKdee89438b8achow101: ACKdee89438b8sipa: ACKdee89438b8aureleoules: reACKdee89438b8- I verified that there is no behavior change. Tree-SHA512: 4a1d37f3e9a1890e7f5eadcf65562688cc451389581fe6e2da0feb2368708edacdd95392578d8afff05270d88fc61dce732d83d1063d84d12cf47b5f4633ec7e
This commit is contained in:
@@ -333,7 +333,10 @@ public:
|
||||
};
|
||||
|
||||
/** Compute the BIP341 tapleaf hash from leaf version & script. */
|
||||
uint256 ComputeTapleafHash(uint8_t leaf_version, const CScript& script);
|
||||
uint256 ComputeTapleafHash(uint8_t leaf_version, Span<const unsigned char> script);
|
||||
/** Compute the BIP341 tapbranch hash from two branches.
|
||||
* Spans must be 32 bytes each. */
|
||||
uint256 ComputeTapbranchHash(Span<const unsigned char> a, Span<const unsigned char> b);
|
||||
/** Compute the BIP341 taproot script tree Merkle root from control block and leaf hash.
|
||||
* Requires control block to have valid length (33 + k*32, with k in {0,1,..,128}). */
|
||||
uint256 ComputeTaprootMerkleRoot(Span<const unsigned char> control, const uint256& tapleaf_hash);
|
||||
|
||||
Reference in New Issue
Block a user