mirror of
https://github.com/bitcoin/bitcoin.git
synced 2025-01-10 11:57:28 -03:00
Remove SyncTransaction for conflicted txn in CWallet::BlockConnected
We shouldn't rely on this sync call to get an accurate view of txn state, if a tx conflicts with one in mapTx we are going to update our wallet dependencies in AddToWalletIfInvolvingMe while conflicting txn get connected. If it doesn't conflict with one of our dependencies we are not going to track it anyway. This is a cleanup, as this SyncTransaction is redundant with the following one for confirmation which is triggering the MarkConflicted logic. We keep the loop because set of conflicted txn isn't same as txn included in block.
This commit is contained in:
parent
a31be09bfd
commit
7e89994133
1 changed files with 3 additions and 11 deletions
|
@ -1410,22 +1410,14 @@ void CWallet::BlockConnected(const CBlock& block, const std::vector<CTransaction
|
||||||
const uint256& block_hash = block.GetHash();
|
const uint256& block_hash = block.GetHash();
|
||||||
auto locked_chain = chain().lock();
|
auto locked_chain = chain().lock();
|
||||||
LOCK(cs_wallet);
|
LOCK(cs_wallet);
|
||||||
// TODO: Temporarily ensure that mempool removals are notified before
|
|
||||||
// connected transactions. This shouldn't matter, but the abandoned
|
|
||||||
// state of transactions in our wallet is currently cleared when we
|
|
||||||
// receive another notification and there is a race condition where
|
|
||||||
// notification of a connected conflict might cause an outside process
|
|
||||||
// to abandon a transaction and then have it inadvertently cleared by
|
|
||||||
// the notification that the conflicted transaction was evicted.
|
|
||||||
|
|
||||||
for (const CTransactionRef& ptx : vtxConflicted) {
|
|
||||||
SyncTransaction(ptx, CWalletTx::Status::CONFLICTED, {} /* block hash */, 0 /* position in block */);
|
|
||||||
TransactionRemovedFromMempool(ptx);
|
|
||||||
}
|
|
||||||
for (size_t i = 0; i < block.vtx.size(); i++) {
|
for (size_t i = 0; i < block.vtx.size(); i++) {
|
||||||
SyncTransaction(block.vtx[i], CWalletTx::Status::CONFIRMED, block_hash, i);
|
SyncTransaction(block.vtx[i], CWalletTx::Status::CONFIRMED, block_hash, i);
|
||||||
TransactionRemovedFromMempool(block.vtx[i]);
|
TransactionRemovedFromMempool(block.vtx[i]);
|
||||||
}
|
}
|
||||||
|
for (const CTransactionRef& ptx : vtxConflicted) {
|
||||||
|
TransactionRemovedFromMempool(ptx);
|
||||||
|
}
|
||||||
|
|
||||||
m_last_block_processed = block_hash;
|
m_last_block_processed = block_hash;
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue