From: svost Date: Fri, 23 Sep 2016 10:33:27 +0000 (+0300) Subject: Fix listaddressgroupings comand X-Git-Tag: nvc-v0.5.9~148^2 X-Git-Url: https://git.novaco.in/?p=novacoin.git;a=commitdiff_plain;h=refs%2Fpull%2F351%2Fhead Fix listaddressgroupings comand --- diff --git a/src/wallet.cpp b/src/wallet.cpp index e72c138..044f3e2 100644 --- a/src/wallet.cpp +++ b/src/wallet.cpp @@ -2885,29 +2885,38 @@ set< set > CWallet::GetAddressGroupings() { CWalletTx *pcoin = &walletEntry.second; - if (pcoin->vin.size() > 0 && IsMine(pcoin->vin[0])) + if (pcoin->vin.size() > 0) { + bool any_mine = false; // group all input addresses with each other BOOST_FOREACH(CTxIn txin, pcoin->vin) { CBitcoinAddress address; + if(!IsMine(txin)) // If this input isn't mine, ignore it + continue; if(!ExtractAddress(*this, mapWallet[txin.prevout.hash].vout[txin.prevout.n].scriptPubKey, address)) continue; grouping.insert(address); + any_mine = true; } // group change with input addresses - BOOST_FOREACH(CTxOut txout, pcoin->vout) + if (any_mine) + { + BOOST_FOREACH(CTxOut txout, pcoin->vout) if (IsChange(txout)) { - CWalletTx tx = mapWallet[pcoin->vin[0].prevout.hash]; CBitcoinAddress txoutAddr; if(!ExtractAddress(*this, txout.scriptPubKey, txoutAddr)) continue; - grouping.insert(txoutAddr); + grouping.insert(txoutAddr); } - groupings.insert(grouping); - grouping.clear(); + } + if (!grouping.empty()) + { + groupings.insert(grouping); + grouping.clear(); + } } // group lone addrs by themselves