91a25d1e71
Adds the following util units and adds them to libbitcoin_util: - `util/url.cpp` takes `urlDecode` from `httpserver.cpp` - `util/error.cpp` takes `TransactionErrorString` from `node/transaction.cpp` and `AmountHighWarn` and `AmountErrMsg` from `ui_interface.cpp` - `util/fees.cpp` takes `StringForFeeReason` and `FeeModeFromString` from `policy/fees.cpp` - `util/rbf.cpp` takes `SignalsOptInRBF` from `policy/rbf.cpp` - 'util/validation.cpp` takes `FormatStateMessage` and `strMessageMagic` from 'validation.cpp`
38 lines
1.3 KiB
C++
38 lines
1.3 KiB
C++
// Copyright (c) 2016-2018 The Bitcoin Core developers
|
|
// Distributed under the MIT software license, see the accompanying
|
|
// file COPYING or http://www.opensource.org/licenses/mit-license.php.
|
|
|
|
#include <policy/rbf.h>
|
|
#include <util/rbf.h>
|
|
|
|
RBFTransactionState IsRBFOptIn(const CTransaction& tx, const CTxMemPool& pool)
|
|
{
|
|
AssertLockHeld(pool.cs);
|
|
|
|
CTxMemPool::setEntries setAncestors;
|
|
|
|
// First check the transaction itself.
|
|
if (SignalsOptInRBF(tx)) {
|
|
return RBFTransactionState::REPLACEABLE_BIP125;
|
|
}
|
|
|
|
// If this transaction is not in our mempool, then we can't be sure
|
|
// we will know about all its inputs.
|
|
if (!pool.exists(tx.GetHash())) {
|
|
return RBFTransactionState::UNKNOWN;
|
|
}
|
|
|
|
// If all the inputs have nSequence >= maxint-1, it still might be
|
|
// signaled for RBF if any unconfirmed parents have signaled.
|
|
uint64_t noLimit = std::numeric_limits<uint64_t>::max();
|
|
std::string dummy;
|
|
CTxMemPoolEntry entry = *pool.mapTx.find(tx.GetHash());
|
|
pool.CalculateMemPoolAncestors(entry, setAncestors, noLimit, noLimit, noLimit, noLimit, dummy, false);
|
|
|
|
for (CTxMemPool::txiter it : setAncestors) {
|
|
if (SignalsOptInRBF(it->GetTx())) {
|
|
return RBFTransactionState::REPLACEABLE_BIP125;
|
|
}
|
|
}
|
|
return RBFTransactionState::FINAL;
|
|
}
|