9876207ce2
* Add missing help string for -devnet * Remove testnet seeds from devnet * Activate BIP34/65/66 at height 2 instead of 1 Height 1 is the genesis block and not the devnet genesis block. The genesis block is still at version 1, resulting in re-indexing to fail.
149 lines
3.8 KiB
C++
149 lines
3.8 KiB
C++
// Copyright (c) 2010 Satoshi Nakamoto
|
|
// Copyright (c) 2009-2015 The Bitcoin Core developers
|
|
// Distributed under the MIT software license, see the accompanying
|
|
// file COPYING or http://www.opensource.org/licenses/mit-license.php.
|
|
|
|
#include "chainparamsbase.h"
|
|
|
|
#include "tinyformat.h"
|
|
#include "util.h"
|
|
|
|
#include <assert.h>
|
|
|
|
const std::string CBaseChainParams::MAIN = "main";
|
|
const std::string CBaseChainParams::TESTNET = "test";
|
|
const std::string CBaseChainParams::DEVNET = "dev";
|
|
const std::string CBaseChainParams::REGTEST = "regtest";
|
|
|
|
void AppendParamsHelpMessages(std::string& strUsage, bool debugHelp)
|
|
{
|
|
strUsage += HelpMessageGroup(_("Chain selection options:"));
|
|
strUsage += HelpMessageOpt("-testnet", _("Use the test chain"));
|
|
strUsage += HelpMessageOpt("-devnet=<name>", _("Use devnet chain with provided name"));
|
|
if (debugHelp) {
|
|
strUsage += HelpMessageOpt("-regtest", "Enter regression test mode, which uses a special chain in which blocks can be solved instantly. "
|
|
"This is intended for regression testing tools and app development.");
|
|
}
|
|
}
|
|
|
|
/**
|
|
* Main network
|
|
*/
|
|
class CBaseMainParams : public CBaseChainParams
|
|
{
|
|
public:
|
|
CBaseMainParams()
|
|
{
|
|
nRPCPort = 9998;
|
|
}
|
|
};
|
|
static CBaseMainParams mainParams;
|
|
|
|
/**
|
|
* Testnet (v3)
|
|
*/
|
|
class CBaseTestNetParams : public CBaseChainParams
|
|
{
|
|
public:
|
|
CBaseTestNetParams()
|
|
{
|
|
nRPCPort = 19998;
|
|
strDataDir = "testnet3";
|
|
}
|
|
};
|
|
static CBaseTestNetParams testNetParams;
|
|
|
|
/**
|
|
* Devnet
|
|
*/
|
|
class CBaseDevNetParams : public CBaseChainParams
|
|
{
|
|
public:
|
|
CBaseDevNetParams(const std::string &dataDir)
|
|
{
|
|
nRPCPort = 19998;
|
|
strDataDir = dataDir;
|
|
}
|
|
};
|
|
static CBaseDevNetParams *devNetParams;
|
|
|
|
/*
|
|
* Regression test
|
|
*/
|
|
class CBaseRegTestParams : public CBaseChainParams
|
|
{
|
|
public:
|
|
CBaseRegTestParams()
|
|
{
|
|
nRPCPort = 18332;
|
|
strDataDir = "regtest";
|
|
}
|
|
};
|
|
static CBaseRegTestParams regTestParams;
|
|
|
|
static CBaseChainParams* pCurrentBaseParams = 0;
|
|
|
|
const CBaseChainParams& BaseParams()
|
|
{
|
|
assert(pCurrentBaseParams);
|
|
return *pCurrentBaseParams;
|
|
}
|
|
|
|
CBaseChainParams& BaseParams(const std::string& chain)
|
|
{
|
|
if (chain == CBaseChainParams::MAIN)
|
|
return mainParams;
|
|
else if (chain == CBaseChainParams::TESTNET)
|
|
return testNetParams;
|
|
else if (chain == CBaseChainParams::DEVNET) {
|
|
assert(devNetParams);
|
|
return *devNetParams;
|
|
} else if (chain == CBaseChainParams::REGTEST)
|
|
return regTestParams;
|
|
else
|
|
throw std::runtime_error(strprintf("%s: Unknown chain %s.", __func__, chain));
|
|
}
|
|
|
|
void SelectBaseParams(const std::string& chain)
|
|
{
|
|
if (chain == CBaseChainParams::DEVNET) {
|
|
std::string devNetName = GetDevNetName();
|
|
assert(!devNetName.empty());
|
|
devNetParams = new CBaseDevNetParams(devNetName);
|
|
}
|
|
|
|
pCurrentBaseParams = &BaseParams(chain);
|
|
}
|
|
|
|
std::string ChainNameFromCommandLine()
|
|
{
|
|
bool fRegTest = GetBoolArg("-regtest", false);
|
|
bool fDevNet = IsArgSet("-devnet");
|
|
bool fTestNet = GetBoolArg("-testnet", false);
|
|
|
|
int nameParamsCount = (fRegTest ? 1 : 0) + (fDevNet ? 1 : 0) + (fTestNet ? 1 : 0);
|
|
if (nameParamsCount > 1)
|
|
throw std::runtime_error("Only one of -regtest, -testnet or -devnet can be used.");
|
|
|
|
if (fDevNet)
|
|
return CBaseChainParams::DEVNET;
|
|
if (fRegTest)
|
|
return CBaseChainParams::REGTEST;
|
|
if (fTestNet)
|
|
return CBaseChainParams::TESTNET;
|
|
return CBaseChainParams::MAIN;
|
|
}
|
|
|
|
std::string GetDevNetName()
|
|
{
|
|
// This function should never be called for non-devnets
|
|
assert(IsArgSet("-devnet"));
|
|
std::string devNetName = GetArg("-devnet", "");
|
|
return "devnet" + (devNetName.empty() ? "" : "-" + devNetName);
|
|
}
|
|
|
|
bool AreBaseParamsConfigured()
|
|
{
|
|
return pCurrentBaseParams != NULL;
|
|
}
|