aboutsummaryrefslogtreecommitdiff
path: root/src/policy/packages.cpp
diff options
context:
space:
mode:
authorglozow <gloriajzhao@gmail.com>2021-07-16 10:29:11 +0100
committerglozow <gloriajzhao@gmail.com>2021-11-29 12:46:58 +0000
commit9b2fdca7f03911ac40fe0f8a0b5da534bee4554b (patch)
tree8ac96fe74605aaf0d0288ef6ae25b0ddb3bb6435 /src/policy/packages.cpp
parent8ae4ba481ce8f7da173bef24432729c87a36cb70 (diff)
downloadbitcoin-9b2fdca7f03911ac40fe0f8a0b5da534bee4554b.tar.xz
[packages] add static IsChildWithParents function
Diffstat (limited to 'src/policy/packages.cpp')
-rw-r--r--src/policy/packages.cpp17
1 files changed, 17 insertions, 0 deletions
diff --git a/src/policy/packages.cpp b/src/policy/packages.cpp
index cfd0539965..21f5488816 100644
--- a/src/policy/packages.cpp
+++ b/src/policy/packages.cpp
@@ -60,3 +60,20 @@ bool CheckPackage(const Package& txns, PackageValidationState& state)
}
return true;
}
+
+bool IsChildWithParents(const Package& package)
+{
+ assert(std::all_of(package.cbegin(), package.cend(), [](const auto& tx){return tx != nullptr;}));
+ if (package.size() < 2) return false;
+
+ // 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::transform(child->vin.cbegin(), child->vin.cend(),
+ std::inserter(input_txids, input_txids.end()),
+ [](const auto& input) { return input.prevout.hash; });
+
+ // Every transaction must be a parent of the last transaction in the package.
+ return std::all_of(package.cbegin(), package.cend() - 1,
+ [&input_txids](const auto& ptx) { return input_txids.count(ptx->GetHash()) > 0; });
+}