|
|
|
// Copyright (c) 2009-2010 Satoshi Nakamoto
|
|
|
|
// Copyright (c) 2009-2014 The Bitcoin Core developers
|
|
|
|
// Distributed under the MIT software license, see the accompanying
|
|
|
|
// file COPYING or http://www.opensource.org/licenses/mit-license.php.
|
|
|
|
|
|
|
|
#ifndef BITCOIN_CHAINPARAMS_H
|
|
|
|
#define BITCOIN_CHAINPARAMS_H
|
|
|
|
|
|
|
|
#include "chainparamsbase.h"
|
|
|
|
#include "checkpoints.h"
|
|
|
|
#include "consensus/params.h"
|
|
|
|
#include "primitives/block.h"
|
|
|
|
#include "protocol.h"
|
|
|
|
|
|
|
|
#include <vector>
|
|
|
|
|
|
|
|
struct CDNSSeedData {
|
|
|
|
std::string name, host;
|
|
|
|
CDNSSeedData(const std::string &strName, const std::string &strHost) : name(strName), host(strHost) {}
|
|
|
|
};
|
|
|
|
|
|
|
|
struct SeedSpec6 {
|
|
|
|
uint8_t addr[16];
|
|
|
|
uint16_t port;
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
* CChainParams defines various tweakable parameters of a given instance of the
|
|
|
|
* Bitcoin system. There are three: the main network on which people trade goods
|
|
|
|
* and services, the public test network which gets reset from time to time and
|
|
|
|
* a regression test mode which is intended for private networks only. It has
|
|
|
|
* minimal difficulty to ensure that blocks can be found instantly.
|
|
|
|
*/
|
|
|
|
class CChainParams
|
|
|
|
{
|
|
|
|
public:
|
|
|
|
enum Base58Type {
|
|
|
|
PUBKEY_ADDRESS,
|
|
|
|
SCRIPT_ADDRESS,
|
|
|
|
SECRET_KEY,
|
|
|
|
EXT_PUBLIC_KEY,
|
|
|
|
EXT_SECRET_KEY,
|
|
|
|
|
|
|
|
MAX_BASE58_TYPES
|
|
|
|
};
|
|
|
|
|
|
|
|
const Consensus::Params& GetConsensus() const { return consensus; }
|
|
|
|
const CMessageHeader::MessageStartChars& MessageStart() const { return pchMessageStart; }
|
|
|
|
const std::vector<unsigned char>& AlertKey() const { return vAlertPubKey; }
|
|
|
|
int GetDefaultPort() const { return nDefaultPort; }
|
|
|
|
int SubsidyHalvingInterval() const { return consensus.nSubsidyHalvingInterval; }
|
|
|
|
int EnforceBlockUpgradeMajority() const { return consensus.nMajorityEnforceBlockUpgrade; }
|
|
|
|
int RejectBlockOutdatedMajority() const { return consensus.nMajorityRejectBlockOutdated; }
|
|
|
|
int ToCheckBlockUpgradeMajority() const { return consensus.nMajorityWindow; }
|
|
|
|
|
|
|
|
/** Used if GenerateBitcoins is called with a negative number of threads */
|
|
|
|
int DefaultMinerThreads() const { return nMinerThreads; }
|
|
|
|
const CBlock& GenesisBlock() const { return genesis; }
|
|
|
|
bool RequireRPCPassword() const { return fRequireRPCPassword; }
|
|
|
|
/** Make miner wait to have peers to avoid wasting work */
|
|
|
|
bool MiningRequiresPeers() const { return fMiningRequiresPeers; }
|
|
|
|
/** Default value for -checkmempool and -checkblockindex argument */
|
|
|
|
bool DefaultConsistencyChecks() const { return fDefaultConsistencyChecks; }
|
|
|
|
/** Make standard checks */
|
|
|
|
bool RequireStandard() const { return fRequireStandard; }
|
Add block pruning functionality
This adds a -prune=N option to bitcoind, which if set to N>0 will enable block
file pruning. When pruning is enabled, block and undo files will be deleted to
try to keep total space used by those files to below the prune target (N, in
MB) specified by the user, subject to some constraints:
- The last 288 blocks on the main chain are always kept (MIN_BLOCKS_TO_KEEP),
- N must be at least 550MB (chosen as a value for the target that could
reasonably be met, with some assumptions about block sizes, orphan rates,
etc; see comment in main.h),
- No blocks are pruned until chainActive is at least 100,000 blocks long (on
mainnet; defined separately for mainnet, testnet, and regtest in chainparams
as nPruneAfterHeight).
This unsets NODE_NETWORK if pruning is enabled.
Also included is an RPC test for pruning (pruning.py).
Thanks to @rdponticelli for earlier work on this feature; this is based in
part off that work.
10 years ago
|
|
|
int64_t PruneAfterHeight() const { return nPruneAfterHeight; }
|
|
|
|
/** Make miner stop after a block is found. In RPC, don't return until nGenProcLimit blocks are generated */
|
|
|
|
bool MineBlocksOnDemand() const { return fMineBlocksOnDemand; }
|
|
|
|
/** In the future use NetworkIDString() for RPC fields */
|
|
|
|
bool TestnetToBeDeprecatedFieldRPC() const { return fTestnetToBeDeprecatedFieldRPC; }
|
|
|
|
/** Return the BIP70 network string (main, test or regtest) */
|
|
|
|
std::string NetworkIDString() const { return strNetworkID; }
|
|
|
|
const std::vector<CDNSSeedData>& DNSSeeds() const { return vSeeds; }
|
|
|
|
const std::vector<unsigned char>& Base58Prefix(Base58Type type) const { return base58Prefixes[type]; }
|
|
|
|
const std::vector<SeedSpec6>& FixedSeeds() const { return vFixedSeeds; }
|
|
|
|
virtual const Checkpoints::CCheckpointData& Checkpoints() const = 0;
|
|
|
|
protected:
|
|
|
|
CChainParams() {}
|
|
|
|
|
|
|
|
Consensus::Params consensus;
|
|
|
|
CMessageHeader::MessageStartChars pchMessageStart;
|
|
|
|
//! Raw pub key bytes for the broadcast alert signing key.
|
|
|
|
std::vector<unsigned char> vAlertPubKey;
|
|
|
|
int nDefaultPort;
|
|
|
|
int nMinerThreads;
|
Add block pruning functionality
This adds a -prune=N option to bitcoind, which if set to N>0 will enable block
file pruning. When pruning is enabled, block and undo files will be deleted to
try to keep total space used by those files to below the prune target (N, in
MB) specified by the user, subject to some constraints:
- The last 288 blocks on the main chain are always kept (MIN_BLOCKS_TO_KEEP),
- N must be at least 550MB (chosen as a value for the target that could
reasonably be met, with some assumptions about block sizes, orphan rates,
etc; see comment in main.h),
- No blocks are pruned until chainActive is at least 100,000 blocks long (on
mainnet; defined separately for mainnet, testnet, and regtest in chainparams
as nPruneAfterHeight).
This unsets NODE_NETWORK if pruning is enabled.
Also included is an RPC test for pruning (pruning.py).
Thanks to @rdponticelli for earlier work on this feature; this is based in
part off that work.
10 years ago
|
|
|
uint64_t nPruneAfterHeight;
|
|
|
|
std::vector<CDNSSeedData> vSeeds;
|
|
|
|
std::vector<unsigned char> base58Prefixes[MAX_BASE58_TYPES];
|
|
|
|
std::string strNetworkID;
|
|
|
|
CBlock genesis;
|
|
|
|
std::vector<SeedSpec6> vFixedSeeds;
|
|
|
|
bool fRequireRPCPassword;
|
|
|
|
bool fMiningRequiresPeers;
|
|
|
|
bool fDefaultConsistencyChecks;
|
|
|
|
bool fRequireStandard;
|
|
|
|
bool fMineBlocksOnDemand;
|
|
|
|
bool fTestnetToBeDeprecatedFieldRPC;
|
|
|
|
};
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Return the currently selected parameters. This won't change after app startup
|
|
|
|
* outside of the unit tests.
|
|
|
|
*/
|
|
|
|
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. */
|
|
|
|
void SelectParams(CBaseChainParams::Network network);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Looks for -regtest or -testnet and then calls SelectParams as appropriate.
|
|
|
|
* Returns false if an invalid combination is given.
|
|
|
|
*/
|
|
|
|
bool SelectParamsFromCommandLine();
|
|
|
|
|
|
|
|
#endif // BITCOIN_CHAINPARAMS_H
|