Browse Source

Merge pull request #2541 from luke-jr/bugfix_wallet_resend

Bugfix: Store last/next wallet resend times unique per CWallet object
0.10
Pieter Wuille 11 years ago
parent
commit
4bb77b4963
  1. 12
      src/wallet.cpp
  2. 3
      src/wallet.h

12
src/wallet.cpp

@ -892,19 +892,17 @@ void CWallet::ResendWalletTransactions() @@ -892,19 +892,17 @@ void CWallet::ResendWalletTransactions()
{
// Do this infrequently and randomly to avoid giving away
// that these are our transactions.
static int64 nNextTime;
if (GetTime() < nNextTime)
if (GetTime() < nNextResend)
return;
bool fFirst = (nNextTime == 0);
nNextTime = GetTime() + GetRand(30 * 60);
bool fFirst = (nNextResend == 0);
nNextResend = GetTime() + GetRand(30 * 60);
if (fFirst)
return;
// Only do it if there's been a new block since last time
static int64 nLastTime;
if (nTimeBestReceived < nLastTime)
if (nTimeBestReceived < nLastResend)
return;
nLastTime = GetTime();
nLastResend = GetTime();
// Rebroadcast any of our txes that aren't in a block yet
printf("ResendWalletTransactions()\n");

3
src/wallet.h

@ -80,6 +80,9 @@ private: @@ -80,6 +80,9 @@ private:
// the maximum wallet format version: memory-only variable that specifies to what version this wallet may be upgraded
int nWalletMaxVersion;
int64 nNextResend;
int64 nLastResend;
public:
mutable CCriticalSection cs_wallet;

Loading…
Cancel
Save