URI: 
       tupdates for ledger plugin - electrum - Electrum Bitcoin wallet
  HTML git clone https://git.parazyd.org/electrum
   DIR Log
   DIR Files
   DIR Refs
   DIR Submodules
       ---
   DIR commit f9e948ebc10ff031dd6cc493ee2ea2ecbddbf34c
   DIR parent 1763b5fcdc3266b496b2ca125a9d984d7f086d14
  HTML Author: ThomasV <thomasv@electrum.org>
       Date:   Thu,  2 Mar 2017 08:38:06 +0100
       
       updates for ledger plugin
       
       Diffstat:
         M plugins/ledger/ledger.py            |      11 ++++++-----
       
       1 file changed, 6 insertions(+), 5 deletions(-)
       ---
   DIR diff --git a/plugins/ledger/ledger.py b/plugins/ledger/ledger.py
       t@@ -278,10 +278,11 @@ class Ledger_KeyStore(Hardware_KeyStore):
                    if txin.get('is_coinbase'):
                        self.give_error("Coinbase not supported")     # should never happen
        
       -            if len(txin['pubkeys']) > 1:
       +            if txin['type'] in ['p2sh']:
                        p2shTransaction = True
        
       -            for i, x_pubkey in enumerate(txin['x_pubkeys']):
       +            pubkeys, x_pubkeys = tx.get_sorted_pubkeys(txin)
       +            for i, x_pubkey in enumerate(x_pubkeys):
                        if x_pubkey in derivations:
                            signingPos = i
                            s = derivations.get(x_pubkey)
       t@@ -292,12 +293,12 @@ class Ledger_KeyStore(Hardware_KeyStore):
        
                    inputs.append([txin['prev_tx'].raw, txin['prevout_n'], txin.get('redeemScript'), txin['prevout_hash'], signingPos ])
                    inputsPaths.append(hwAddress)
       -            pubKeys.append(txin['pubkeys'])
       +            pubKeys.append(pubkeys)
        
                # Sanity check
                if p2shTransaction:
       -            for txinput in tx.inputs():
       -                if len(txinput['pubkeys']) < 2:
       +            for txin in tx.inputs():
       +                if txin['type'] != 'p2sh':
                            self.give_error("P2SH / regular input mixed in same transaction not supported") # should never happen
        
                txOutput = var_int(len(tx.outputs()))