mirror of
https://github.com/bitcoin/bitcoin.git
synced 2025-01-10 11:57:28 -03:00
4f74c59334
There are no changes to behavior. Changes in this commit are all additions, and are easiest to review using "git diff -U0 --word-diff-regex=." options. Motivation for this change is to keep util functions with really generic names like "Split" and "Join" out of the global namespace so it is easier to see where these functions are defined, and so they don't interfere with function overloading, especially since the util library is a dependency of the kernel library and intended to be used with external code.
136 lines
5.1 KiB
C++
136 lines
5.1 KiB
C++
// Copyright (c) 2010 Satoshi Nakamoto
|
|
// Copyright (c) 2009-2022 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 <chainparams.h>
|
|
|
|
#include <chainparamsbase.h>
|
|
#include <common/args.h>
|
|
#include <consensus/params.h>
|
|
#include <deploymentinfo.h>
|
|
#include <logging.h>
|
|
#include <tinyformat.h>
|
|
#include <util/chaintype.h>
|
|
#include <util/strencodings.h>
|
|
#include <util/string.h>
|
|
|
|
#include <cassert>
|
|
#include <cstdint>
|
|
#include <limits>
|
|
#include <stdexcept>
|
|
#include <vector>
|
|
|
|
using util::SplitString;
|
|
|
|
void ReadSigNetArgs(const ArgsManager& args, CChainParams::SigNetOptions& options)
|
|
{
|
|
if (args.IsArgSet("-signetseednode")) {
|
|
options.seeds.emplace(args.GetArgs("-signetseednode"));
|
|
}
|
|
if (args.IsArgSet("-signetchallenge")) {
|
|
const auto signet_challenge = args.GetArgs("-signetchallenge");
|
|
if (signet_challenge.size() != 1) {
|
|
throw std::runtime_error("-signetchallenge cannot be multiple values.");
|
|
}
|
|
const auto val{TryParseHex<uint8_t>(signet_challenge[0])};
|
|
if (!val) {
|
|
throw std::runtime_error(strprintf("-signetchallenge must be hex, not '%s'.", signet_challenge[0]));
|
|
}
|
|
options.challenge.emplace(*val);
|
|
}
|
|
}
|
|
|
|
void ReadRegTestArgs(const ArgsManager& args, CChainParams::RegTestOptions& options)
|
|
{
|
|
if (auto value = args.GetBoolArg("-fastprune")) options.fastprune = *value;
|
|
|
|
for (const std::string& arg : args.GetArgs("-testactivationheight")) {
|
|
const auto found{arg.find('@')};
|
|
if (found == std::string::npos) {
|
|
throw std::runtime_error(strprintf("Invalid format (%s) for -testactivationheight=name@height.", arg));
|
|
}
|
|
|
|
const auto value{arg.substr(found + 1)};
|
|
int32_t height;
|
|
if (!ParseInt32(value, &height) || height < 0 || height >= std::numeric_limits<int>::max()) {
|
|
throw std::runtime_error(strprintf("Invalid height value (%s) for -testactivationheight=name@height.", arg));
|
|
}
|
|
|
|
const auto deployment_name{arg.substr(0, found)};
|
|
if (const auto buried_deployment = GetBuriedDeployment(deployment_name)) {
|
|
options.activation_heights[*buried_deployment] = height;
|
|
} else {
|
|
throw std::runtime_error(strprintf("Invalid name (%s) for -testactivationheight=name@height.", arg));
|
|
}
|
|
}
|
|
|
|
if (!args.IsArgSet("-vbparams")) return;
|
|
|
|
for (const std::string& strDeployment : args.GetArgs("-vbparams")) {
|
|
std::vector<std::string> vDeploymentParams = SplitString(strDeployment, ':');
|
|
if (vDeploymentParams.size() < 3 || 4 < vDeploymentParams.size()) {
|
|
throw std::runtime_error("Version bits parameters malformed, expecting deployment:start:end[:min_activation_height]");
|
|
}
|
|
CChainParams::VersionBitsParameters vbparams{};
|
|
if (!ParseInt64(vDeploymentParams[1], &vbparams.start_time)) {
|
|
throw std::runtime_error(strprintf("Invalid nStartTime (%s)", vDeploymentParams[1]));
|
|
}
|
|
if (!ParseInt64(vDeploymentParams[2], &vbparams.timeout)) {
|
|
throw std::runtime_error(strprintf("Invalid nTimeout (%s)", vDeploymentParams[2]));
|
|
}
|
|
if (vDeploymentParams.size() >= 4) {
|
|
if (!ParseInt32(vDeploymentParams[3], &vbparams.min_activation_height)) {
|
|
throw std::runtime_error(strprintf("Invalid min_activation_height (%s)", vDeploymentParams[3]));
|
|
}
|
|
} else {
|
|
vbparams.min_activation_height = 0;
|
|
}
|
|
bool found = false;
|
|
for (int j=0; j < (int)Consensus::MAX_VERSION_BITS_DEPLOYMENTS; ++j) {
|
|
if (vDeploymentParams[0] == VersionBitsDeploymentInfo[j].name) {
|
|
options.version_bits_parameters[Consensus::DeploymentPos(j)] = vbparams;
|
|
found = true;
|
|
LogPrintf("Setting version bits activation parameters for %s to start=%ld, timeout=%ld, min_activation_height=%d\n", vDeploymentParams[0], vbparams.start_time, vbparams.timeout, vbparams.min_activation_height);
|
|
break;
|
|
}
|
|
}
|
|
if (!found) {
|
|
throw std::runtime_error(strprintf("Invalid deployment (%s)", vDeploymentParams[0]));
|
|
}
|
|
}
|
|
}
|
|
|
|
static std::unique_ptr<const CChainParams> globalChainParams;
|
|
|
|
const CChainParams &Params() {
|
|
assert(globalChainParams);
|
|
return *globalChainParams;
|
|
}
|
|
|
|
std::unique_ptr<const CChainParams> CreateChainParams(const ArgsManager& args, const ChainType chain)
|
|
{
|
|
switch (chain) {
|
|
case ChainType::MAIN:
|
|
return CChainParams::Main();
|
|
case ChainType::TESTNET:
|
|
return CChainParams::TestNet();
|
|
case ChainType::SIGNET: {
|
|
auto opts = CChainParams::SigNetOptions{};
|
|
ReadSigNetArgs(args, opts);
|
|
return CChainParams::SigNet(opts);
|
|
}
|
|
case ChainType::REGTEST: {
|
|
auto opts = CChainParams::RegTestOptions{};
|
|
ReadRegTestArgs(args, opts);
|
|
return CChainParams::RegTest(opts);
|
|
}
|
|
}
|
|
assert(false);
|
|
}
|
|
|
|
void SelectParams(const ChainType chain)
|
|
{
|
|
SelectBaseParams(chain);
|
|
globalChainParams = CreateChainParams(gArgs, chain);
|
|
}
|