mirror of
https://github.com/bitcoin/bitcoin.git
synced 2026-01-19 06:43:45 +01:00
[mempool] Revert unbroadcast set to tracking just txid
When I originally implemented the unbroadcast set in 18038, it just tracked txids. After 18038 was merged, I offered a patch to 18044 to make the unbroadcast changes compatible with wtxid relay. In this patch, I updated `unbroadcast_txids` to a map of txid -> wtxid. Post merge review comments shed light on the fact that this update was unnecessary, and distracting. So, this commit updates the unbroadcast ids back to a set.
This commit is contained in:
@@ -5116,7 +5116,7 @@ bool LoadMempool(CTxMemPool& pool)
|
||||
}
|
||||
|
||||
// TODO: remove this try except in v0.22
|
||||
std::map<uint256, uint256> unbroadcast_txids;
|
||||
std::set<uint256> unbroadcast_txids;
|
||||
try {
|
||||
file >> unbroadcast_txids;
|
||||
unbroadcast = unbroadcast_txids.size();
|
||||
@@ -5124,13 +5124,10 @@ bool LoadMempool(CTxMemPool& pool)
|
||||
// mempool.dat files created prior to v0.21 will not have an
|
||||
// unbroadcast set. No need to log a failure if parsing fails here.
|
||||
}
|
||||
for (const auto& elem : unbroadcast_txids) {
|
||||
// Don't add unbroadcast transactions that didn't get back into the
|
||||
// mempool.
|
||||
const CTransactionRef& added_tx = pool.get(elem.first);
|
||||
if (added_tx != nullptr) {
|
||||
pool.AddUnbroadcastTx(elem.first, added_tx->GetWitnessHash());
|
||||
}
|
||||
for (const auto& txid : unbroadcast_txids) {
|
||||
// Ensure transactions were accepted to mempool then add to
|
||||
// unbroadcast set.
|
||||
if (pool.get(txid) != nullptr) pool.AddUnbroadcastTx(txid);
|
||||
}
|
||||
} catch (const std::exception& e) {
|
||||
LogPrintf("Failed to deserialize mempool data on disk: %s. Continuing anyway.\n", e.what());
|
||||
@@ -5147,7 +5144,7 @@ bool DumpMempool(const CTxMemPool& pool)
|
||||
|
||||
std::map<uint256, CAmount> mapDeltas;
|
||||
std::vector<TxMempoolInfo> vinfo;
|
||||
std::map<uint256, uint256> unbroadcast_txids;
|
||||
std::set<uint256> unbroadcast_txids;
|
||||
|
||||
static Mutex dump_mutex;
|
||||
LOCK(dump_mutex);
|
||||
|
||||
Reference in New Issue
Block a user