mirror of
https://github.com/bitcoin/bitcoin.git
synced 2026-04-14 09:37:59 +02:00
policy, refactor: Convert uint256 to Txid
This commit is contained in:
@@ -16,7 +16,7 @@
|
||||
|
||||
/** IsTopoSortedPackage where a set of txids has been pre-populated. The set is assumed to be correct and
|
||||
* is mutated within this function (even if return value is false). */
|
||||
bool IsTopoSortedPackage(const Package& txns, std::unordered_set<uint256, SaltedTxidHasher>& later_txids)
|
||||
bool IsTopoSortedPackage(const Package& txns, std::unordered_set<Txid, SaltedTxidHasher>& later_txids)
|
||||
{
|
||||
// Avoid misusing this function: later_txids should contain the txids of txns.
|
||||
Assume(txns.size() == later_txids.size());
|
||||
@@ -42,7 +42,7 @@ bool IsTopoSortedPackage(const Package& txns, std::unordered_set<uint256, Salted
|
||||
|
||||
bool IsTopoSortedPackage(const Package& txns)
|
||||
{
|
||||
std::unordered_set<uint256, SaltedTxidHasher> later_txids;
|
||||
std::unordered_set<Txid, SaltedTxidHasher> later_txids;
|
||||
std::transform(txns.cbegin(), txns.cend(), std::inserter(later_txids, later_txids.end()),
|
||||
[](const auto& tx) { return tx->GetHash(); });
|
||||
|
||||
@@ -91,7 +91,7 @@ bool IsWellFormedPackage(const Package& txns, PackageValidationState& state, boo
|
||||
return state.Invalid(PackageValidationResult::PCKG_POLICY, "package-too-large");
|
||||
}
|
||||
|
||||
std::unordered_set<uint256, SaltedTxidHasher> later_txids;
|
||||
std::unordered_set<Txid, SaltedTxidHasher> later_txids;
|
||||
std::transform(txns.cbegin(), txns.cend(), std::inserter(later_txids, later_txids.end()),
|
||||
[](const auto& tx) { return tx->GetHash(); });
|
||||
|
||||
@@ -123,7 +123,7 @@ bool IsChildWithParents(const Package& package)
|
||||
|
||||
// The package is expected to be sorted, so the last transaction is the child.
|
||||
const auto& child = package.back();
|
||||
std::unordered_set<uint256, SaltedTxidHasher> input_txids;
|
||||
std::unordered_set<Txid, SaltedTxidHasher> input_txids;
|
||||
std::transform(child->vin.cbegin(), child->vin.cend(),
|
||||
std::inserter(input_txids, input_txids.end()),
|
||||
[](const auto& input) { return input.prevout.hash; });
|
||||
@@ -136,7 +136,7 @@ bool IsChildWithParents(const Package& package)
|
||||
bool IsChildWithParentsTree(const Package& package)
|
||||
{
|
||||
if (!IsChildWithParents(package)) return false;
|
||||
std::unordered_set<uint256, SaltedTxidHasher> parent_txids;
|
||||
std::unordered_set<Txid, SaltedTxidHasher> parent_txids;
|
||||
std::transform(package.cbegin(), package.cend() - 1, std::inserter(parent_txids, parent_txids.end()),
|
||||
[](const auto& ptx) { return ptx->GetHash(); });
|
||||
// Each parent must not have an input who is one of the other parents.
|
||||
|
||||
Reference in New Issue
Block a user