Chainparams: Separate globals and depedendent functions #6359
pull jtimon wants to merge 6 commits into bitcoin:master from jtimon:chainparams-globals-0.11.99 changing 18 files +229 −150-
jtimon commented at 0:14 am on July 1, 2015: contributorThis shares the first commit with #6230. This is an alternative to https://github.com/theuni/bitcoin/commit/123f3b0dcef29355060290d56138ff99be212007 which @theuni wasn’t even proposing yet. But I would like your feedback on the factory and the container (which are shared with #6068 ). This is blocking #6229 and #5229. EDIT: The fixup commit cleaning up the includes
may make more sense after more of #5970 (for example, #6163, we’re not that far away from making miner.cpp independent from the chainparams globals)is left for later. -
Chainparams: Replace CBaseChainParams::Network enum with string constants (suggested by Wladimir) 246b4966c1
-
Introduce Container template a74eb425d2
-
Chainparams: Use a regular factory for creating chainparams d1b02c52e2
-
jtimon force-pushed on Jul 1, 2015
-
jtimon force-pushed on Jul 1, 2015
-
jtimon force-pushed on Jul 1, 2015
-
Chainparams: Translations: DRY: options and error strings
Also remove SelectBaseParamsFromCommandLine and SelectParamsFromCommandLine
-
remove SelectBaseParams(), BaseParams() and AreBaseParamsConfigured() 7fb9f6ad7b
-
MOVEONLY: Chainparams: Separate globals and functions depending on them db85b3d747
-
jtimon force-pushed on Jul 2, 2015
-
jtimon closed this on Jul 2, 2015
-
theuni commented at 4:43 pm on July 2, 2015: member
@jtimon I’m not sure it’s worth the complication of a factory here. Given that all chainparams and consensusparams are immutable, why not just pass around new instances when necessary? That should still be cheap, and much simpler? Especially given the trend to pass the params around as necessary rather than call Params() directly.
Something like:
0static CBaseChainParams::Network nCurrentParams = CBaseChainParams::MAX_NETWORK_TYPES; 1 2const CChainParams Params() { 3 switch (nCurrentParams) { 4 case CBaseChainParams::MAIN: 5 return CChainParams(CMainParams()); 6 case CBaseChainParams::TESTNET: 7 return CChainParams(CTestNetParams()); 8 case CBaseChainParams::REGTEST: 9 return CChainParams(CRegTestParams()); 10 default: 11 assert(false && "Unimplemented network"); 12 return CChainParams(CMainParams()); 13 } 14} 15 16void SelectParams(CBaseChainParams::Network network) { 17 SelectBaseParams(network); 18 nCurrentParams = network; 19}
Hell, since there are no virtual functions left (nor should there be), we could even do away with the inheritance and just make CBaseChainParams::Network a ctor arg for CChainParams.
-
jtimon commented at 7:22 pm on July 2, 2015: contributor
The main point of the factory is that it is not on globals/ because once we’re finished “passing chainparams around” there should be no need for any global at all: You either take it as parameter or use the factory (this includes removing the SelectParams from
BasicTestingSetup::BasicTestingSetup()
, since nobody depends on the global and tests can use the factory directly).But if copying the object in the factory (like you do with the
Params()
of your example), then the factory doesn’t need to return a pointer (it could just be the current parametrized Params() ), and the Container would also be unnecessary (and the same goes for CPolicy).The enum doesn’t scale very well once you go beyond -testnet and -regtest (see #5229 in fact, I’m preparing a PR to add infinite new testing altchains). The same happens with the single constructor parameter. But you are right, the inheritance is overkill here. With a fully parametric constructor the factory can just always call that constructor with different values. ie:
0CChainParams* Params(const std::string& chain) 1{ 2 if (chain == CBaseChainParams::MAIN) 3 return new CChainParams("main", 210000, 750, 950, 1000...); 4 else if (chain == CBaseChainParams::TESTNET) 5 ...
-
jtimon commented at 2:20 pm on July 6, 2015: contributor@theuni I’ve been exploring your suggestion and it’s not so straight-forward as you may think. If Params(string) returns a new object instead of a reference some places will crash, like this one: https://github.com/bitcoin/bitcoin/blob/master/src/test/alert_tests.cpp#L125 It also means that Params() and BaseParams() have to return a new object as well instead of a const reference. It works fine for ParamsBase, which doesn’t have a similar &ParamsBase(enum/string) psedo-factory. But I really prefer to just remove the interface functions in this case (where it’s easy, see https://github.com/jtimon/bitcoin/commit/7fb9f6ad7bad4b64df0fdb36e5230becd2290864 ). Can we first agree that it will be better to remove SelectParamsFromCommandLine and SelectBaseParamsFromCommandLine before separating the globals? I have reopened #6235 with that. @rustyrussell you may be interested in this discussion, or reviewing #6235.
-
MarcoFalke locked this on Sep 8, 2021
This is a metadata mirror of the GitHub repository bitcoin/bitcoin. This site is not affiliated with GitHub. Content is generated from a GitHub metadata backup.
generated: 2025-01-22 06:12 UTC
More mirrored repositories can be found on mirror.b10c.me