mirror of
https://github.com/kvazar-network/kevacoin.git
synced 2025-01-11 23:58:18 +00:00
Bugfix: do not keep relaying spent wallet transactions
The original test (checking whether the transaction occurs in the txindex) is not usable anymore, as it will miss anything already fully spent. However, as merkle transactions (and by extension, wallet transactions) track which block they were last seen being included in, we can use that to determine the need for rebroadcasting.
This commit is contained in:
parent
41db7c224a
commit
5eaf91a428
@ -820,21 +820,17 @@ void CWallet::ReacceptWalletTransactions()
|
|||||||
|
|
||||||
void CWalletTx::RelayWalletTransaction()
|
void CWalletTx::RelayWalletTransaction()
|
||||||
{
|
{
|
||||||
CCoinsViewCache& coins = *pcoinsTip;
|
|
||||||
BOOST_FOREACH(const CMerkleTx& tx, vtxPrev)
|
BOOST_FOREACH(const CMerkleTx& tx, vtxPrev)
|
||||||
{
|
{
|
||||||
if (!tx.IsCoinBase())
|
if (!tx.IsCoinBase()) {
|
||||||
{
|
if (tx.GetDepthInMainChain() == 0)
|
||||||
uint256 hash = tx.GetHash();
|
RelayMessage(CInv(MSG_TX, tx.GetHash()), (CTransaction)tx);
|
||||||
if (!coins.HaveCoins(hash))
|
|
||||||
RelayMessage(CInv(MSG_TX, hash), (CTransaction)tx);
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
if (!IsCoinBase())
|
if (!IsCoinBase())
|
||||||
{
|
{
|
||||||
uint256 hash = GetHash();
|
if (GetDepthInMainChain() == 0) {
|
||||||
if (!coins.HaveCoins(hash))
|
uint256 hash = GetHash();
|
||||||
{
|
|
||||||
printf("Relaying wtx %s\n", hash.ToString().substr(0,10).c_str());
|
printf("Relaying wtx %s\n", hash.ToString().substr(0,10).c_str());
|
||||||
RelayMessage(CInv(MSG_TX, hash), (CTransaction)*this);
|
RelayMessage(CInv(MSG_TX, hash), (CTransaction)*this);
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user