Reduce inefficiency of GetAccountAddress()

Don't scan the wallet to see if the current key has been used if we're going to make a new key anyway.
Stop scanning the wallet as soon as we see that the current key has been used.
Don't call isValid() twice on the current key.
This commit is contained in:
Chris Moore 2015-12-28 16:56:53 -08:00
parent be9a9a3d22
commit 2409865e14

View File

@ -137,26 +137,25 @@ CBitcoinAddress GetAccountAddress(string strAccount, bool bForceNew=false)
CAccount account; CAccount account;
walletdb.ReadAccount(strAccount, account); walletdb.ReadAccount(strAccount, account);
bool bKeyUsed = false; if (!bForceNew) {
if (!account.vchPubKey.IsValid())
// Check if the current key has been used bForceNew = true;
if (account.vchPubKey.IsValid()) else {
{ // Check if the current key has been used
CScript scriptPubKey = GetScriptForDestination(account.vchPubKey.GetID()); CScript scriptPubKey = GetScriptForDestination(account.vchPubKey.GetID());
for (map<uint256, CWalletTx>::iterator it = pwalletMain->mapWallet.begin(); for (map<uint256, CWalletTx>::iterator it = pwalletMain->mapWallet.begin();
it != pwalletMain->mapWallet.end() && account.vchPubKey.IsValid(); it != pwalletMain->mapWallet.end() && account.vchPubKey.IsValid();
++it) ++it)
{ BOOST_FOREACH(const CTxOut& txout, (*it).second.vout)
const CWalletTx& wtx = (*it).second; if (txout.scriptPubKey == scriptPubKey) {
BOOST_FOREACH(const CTxOut& txout, wtx.vout) bForceNew = true;
if (txout.scriptPubKey == scriptPubKey) break;
bKeyUsed = true; }
} }
} }
// Generate a new key // Generate a new key
if (!account.vchPubKey.IsValid() || bForceNew || bKeyUsed) if (bForceNew) {
{
if (!pwalletMain->GetKeyFromPool(account.vchPubKey)) if (!pwalletMain->GetKeyFromPool(account.vchPubKey))
throw JSONRPCError(RPC_WALLET_KEYPOOL_RAN_OUT, "Error: Keypool ran out, please call keypoolrefill first"); throw JSONRPCError(RPC_WALLET_KEYPOOL_RAN_OUT, "Error: Keypool ran out, please call keypoolrefill first");