Browse Source

remove dust output when bumping fee

283
ThomasV 8 years ago
parent
commit
15546d817c
  1. 21
      lib/wallet.py

21
lib/wallet.py

@ -804,6 +804,10 @@ class Abstract_Wallet(PrintError):
f = self.network.relay_fee if self.network and self.network.relay_fee else RELAY_FEE f = self.network.relay_fee if self.network and self.network.relay_fee else RELAY_FEE
return min(f, MAX_RELAY_FEE) return min(f, MAX_RELAY_FEE)
def dust_threshold(self):
# Change <= dust threshold is added to the tx fee
return 182 * 3 * self.relayfee() / 1000
def get_tx_fee(self, tx): def get_tx_fee(self, tx):
# this method can be overloaded # this method can be overloaded
return tx.get_fee() return tx.get_fee()
@ -844,14 +848,11 @@ class Abstract_Wallet(PrintError):
else: else:
fee_estimator = lambda size: fixed_fee fee_estimator = lambda size: fixed_fee
# Change <= dust threshold is added to the tx fee
dust_threshold = 182 * 3 * self.relayfee() / 1000
# Let the coin chooser select the coins to spend # Let the coin chooser select the coins to spend
max_change = self.max_change_outputs if self.multiple_change else 1 max_change = self.max_change_outputs if self.multiple_change else 1
coin_chooser = coinchooser.get_coin_chooser(config) coin_chooser = coinchooser.get_coin_chooser(config)
tx = coin_chooser.make_tx(coins, outputs, change_addrs[:max_change], tx = coin_chooser.make_tx(coins, outputs, change_addrs[:max_change],
fee_estimator, dust_threshold) fee_estimator, self.dust_threshold())
# Sort the inputs and outputs deterministically # Sort the inputs and outputs deterministically
tx.BIP_LI01_sort() tx.BIP_LI01_sort()
@ -1008,7 +1009,7 @@ class Abstract_Wallet(PrintError):
def bump_fee(self, tx, delta): def bump_fee(self, tx, delta):
if tx.is_final(): if tx.is_final():
raise BaseException("cannot bump fee: transaction is final") raise BaseException(_("Cannot bump fee: transaction is final"))
inputs = copy.deepcopy(tx.inputs()) inputs = copy.deepcopy(tx.inputs())
outputs = copy.deepcopy(tx.outputs()) outputs = copy.deepcopy(tx.outputs())
for txin in inputs: for txin in inputs:
@ -1017,12 +1018,14 @@ class Abstract_Wallet(PrintError):
for i, o in enumerate(outputs): for i, o in enumerate(outputs):
otype, address, value = o otype, address, value = o
if self.is_mine(address) and value >= delta: if self.is_mine(address) and value >= delta:
outputs[i] = otype, address, value - delta if value - delta >= self.dust_threshold():
outputs[i] = otype, address, value - delta
else:
del outputs[i]
break break
else: else:
raise BaseException("cannot bump fee: could not find a change output") raise BaseException(_("Cannot bump fee: could not find a change output"))
new_tx = Transaction.from_io(inputs, outputs) return Transaction.from_io(inputs, outputs)
return new_tx
def add_input_info(self, txin): def add_input_info(self, txin):
# Add address for utxo that are in wallet # Add address for utxo that are in wallet

Loading…
Cancel
Save