Browse Source

fix listunspent, add method wallet.get_unspent_coins

283
thomasv 12 years ago
parent
commit
2642fa0f7d
  1. 3
      electrum
  2. 43
      lib/wallet.py

3
electrum

@ -792,8 +792,7 @@ if __name__ == '__main__':
elif cmd == 'listunspent': elif cmd == 'listunspent':
unspent = map(lambda x: {"txid":x[0].split(':')[0],"vout":x[0].split(':')[1],"amount":x[1]*1.e-8}, wallet.prevout_values.items() ) print_json(wallet.get_unspent_coins())
print_json(unspent)
if cmd not in offline_commands and not options.offline: if cmd not in offline_commands and not options.offline:

43
lib/wallet.py

@ -465,20 +465,9 @@ class Wallet:
return conf, unconf return conf, unconf
def choose_tx_inputs( self, amount, fixed_fee, from_addr = None ): def get_unspent_coins(self, domain=None):
""" todo: minimize tx size """
total = 0
fee = self.fee if fixed_fee is None else fixed_fee
coins = [] coins = []
prioritized_coins = [] if domain is None: domain = self.all_addresses()
domain = [from_addr] if from_addr else self.all_addresses()
for i in self.frozen_addresses:
if i in domain: domain.remove(i)
for i in self.prioritized_addresses:
if i in domain: domain.remove(i)
for addr in domain: for addr in domain:
h = self.history.get(addr, []) h = self.history.get(addr, [])
if h == ['*']: continue if h == ['*']: continue
@ -490,20 +479,26 @@ class Wallet:
if key in self.spent_outputs: continue if key in self.spent_outputs: continue
output['tx_hash'] = tx_hash output['tx_hash'] = tx_hash
coins.append(output) coins.append(output)
return coins
for addr in self.prioritized_addresses:
h = self.history.get(addr, [])
if h == ['*']: continue
for tx_hash, tx_height in h:
tx = self.transactions.get(tx_hash)
for output in tx.d.get('outputs'):
if output.get('address') != addr: continue
key = tx_hash + ":%d" % output.get('index')
if key in self.spent_outputs: continue
output['tx_hash'] = tx_hash
prioritized_coins.append(output)
def choose_tx_inputs( self, amount, fixed_fee, from_addr = None ):
""" todo: minimize tx size """
total = 0
fee = self.fee if fixed_fee is None else fixed_fee
coins = []
prioritized_coins = []
domain = [from_addr] if from_addr else self.all_addresses()
for i in self.frozen_addresses:
if i in domain: domain.remove(i)
for i in self.prioritized_addresses:
if i in domain: domain.remove(i)
coins = self.get_unspent_coins(domain)
prioritized_coins = self.get_unspent_coins(self.prioritized_addresses)
inputs = [] inputs = []
coins = prioritized_coins + coins coins = prioritized_coins + coins

Loading…
Cancel
Save