Merge commit '293f264' into 0.6.0.x
authorLuke Dashjr <luke-jr+git@utopios.org>
Mon, 7 May 2012 04:00:26 +0000 (04:00 +0000)
committerLuke Dashjr <luke-jr+git@utopios.org>
Mon, 7 May 2012 04:00:26 +0000 (04:00 +0000)
src/qt/bitcoin.cpp
src/qt/walletmodel.cpp

index c7f0092..9fea2c1 100644 (file)
@@ -287,6 +287,7 @@ int main(int argc, char *argv[])
 #endif
                 app.exec();
 
+                window.hide();
                 guiref = 0;
             }
             Shutdown(NULL);
index 8344a65..0a085f5 100644 (file)
@@ -153,14 +153,20 @@ WalletModel::SendCoinsReturn WalletModel::sendCoins(const QList<SendCoinsRecipie
         hex = QString::fromStdString(wtx.GetHash().GetHex());
     }
 
-    // Add addresses that we've sent to to the address book
+    // Add addresses / update labels that we've sent to to the address book
     foreach(const SendCoinsRecipient &rcp, recipients)
     {
         std::string strAddress = rcp.address.toStdString();
+        std::string strLabel = rcp.label.toStdString();
         CRITICAL_BLOCK(wallet->cs_wallet)
         {
-            if (!wallet->mapAddressBook.count(strAddress))
-                wallet->SetAddressBookName(strAddress, rcp.label.toStdString());
+            std::map<CBitcoinAddress, std::string>::iterator mi = wallet->mapAddressBook.find(strAddress);
+
+            // Check if we have a new address or an updated label
+            if (mi == wallet->mapAddressBook.end() || mi->second != strLabel)
+            {
+                wallet->SetAddressBookName(strAddress, strLabel);
+            }
         }
     }