2013-05-07 15:16:25 +02:00
|
|
|
// Copyright (c) 2010 Satoshi Nakamoto
|
2014-12-17 02:47:57 +01:00
|
|
|
// Copyright (c) 2009-2014 The Bitcoin Core developers
|
2014-10-25 11:24:16 +02:00
|
|
|
// Distributed under the MIT software license, see the accompanying
|
2013-05-07 15:16:25 +02:00
|
|
|
// file COPYING or http://www.opensource.org/licenses/mit-license.php.
|
|
|
|
|
|
|
|
#include "chainparams.h"
|
2013-04-13 07:13:08 +02:00
|
|
|
|
2013-05-07 15:16:25 +02:00
|
|
|
#include "util.h"
|
2014-09-25 05:32:36 +02:00
|
|
|
#include "utilstrencodings.h"
|
2013-05-07 15:16:25 +02:00
|
|
|
|
2014-08-28 22:56:53 +02:00
|
|
|
#include <assert.h>
|
|
|
|
|
2013-06-23 02:33:47 +02:00
|
|
|
#include <boost/assign/list_of.hpp>
|
2014-12-08 23:43:18 +01:00
|
|
|
#include <stdio.h>
|
2013-06-23 02:33:47 +02:00
|
|
|
|
2014-06-16 16:30:38 +02:00
|
|
|
using namespace std;
|
2013-06-23 02:33:47 +02:00
|
|
|
|
2014-07-24 13:52:57 +02:00
|
|
|
#include "chainparamsseeds.h"
|
|
|
|
|
2014-10-25 11:24:16 +02:00
|
|
|
/**
|
|
|
|
* Main network
|
|
|
|
*/
|
|
|
|
/**
|
|
|
|
* What makes a good checkpoint block?
|
|
|
|
* + Is surrounded by blocks with reasonable timestamps
|
|
|
|
* (no blocks before with a timestamp after, none after with
|
|
|
|
* timestamp before)
|
|
|
|
* + Contains no strange transactions
|
|
|
|
*/
|
2014-12-08 23:43:18 +01:00
|
|
|
|
2013-05-07 15:16:25 +02:00
|
|
|
class CMainParams : public CChainParams {
|
|
|
|
public:
|
|
|
|
CMainParams() {
|
2015-06-12 04:55:12 +02:00
|
|
|
strNetworkID = "lbrycrd";
|
2015-04-06 17:43:13 +02:00
|
|
|
consensus.nSubsidyHalvingInterval = 2100000;
|
2015-02-11 11:58:11 +01:00
|
|
|
consensus.nMajorityEnforceBlockUpgrade = 750;
|
|
|
|
consensus.nMajorityRejectBlockOutdated = 950;
|
|
|
|
consensus.nMajorityWindow = 1000;
|
2015-04-30 18:22:51 +02:00
|
|
|
consensus.powLimit = uint256S("0000ffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff");
|
2015-04-06 17:43:13 +02:00
|
|
|
consensus.nPowTargetTimespan = 30 * 60 * 12;//14 * 24 * 60 * 60; // two weeks
|
|
|
|
consensus.nPowTargetSpacing = 30;
|
2015-02-11 11:58:11 +01:00
|
|
|
consensus.fPowAllowMinDifficultyBlocks = false;
|
2014-10-25 11:24:16 +02:00
|
|
|
/**
|
|
|
|
* The message start string is designed to be unlikely to occur in normal data.
|
|
|
|
* The characters are rarely used upper ASCII, not valid as UTF-8, and produce
|
2015-04-28 16:47:17 +02:00
|
|
|
* a large 32-bit integer with any alignment.
|
2014-10-25 11:24:16 +02:00
|
|
|
*/
|
2015-09-23 22:19:59 +02:00
|
|
|
pchMessageStart[0] = 0xfa;
|
|
|
|
pchMessageStart[1] = 0xe4;
|
|
|
|
pchMessageStart[2] = 0xaa;
|
|
|
|
pchMessageStart[3] = 0xf1;
|
2013-05-07 15:16:25 +02:00
|
|
|
vAlertPubKey = ParseHex("04fc9702847840aaf195de8442ebecedf5b095cdbb9bc716bda9110971b28a49e0ead8564ff0db22209e0374782c093bb899692d524e9d6a6956e7c5ecbcd68284");
|
2015-09-24 07:15:28 +02:00
|
|
|
nDefaultPort = 9246;
|
2014-12-08 23:43:18 +01:00
|
|
|
nMinerThreads = 2;
|
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.
2015-02-23 20:27:44 +01:00
|
|
|
nPruneAfterHeight = 100000;
|
2013-05-07 15:16:25 +02:00
|
|
|
|
2014-10-25 11:24:16 +02:00
|
|
|
/**
|
2015-04-28 16:47:17 +02:00
|
|
|
* Build the genesis block. Note that the output of its generation
|
|
|
|
* transaction cannot be spent since it did not originally exist in the
|
|
|
|
* database.
|
|
|
|
*
|
2014-10-25 11:24:16 +02:00
|
|
|
* CBlock(hash=000000000019d6, ver=1, hashPrevBlock=00000000000000, hashMerkleRoot=4a5e1e, nTime=1231006505, nBits=1d00ffff, nNonce=2083236893, vtx=1)
|
|
|
|
* CTransaction(hash=4a5e1e, ver=1, vin.size=1, vout.size=1, nLockTime=0)
|
|
|
|
* CTxIn(COutPoint(000000, -1), coinbase 04ffff001d0104455468652054696d65732030332f4a616e2f32303039204368616e63656c6c6f72206f6e206272696e6b206f66207365636f6e64206261696c6f757420666f722062616e6b73)
|
|
|
|
* CTxOut(nValue=50.00000000, scriptPubKey=0x5F1DF16B2B704C8A578D0B)
|
|
|
|
* vMerkleTree: 4a5e1e
|
|
|
|
*/
|
2014-12-08 23:43:18 +01:00
|
|
|
const char* pszTimestamp = "insert timestamp string";//"The Times 03/Jan/2009 Chancellor on brink of second bailout for banks";
|
2014-06-07 13:53:27 +02:00
|
|
|
CMutableTransaction txNew;
|
2015-06-03 01:25:34 +02:00
|
|
|
txNew.nVersion = 1;
|
2013-05-07 15:16:25 +02:00
|
|
|
txNew.vin.resize(1);
|
|
|
|
txNew.vout.resize(1);
|
2014-03-26 20:56:45 +01:00
|
|
|
txNew.vin[0].scriptSig = CScript() << 486604799 << CScriptNum(4) << vector<unsigned char>((const unsigned char*)pszTimestamp, (const unsigned char*)pszTimestamp + strlen(pszTimestamp));
|
2013-05-07 15:16:25 +02:00
|
|
|
txNew.vout[0].nValue = 50 * COIN;
|
2014-12-08 23:43:18 +01:00
|
|
|
//txNew.vout[0].scriptPubKey = CScript() << ParseHex("04678afdb0fe5548271967f1a67130b7105cd6a828e03909a67962e0ea1f61deb649f6bc3f4cef38c4f35504e51ec112de5c384df7ba0b8d578a4c702b6bf11d5f") << OP_CHECKSIG;
|
|
|
|
//txNew.vout[0].scriptPubKey = CScript() << ParseHex("0425caecb9fbf6cf50979644e85c11e3ec9007fd477fab9683648c6539e59b59c3a4d9b9c0b552c37eee6476f3e0d8425ac0346fe69ad61628b8c340d42fbfa3fd") << OP_CHECKSIG;
|
2015-04-09 05:28:04 +02:00
|
|
|
//txNew.vout[0].scriptPubKey = CScript() << OP_DUP << OP_HASH160 << ParseHex("e5ff2d9e3a254622ae493573169c0fa94c82fe4f") << OP_EQUALVERIFY << OP_CHECKSIG;
|
|
|
|
txNew.vout[0].scriptPubKey = CScript() << OP_DUP << OP_HASH160 << ParseHex("345991dbf57bfb014b87006acdfafbfc5fe8292f") << OP_EQUALVERIFY << OP_CHECKSIG;
|
2013-05-07 15:16:25 +02:00
|
|
|
genesis.vtx.push_back(txNew);
|
2014-12-15 09:11:16 +01:00
|
|
|
genesis.hashPrevBlock.SetNull();
|
2013-05-07 15:16:25 +02:00
|
|
|
genesis.hashMerkleRoot = genesis.BuildMerkleTree();
|
2015-09-24 07:15:28 +02:00
|
|
|
genesis.hashClaimTrie = uint256S("0x0000000000000000000000000000000000000000000000000000000000000001");
|
2013-05-07 15:16:25 +02:00
|
|
|
genesis.nVersion = 1;
|
2014-12-08 23:43:18 +01:00
|
|
|
genesis.nTime = 1417453734;
|
2015-05-20 16:26:14 +02:00
|
|
|
genesis.nBits = 0x1f00ffff;
|
2015-04-09 05:28:04 +02:00
|
|
|
genesis.nNonce = 7885;
|
2014-12-08 23:43:18 +01:00
|
|
|
|
|
|
|
/*bool found = false;
|
|
|
|
while (!found)
|
|
|
|
{
|
|
|
|
genesis.nNonce += 1;
|
2015-04-09 05:28:04 +02:00
|
|
|
consensus.hashGenesisBlock = genesis.GetHash();
|
|
|
|
if (CheckProofOfWork2(consensus.hashGenesisBlock, consensus.powLimit.GetCompact(), consensus))
|
2014-12-08 23:43:18 +01:00
|
|
|
{
|
2015-04-09 05:28:04 +02:00
|
|
|
std::cout << "nonce: " << genesis.nNonce << std::endl;
|
|
|
|
std::cout << "hex: " << consensus.hashGenesisBlock.GetHex() << std::endl;
|
2014-12-08 23:43:18 +01:00
|
|
|
found = true;
|
|
|
|
}
|
|
|
|
}*/
|
2013-05-07 15:16:25 +02:00
|
|
|
|
2015-02-11 11:58:11 +01:00
|
|
|
consensus.hashGenesisBlock = genesis.GetHash();
|
2015-04-09 05:28:04 +02:00
|
|
|
//printf("hex: %s\n", consensus.hashGenesisBlock.GetHex().c_str());
|
2015-04-06 17:43:13 +02:00
|
|
|
//assert(consensus.hashGenesisBlock == uint256S("0x000000000019d6689c085ae165831e934ff763ae46a2a6c172b3f1b60a8ce26f"));
|
2015-04-09 05:28:04 +02:00
|
|
|
//assert(consensus.hashGenesisBlock == uint256S("0x00ef6ded2b610fc5e4f06d187d12136bd5fba7b932fa0b66bf353c7c1648ec9c"));
|
|
|
|
assert(consensus.hashGenesisBlock == uint256S("0x0000343f59c49eb433ba3a37ee4b3493ff014ee9b266f610bb3cd1b36927787a"));
|
2015-01-05 17:43:07 +01:00
|
|
|
//printf("%s\n", genesis.hashMerkleRoot.GetHex().c_str());
|
2014-12-08 23:43:18 +01:00
|
|
|
//assert(genesis.hashMerkleRoot == uint256("0x4a5e1e4baab89f3a32518a88c31bc87f618f76673e2cc77ab2127b7afdeda33b"));
|
2015-04-09 05:28:04 +02:00
|
|
|
//assert(genesis.hashMerkleRoot == uint256S("0xa7d51d407092059a2beeffab22e65d6176cfb3c33b93515109480aa7c81c9141"));
|
|
|
|
assert(genesis.hashMerkleRoot == uint256S("0x93621531f4de4b27d4ffdf785ef12855f2b18687e2141466ff50e2848d83f551"));
|
2013-05-07 15:16:25 +02:00
|
|
|
|
2014-12-08 23:43:18 +01:00
|
|
|
vSeeds.clear();
|
2015-04-07 01:00:27 +02:00
|
|
|
vFixedSeeds.clear();
|
2013-05-07 15:16:25 +02:00
|
|
|
|
2014-11-24 23:25:58 +01:00
|
|
|
base58Prefixes[PUBKEY_ADDRESS] = std::vector<unsigned char>(1,0);
|
|
|
|
base58Prefixes[SCRIPT_ADDRESS] = std::vector<unsigned char>(1,5);
|
|
|
|
base58Prefixes[SECRET_KEY] = std::vector<unsigned char>(1,128);
|
|
|
|
base58Prefixes[EXT_PUBLIC_KEY] = boost::assign::list_of(0x04)(0x88)(0xB2)(0x1E).convert_to_container<std::vector<unsigned char> >();
|
|
|
|
base58Prefixes[EXT_SECRET_KEY] = boost::assign::list_of(0x04)(0x88)(0xAD)(0xE4).convert_to_container<std::vector<unsigned char> >();
|
2013-05-07 15:16:25 +02:00
|
|
|
|
2015-01-24 05:40:50 +01:00
|
|
|
vFixedSeeds = std::vector<SeedSpec6>(pnSeed6_main, pnSeed6_main + ARRAYLEN(pnSeed6_main));
|
2013-05-07 15:16:25 +02:00
|
|
|
|
2014-06-04 12:51:29 +02:00
|
|
|
fRequireRPCPassword = true;
|
|
|
|
fMiningRequiresPeers = true;
|
2015-03-13 17:25:34 +01:00
|
|
|
fDefaultConsistencyChecks = false;
|
2014-06-04 12:51:29 +02:00
|
|
|
fRequireStandard = true;
|
|
|
|
fMineBlocksOnDemand = false;
|
2014-08-31 22:32:52 +02:00
|
|
|
fTestnetToBeDeprecatedFieldRPC = false;
|
2014-08-31 21:32:23 +02:00
|
|
|
|
2015-04-24 00:30:55 +02:00
|
|
|
checkpointData = (Checkpoints::CCheckpointData) {
|
|
|
|
boost::assign::map_list_of
|
2015-05-20 16:26:14 +02:00
|
|
|
( 0, uint256S("0x0000343f59c49eb433ba3a37ee4b3493ff014ee9b266f610bb3cd1b36927787a")),
|
|
|
|
1417453734, // * UNIX timestamp of last checkpoint block
|
|
|
|
1, // * total number of transactions between genesis and last checkpoint
|
2015-04-24 00:30:55 +02:00
|
|
|
// (the tx=... number in the SetBestChain debug.log lines)
|
2015-05-20 16:26:14 +02:00
|
|
|
0.0 // * estimated number of transactions per day after checkpoint
|
2015-04-24 00:30:55 +02:00
|
|
|
};
|
2014-08-31 21:32:23 +02:00
|
|
|
}
|
2013-05-07 15:16:25 +02:00
|
|
|
};
|
|
|
|
static CMainParams mainParams;
|
|
|
|
|
2014-10-25 11:24:16 +02:00
|
|
|
/**
|
|
|
|
* Testnet (v3)
|
|
|
|
*/
|
2013-05-07 15:16:25 +02:00
|
|
|
class CTestNetParams : public CMainParams {
|
|
|
|
public:
|
|
|
|
CTestNetParams() {
|
2014-06-11 12:23:49 +02:00
|
|
|
strNetworkID = "test";
|
2015-02-11 11:58:11 +01:00
|
|
|
consensus.nMajorityEnforceBlockUpgrade = 51;
|
|
|
|
consensus.nMajorityRejectBlockOutdated = 75;
|
|
|
|
consensus.nMajorityWindow = 100;
|
|
|
|
consensus.fPowAllowMinDifficultyBlocks = true;
|
2013-05-07 15:16:25 +02:00
|
|
|
pchMessageStart[0] = 0x0b;
|
|
|
|
pchMessageStart[1] = 0x11;
|
|
|
|
pchMessageStart[2] = 0x09;
|
|
|
|
pchMessageStart[3] = 0x07;
|
|
|
|
vAlertPubKey = ParseHex("04302390343f91cc401d56d68b123028bf52e5fca1939df127f63c6467cdf9c8e2c14b61104cf817d0b780da337893ecc4aaff1309e536162dabbdb45200ca2b0a");
|
2015-09-24 07:15:28 +02:00
|
|
|
nDefaultPort = 19246;
|
2014-03-22 18:29:34 +01:00
|
|
|
nMinerThreads = 0;
|
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.
2015-02-23 20:27:44 +01:00
|
|
|
nPruneAfterHeight = 1000;
|
2013-05-07 15:16:25 +02:00
|
|
|
|
2014-10-25 11:24:16 +02:00
|
|
|
//! Modify the testnet genesis block so the timestamp is valid for a later start.
|
2013-05-07 15:16:25 +02:00
|
|
|
genesis.nTime = 1296688602;
|
|
|
|
genesis.nNonce = 414098458;
|
2015-02-11 11:58:11 +01:00
|
|
|
consensus.hashGenesisBlock = genesis.GetHash();
|
2015-04-06 17:43:13 +02:00
|
|
|
//assert(consensus.hashGenesisBlock == uint256("0x000000000933ea01ad0ee984209779baaec3ced90fa3f408719526f8d77f4943"));
|
2013-05-07 15:16:25 +02:00
|
|
|
|
|
|
|
vFixedSeeds.clear();
|
|
|
|
vSeeds.clear();
|
2014-12-08 23:43:18 +01:00
|
|
|
//vSeeds.push_back(CDNSSeedData("alexykot.me", "testnet-seed.alexykot.me"));
|
|
|
|
//vSeeds.push_back(CDNSSeedData("bitcoin.petertodd.org", "testnet-seed.bitcoin.petertodd.org"));
|
|
|
|
//vSeeds.push_back(CDNSSeedData("bluematt.me", "testnet-seed.bluematt.me"));
|
|
|
|
//vSeeds.push_back(CDNSSeedData("bitcoin.schildbach.de", "testnet-seed.bitcoin.schildbach.de"));
|
2013-05-07 15:16:25 +02:00
|
|
|
|
2014-11-24 23:25:58 +01:00
|
|
|
base58Prefixes[PUBKEY_ADDRESS] = std::vector<unsigned char>(1,111);
|
|
|
|
base58Prefixes[SCRIPT_ADDRESS] = std::vector<unsigned char>(1,196);
|
|
|
|
base58Prefixes[SECRET_KEY] = std::vector<unsigned char>(1,239);
|
|
|
|
base58Prefixes[EXT_PUBLIC_KEY] = boost::assign::list_of(0x04)(0x35)(0x87)(0xCF).convert_to_container<std::vector<unsigned char> >();
|
|
|
|
base58Prefixes[EXT_SECRET_KEY] = boost::assign::list_of(0x04)(0x35)(0x83)(0x94).convert_to_container<std::vector<unsigned char> >();
|
2014-03-22 20:09:12 +01:00
|
|
|
|
2015-01-24 05:40:50 +01:00
|
|
|
vFixedSeeds = std::vector<SeedSpec6>(pnSeed6_test, pnSeed6_test + ARRAYLEN(pnSeed6_test));
|
2014-07-24 13:52:57 +02:00
|
|
|
|
2014-06-04 12:51:29 +02:00
|
|
|
fRequireRPCPassword = true;
|
|
|
|
fMiningRequiresPeers = true;
|
2015-03-13 17:25:34 +01:00
|
|
|
fDefaultConsistencyChecks = false;
|
2014-06-04 12:51:29 +02:00
|
|
|
fRequireStandard = false;
|
|
|
|
fMineBlocksOnDemand = false;
|
2014-08-31 22:32:52 +02:00
|
|
|
fTestnetToBeDeprecatedFieldRPC = true;
|
2015-04-24 00:30:55 +02:00
|
|
|
|
|
|
|
checkpointData = (Checkpoints::CCheckpointData) {
|
|
|
|
boost::assign::map_list_of
|
|
|
|
( 546, uint256S("000000002a936ca763904c3c35fce2f3556c559c0214345d31b1bcebf76acb70")),
|
|
|
|
1337966069,
|
|
|
|
1488,
|
|
|
|
300
|
|
|
|
};
|
|
|
|
|
2014-08-31 21:32:23 +02:00
|
|
|
}
|
2013-05-07 15:16:25 +02:00
|
|
|
};
|
|
|
|
static CTestNetParams testNetParams;
|
|
|
|
|
2014-10-25 11:24:16 +02:00
|
|
|
/**
|
|
|
|
* Regression test
|
|
|
|
*/
|
2013-05-07 15:16:25 +02:00
|
|
|
class CRegTestParams : public CTestNetParams {
|
|
|
|
public:
|
|
|
|
CRegTestParams() {
|
2014-06-11 12:23:49 +02:00
|
|
|
strNetworkID = "regtest";
|
2015-02-11 11:58:11 +01:00
|
|
|
consensus.nSubsidyHalvingInterval = 150;
|
|
|
|
consensus.nMajorityEnforceBlockUpgrade = 750;
|
|
|
|
consensus.nMajorityRejectBlockOutdated = 950;
|
|
|
|
consensus.nMajorityWindow = 1000;
|
2015-03-25 20:00:32 +01:00
|
|
|
consensus.powLimit = uint256S("7fffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff");
|
2013-05-07 15:16:25 +02:00
|
|
|
pchMessageStart[0] = 0xfa;
|
|
|
|
pchMessageStart[1] = 0xbf;
|
|
|
|
pchMessageStart[2] = 0xb5;
|
|
|
|
pchMessageStart[3] = 0xda;
|
2014-03-08 07:47:56 +01:00
|
|
|
nMinerThreads = 1;
|
2013-05-07 15:16:25 +02:00
|
|
|
genesis.nTime = 1296688602;
|
|
|
|
genesis.nBits = 0x207fffff;
|
|
|
|
genesis.nNonce = 2;
|
2015-02-11 11:58:11 +01:00
|
|
|
consensus.hashGenesisBlock = genesis.GetHash();
|
2013-05-07 15:16:25 +02:00
|
|
|
nDefaultPort = 18444;
|
2015-04-06 17:43:13 +02:00
|
|
|
//assert(consensus.hashGenesisBlock == uint256("0x0f9188f13cb7b2c71f2a335e3a4fc328bf5beb436012afca590b1a11466e2206"));
|
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.
2015-02-23 20:27:44 +01:00
|
|
|
nPruneAfterHeight = 1000;
|
2013-05-07 15:16:25 +02:00
|
|
|
|
2014-10-25 11:24:16 +02:00
|
|
|
vFixedSeeds.clear(); //! Regtest mode doesn't have any fixed seeds.
|
|
|
|
vSeeds.clear(); //! Regtest mode doesn't have any DNS seeds.
|
2013-05-07 15:16:25 +02:00
|
|
|
|
2014-06-04 12:51:29 +02:00
|
|
|
fRequireRPCPassword = false;
|
|
|
|
fMiningRequiresPeers = false;
|
2015-03-13 17:25:34 +01:00
|
|
|
fDefaultConsistencyChecks = true;
|
2014-06-04 12:51:29 +02:00
|
|
|
fRequireStandard = false;
|
|
|
|
fMineBlocksOnDemand = true;
|
2014-08-31 22:32:52 +02:00
|
|
|
fTestnetToBeDeprecatedFieldRPC = false;
|
2015-04-24 00:30:55 +02:00
|
|
|
|
|
|
|
checkpointData = (Checkpoints::CCheckpointData){
|
|
|
|
boost::assign::map_list_of
|
|
|
|
( 0, uint256S("0f9188f13cb7b2c71f2a335e3a4fc328bf5beb436012afca590b1a11466e2206")),
|
|
|
|
0,
|
|
|
|
0,
|
|
|
|
0
|
|
|
|
};
|
2014-08-31 21:32:23 +02:00
|
|
|
}
|
2013-05-07 15:16:25 +02:00
|
|
|
};
|
|
|
|
static CRegTestParams regTestParams;
|
|
|
|
|
2014-06-19 15:10:04 +02:00
|
|
|
static CChainParams *pCurrentParams = 0;
|
2013-05-07 15:16:25 +02:00
|
|
|
|
|
|
|
const CChainParams &Params() {
|
2014-06-19 15:10:04 +02:00
|
|
|
assert(pCurrentParams);
|
2013-05-07 15:16:25 +02:00
|
|
|
return *pCurrentParams;
|
|
|
|
}
|
|
|
|
|
2014-08-02 20:54:57 +02:00
|
|
|
CChainParams &Params(CBaseChainParams::Network network) {
|
2013-05-07 15:16:25 +02:00
|
|
|
switch (network) {
|
2014-06-19 15:10:04 +02:00
|
|
|
case CBaseChainParams::MAIN:
|
2014-08-02 20:54:57 +02:00
|
|
|
return mainParams;
|
2014-06-19 15:10:04 +02:00
|
|
|
case CBaseChainParams::TESTNET:
|
2014-08-02 20:54:57 +02:00
|
|
|
return testNetParams;
|
2014-06-19 15:10:04 +02:00
|
|
|
case CBaseChainParams::REGTEST:
|
2014-08-02 20:54:57 +02:00
|
|
|
return regTestParams;
|
2013-05-07 15:16:25 +02:00
|
|
|
default:
|
|
|
|
assert(false && "Unimplemented network");
|
2014-08-02 20:54:57 +02:00
|
|
|
return mainParams;
|
2013-05-07 15:16:25 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2014-08-02 20:54:57 +02:00
|
|
|
void SelectParams(CBaseChainParams::Network network) {
|
|
|
|
SelectBaseParams(network);
|
|
|
|
pCurrentParams = &Params(network);
|
|
|
|
}
|
|
|
|
|
2014-10-16 22:49:33 +02:00
|
|
|
bool SelectParamsFromCommandLine()
|
2014-09-01 00:41:28 +02:00
|
|
|
{
|
2014-10-09 19:15:38 +02:00
|
|
|
CBaseChainParams::Network network = NetworkIdFromCommandLine();
|
2014-09-01 00:41:28 +02:00
|
|
|
if (network == CBaseChainParams::MAX_NETWORK_TYPES)
|
2013-05-07 15:16:25 +02:00
|
|
|
return false;
|
|
|
|
|
2014-09-01 00:41:28 +02:00
|
|
|
SelectParams(network);
|
2013-05-07 15:16:25 +02:00
|
|
|
return true;
|
|
|
|
}
|