Merge pull request #4623

e84843c Broken addresses on command line no longer trigger testnet. (Ross Nicoll)
This commit is contained in:
Wladimir J. van der Laan 2014-09-10 14:29:16 +02:00
commit f23869e14b
No known key found for this signature in database
GPG Key ID: 74810B012346C9A6
5 changed files with 26 additions and 13 deletions

View File

@ -215,9 +215,13 @@ bool CBitcoinAddress::Set(const CTxDestination &dest) {
} }
bool CBitcoinAddress::IsValid() const { bool CBitcoinAddress::IsValid() const {
return IsValid(Params());
}
bool CBitcoinAddress::IsValid(const CChainParams &params) const {
bool fCorrectSize = vchData.size() == 20; bool fCorrectSize = vchData.size() == 20;
bool fKnownVersion = vchVersion == Params().Base58Prefix(CChainParams::PUBKEY_ADDRESS) || bool fKnownVersion = vchVersion == params.Base58Prefix(CChainParams::PUBKEY_ADDRESS) ||
vchVersion == Params().Base58Prefix(CChainParams::SCRIPT_ADDRESS); vchVersion == params.Base58Prefix(CChainParams::SCRIPT_ADDRESS);
return fCorrectSize && fKnownVersion; return fCorrectSize && fKnownVersion;
} }

View File

@ -104,6 +104,7 @@ public:
bool Set(const CScriptID &id); bool Set(const CScriptID &id);
bool Set(const CTxDestination &dest); bool Set(const CTxDestination &dest);
bool IsValid() const; bool IsValid() const;
bool IsValid(const CChainParams &params) const;
CBitcoinAddress() {} CBitcoinAddress() {}
CBitcoinAddress(const CTxDestination &dest) { Set(dest); } CBitcoinAddress(const CTxDestination &dest) { Set(dest); }

View File

@ -221,24 +221,25 @@ const CChainParams &Params() {
return *pCurrentParams; return *pCurrentParams;
} }
void SelectParams(CBaseChainParams::Network network) { CChainParams &Params(CBaseChainParams::Network network) {
SelectBaseParams(network);
switch (network) { switch (network) {
case CBaseChainParams::MAIN: case CBaseChainParams::MAIN:
pCurrentParams = &mainParams; return mainParams;
break;
case CBaseChainParams::TESTNET: case CBaseChainParams::TESTNET:
pCurrentParams = &testNetParams; return testNetParams;
break;
case CBaseChainParams::REGTEST: case CBaseChainParams::REGTEST:
pCurrentParams = &regTestParams; return regTestParams;
break;
default: default:
assert(false && "Unimplemented network"); assert(false && "Unimplemented network");
return; return mainParams;
} }
} }
void SelectParams(CBaseChainParams::Network network) {
SelectBaseParams(network);
pCurrentParams = &Params(network);
}
bool SelectParamsFromCommandLine() { bool SelectParamsFromCommandLine() {
if (!SelectBaseParamsFromCommandLine()) if (!SelectBaseParamsFromCommandLine())
return false; return false;

View File

@ -111,6 +111,9 @@ protected:
*/ */
const CChainParams &Params(); const CChainParams &Params();
/** Return parameters for the given network. */
CChainParams &Params(CBaseChainParams::Network network);
/** Sets the params returned by Params() to those for the given network. */ /** Sets the params returned by Params() to those for the given network. */
void SelectParams(CBaseChainParams::Network network); void SelectParams(CBaseChainParams::Network network);

View File

@ -10,6 +10,7 @@
#include "optionsmodel.h" #include "optionsmodel.h"
#include "base58.h" #include "base58.h"
#include "chainparams.h"
#include "ui_interface.h" #include "ui_interface.h"
#include "util.h" #include "util.h"
#include "wallet.h" #include "wallet.h"
@ -200,8 +201,11 @@ bool PaymentServer::ipcParseCommandLine(int argc, char* argv[])
{ {
CBitcoinAddress address(r.address.toStdString()); CBitcoinAddress address(r.address.toStdString());
SelectParams(CBaseChainParams::MAIN); if (address.IsValid(Params(CBaseChainParams::MAIN)))
if (!address.IsValid()) {
SelectParams(CBaseChainParams::MAIN);
}
else if (address.IsValid(Params(CBaseChainParams::TESTNET)))
{ {
SelectParams(CBaseChainParams::TESTNET); SelectParams(CBaseChainParams::TESTNET);
} }