mirror of
https://github.com/bitcoin/bitcoin.git
synced 2025-01-26 19:23:26 -03:00
Fix for small change outputs
With the separation of CENT and MIN_TX_FEE, it is now reasonable to create change outputs between 0.01 and 0.0005, as these are spendable according to the policy, even though they require a fee to be paid. Also, when enough fee was already present, everything can go into a change output, without further increasing the fee.
This commit is contained in:
parent
c2da35319d
commit
a7dd11c6da
1 changed files with 11 additions and 3 deletions
|
@ -941,9 +941,17 @@ bool CWallet::CreateTransaction(const vector<pair<CScript, int64> >& vecSend, CW
|
||||||
dPriority += (double)nCredit * pcoin.first->GetDepthInMainChain();
|
dPriority += (double)nCredit * pcoin.first->GetDepthInMainChain();
|
||||||
}
|
}
|
||||||
|
|
||||||
// Fill a vout back to self with any change
|
int64 nChange = nValueIn - nValue - nFeeRet;
|
||||||
int64 nChange = nValueIn - nTotalValue;
|
// if sub-cent change is required, the fee must be raised to at least MIN_TX_FEE
|
||||||
if (nChange >= CENT)
|
// or until nChange becomes zero
|
||||||
|
if (nFeeRet < MIN_TX_FEE && nChange > 0 && nChange < CENT)
|
||||||
|
{
|
||||||
|
int64 nMoveToFee = min(nChange, MIN_TX_FEE - nFeeRet);
|
||||||
|
nChange -= nMoveToFee;
|
||||||
|
nFeeRet += nMoveToFee;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (nChange > 0)
|
||||||
{
|
{
|
||||||
// Note: We use a new key here to keep it from being obvious which side is the change.
|
// Note: We use a new key here to keep it from being obvious which side is the change.
|
||||||
// The drawback is that by not reusing a previous key, the change may be lost if a
|
// The drawback is that by not reusing a previous key, the change may be lost if a
|
||||||
|
|
Loading…
Add table
Reference in a new issue