mirror of
https://github.com/dashpay/dash.git
synced 2024-12-29 05:49:11 +01:00
a9822d4a34
18326ae
[doc] Add comments for chainparams.h, validation.cpp (James O'Beirne)
Pull request description:
Added a few comments during a leisurely read through some of the validation code. If this kind of thing seems useful, I can add similar documentation for most of the `CChainState` interface.
Tree-SHA512: a4d9db60383a8ff02e74ac326ed88902eec1ee441e8cd4e1845bcf257072673c15974225288cebf0a633e76a3410f99e2206616b4694725a2a5b0d19c78327d6
193 lines
7.5 KiB
C++
193 lines
7.5 KiB
C++
// Copyright (c) 2009-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.
|
|
|
|
#ifndef BITCOIN_CHAINPARAMS_H
|
|
#define BITCOIN_CHAINPARAMS_H
|
|
|
|
#include <chainparamsbase.h>
|
|
#include <consensus/params.h>
|
|
#include <primitives/block.h>
|
|
#include <protocol.h>
|
|
|
|
#include <memory>
|
|
#include <vector>
|
|
|
|
struct SeedSpec6 {
|
|
uint8_t addr[16];
|
|
uint16_t port;
|
|
};
|
|
|
|
typedef std::map<int, uint256> MapCheckpoints;
|
|
|
|
struct CCheckpointData {
|
|
MapCheckpoints mapCheckpoints;
|
|
};
|
|
|
|
/**
|
|
* Holds various statistics on transactions within a chain. Used to estimate
|
|
* verification progress during chain sync.
|
|
*
|
|
* See also: CChainParams::TxData, GuessVerificationProgress.
|
|
*/
|
|
struct ChainTxData {
|
|
int64_t nTime;
|
|
int64_t nTxCount;
|
|
double dTxRate;
|
|
};
|
|
|
|
/**
|
|
* CChainParams defines various tweakable parameters of a given instance of the
|
|
* Dash 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, // BIP16
|
|
EXT_PUBLIC_KEY, // BIP32
|
|
EXT_SECRET_KEY, // BIP32
|
|
|
|
MAX_BASE58_TYPES
|
|
};
|
|
|
|
const Consensus::Params& GetConsensus() const { return consensus; }
|
|
const CMessageHeader::MessageStartChars& MessageStart() const { return pchMessageStart; }
|
|
int GetDefaultPort() const { return nDefaultPort; }
|
|
|
|
const CBlock& GenesisBlock() const { return genesis; }
|
|
const CBlock& DevNetGenesisBlock() const { return devnetGenesis; }
|
|
/** Default value for -checkmempool and -checkblockindex argument */
|
|
bool DefaultConsistencyChecks() const { return fDefaultConsistencyChecks; }
|
|
/** Policy: Filter transactions that do not match well-defined patterns */
|
|
bool RequireStandard() const { return fRequireStandard; }
|
|
/** Require addresses specified with "-externalip" parameter to be routable */
|
|
bool RequireRoutableExternalIP() const { return fRequireRoutableExternalIP; }
|
|
uint64_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; }
|
|
/** Allow multiple addresses to be selected from the same network group (e.g. 192.168.x.x) */
|
|
bool AllowMultipleAddressesFromGroup() const { return fAllowMultipleAddressesFromGroup; }
|
|
/** Allow nodes with the same address and multiple ports */
|
|
bool AllowMultiplePorts() const { return fAllowMultiplePorts; }
|
|
/** How long to wait until we allow retrying of a LLMQ connection */
|
|
int LLMQConnectionRetryTimeout() const { return nLLMQConnectionRetryTimeout; }
|
|
/** Return the BIP70 network string (main, test or regtest) */
|
|
std::string NetworkIDString() const { return strNetworkID; }
|
|
/** Return the list of hostnames to look up for DNS seeds */
|
|
const std::vector<std::string>& DNSSeeds() const { return vSeeds; }
|
|
const std::vector<unsigned char>& Base58Prefix(Base58Type type) const { return base58Prefixes[type]; }
|
|
int ExtCoinType() const { return nExtCoinType; }
|
|
const std::vector<SeedSpec6>& FixedSeeds() const { return vFixedSeeds; }
|
|
const CCheckpointData& Checkpoints() const { return checkpointData; }
|
|
const ChainTxData& TxData() const { return chainTxData; }
|
|
void UpdateVersionBitsParameters(Consensus::DeploymentPos d, int64_t nStartTime, int64_t nTimeout, int64_t nWindowSize, int64_t nThreshold);
|
|
void UpdateDIP3Parameters(int nActivationHeight, int nEnforcementHeight);
|
|
void UpdateBudgetParameters(int nMasternodePaymentsStartBlock, int nBudgetPaymentsStartBlock, int nSuperblockStartBlock);
|
|
void UpdateSubsidyAndDiffParams(int nMinimumDifficultyBlocks, int nHighSubsidyBlocks, int nHighSubsidyFactor);
|
|
void UpdateLLMQChainLocks(Consensus::LLMQType llmqType);
|
|
void UpdateLLMQTestParams(int size, int threshold);
|
|
void UpdateLLMQDevnetParams(int size, int threshold);
|
|
int PoolMinParticipants() const { return nPoolMinParticipants; }
|
|
int PoolNewMinParticipants() const { return nPoolNewMinParticipants; }
|
|
int PoolMaxParticipants() const { return nPoolMaxParticipants; }
|
|
int PoolNewMaxParticipants() const { return nPoolNewMaxParticipants; }
|
|
int FulfilledRequestExpireTime() const { return nFulfilledRequestExpireTime; }
|
|
const std::vector<std::string>& SporkAddresses() const { return vSporkAddresses; }
|
|
int MinSporkKeys() const { return nMinSporkKeys; }
|
|
bool BIP9CheckMasternodesUpgraded() const { return fBIP9CheckMasternodesUpgraded; }
|
|
protected:
|
|
CChainParams() {}
|
|
|
|
Consensus::Params consensus;
|
|
CMessageHeader::MessageStartChars pchMessageStart;
|
|
int nDefaultPort;
|
|
uint64_t nPruneAfterHeight;
|
|
std::vector<std::string> vSeeds;
|
|
std::vector<unsigned char> base58Prefixes[MAX_BASE58_TYPES];
|
|
int nExtCoinType;
|
|
std::string strNetworkID;
|
|
CBlock genesis;
|
|
CBlock devnetGenesis;
|
|
std::vector<SeedSpec6> vFixedSeeds;
|
|
bool fDefaultConsistencyChecks;
|
|
bool fRequireStandard;
|
|
bool fRequireRoutableExternalIP;
|
|
bool fMineBlocksOnDemand;
|
|
bool fAllowMultipleAddressesFromGroup;
|
|
bool fAllowMultiplePorts;
|
|
int nLLMQConnectionRetryTimeout;
|
|
CCheckpointData checkpointData;
|
|
ChainTxData chainTxData;
|
|
int nPoolMinParticipants;
|
|
int nPoolNewMinParticipants;
|
|
int nPoolMaxParticipants;
|
|
int nPoolNewMaxParticipants;
|
|
int nFulfilledRequestExpireTime;
|
|
std::vector<std::string> vSporkAddresses;
|
|
int nMinSporkKeys;
|
|
bool fBIP9CheckMasternodesUpgraded;
|
|
};
|
|
|
|
/**
|
|
* Creates and returns a std::unique_ptr<CChainParams> of the chosen chain.
|
|
* @returns a CChainParams* of the chosen chain.
|
|
* @throws a std::runtime_error if the chain is not supported.
|
|
*/
|
|
std::unique_ptr<CChainParams> CreateChainParams(const std::string& chain);
|
|
|
|
/**
|
|
* Return the currently selected parameters. This won't change after app
|
|
* startup, except for unit tests.
|
|
*/
|
|
const CChainParams &Params();
|
|
|
|
/**
|
|
* Sets the params returned by Params() to those for the given BIP70 chain name.
|
|
* @throws std::runtime_error when the chain is not supported.
|
|
*/
|
|
void SelectParams(const std::string& chain);
|
|
|
|
/**
|
|
* Allows modifying the Version Bits regtest parameters.
|
|
*/
|
|
void UpdateVersionBitsParameters(Consensus::DeploymentPos d, int64_t nStartTime, int64_t nTimeout, int64_t nWindowSize, int64_t nThreshold);
|
|
|
|
/**
|
|
* Allows modifying the DIP3 activation and enforcement height
|
|
*/
|
|
void UpdateDIP3Parameters(int nActivationHeight, int nEnforcementHeight);
|
|
|
|
/**
|
|
* Allows modifying the budget regtest parameters.
|
|
*/
|
|
void UpdateBudgetParameters(int nMasternodePaymentsStartBlock, int nBudgetPaymentsStartBlock, int nSuperblockStartBlock);
|
|
|
|
/**
|
|
* Allows modifying the subsidy and difficulty devnet parameters.
|
|
*/
|
|
void UpdateDevnetSubsidyAndDiffParams(int nMinimumDifficultyBlocks, int nHighSubsidyBlocks, int nHighSubsidyFactor);
|
|
|
|
/**
|
|
* Allows modifying the LLMQ type for ChainLocks.
|
|
*/
|
|
void UpdateDevnetLLMQChainLocks(Consensus::LLMQType llmqType);
|
|
|
|
/**
|
|
* Allows modifying parameters of the test LLMQ
|
|
*/
|
|
void UpdateLLMQTestParams(int size, int threshold);
|
|
|
|
/**
|
|
* Allows modifying parameters of the devnet LLMQ
|
|
*/
|
|
void UpdateLLMQDevnetParams(int size, int threshold);
|
|
|
|
#endif // BITCOIN_CHAINPARAMS_H
|