mirror of
https://github.com/bitcoin/bitcoin.git
synced 2026-06-10 06:39:15 +02:00
Merge #19879: [p2p] miscellaneous wtxid followups
a8a64acaf3[BroadcastTransaction] Remove unsafe move operator (Amiti Uttarwar)125c038126[p2p] Remove dead code (Amiti Uttarwar)fc66d0a65c[p2p] Check for nullptr before dereferencing pointer (Adam Jonas)cb79b9dbf4[mempool] Revert unbroadcast set to tracking just txid (Amiti Uttarwar) Pull request description: Addresses some outstanding review comments from #18044 - reverts unbroadcast txids to a set instead of a map (simpler, communicates intent better, takes less space, no efficiency advantages of map) - adds safety around two touchpoints (check for nullptr before dereferencing pointer, remove an inaccurate std::move operator) - removes some dead code Links to comments on wtxid PR: [1](https://github.com/bitcoin/bitcoin/pull/18044#discussion_r460495254) [2](https://github.com/bitcoin/bitcoin/pull/18044#discussion_r460496023) [3](https://github.com/bitcoin/bitcoin/pull/18044#discussion_r463532611) thanks to jnewbery & adamjonas for flagging these ! ! ACKs for top commit: sdaftuar: utACKa8a64acaf3naumenkogs: utACKa8a64acaf3jnewbery: utACKa8a64acaf3Tree-SHA512: 7be669cb30cc17fb9e06b50e636ef7887c6a27354697987e4e4d38dba4b8f50e175647587430cd9bc3295bec01ce8b1e6639a50a4249d8fff9b1ca1b9ead3277
This commit is contained in:
@@ -5123,7 +5123,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();
|
||||
@@ -5131,13 +5131,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());
|
||||
@@ -5154,7 +5151,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