mirror of
https://github.com/bitcoin/bitcoin.git
synced 2025-02-02 09:46:52 -05:00
d8fe24cbfb
e90478f43e
log: harmonize bitcoind server logging (Jon Atack) Pull request description: Harmonize the user-facing output of the `bitcoind -daemon`, `bitcoin-cli help stop`, `bitcoin-cli stop`, and `bitcoind -version` commands to be consistent with each other as well as with the "Bitcoin Core is probably already running" messages, e.g. `git grep 'probably already running.")'`. Before: ``` $ bitcoind -regtest -daemon Bitcoin Core daemon starting $ bitcoind -regtest -daemon Error: Bitcoin Core is probably already running. $ bitcoind -regtest -version Bitcoin Core Daemon version v0.18.99.0-e653eeff76-dirty $ bitcoin-cli -regtest help stop stop Stop Bitcoin server. $ bitcoin-cli -regtest stop Bitcoin server stopping ``` these five commands output: "Bitcoin Core daemon" "Bitcoin Core" "Bitcoin Core Daemon" "Bitcoin server" "Bitcoin server" After this commit, they are all "Bitcoin Core". ``` $ bitcoind -regtest -daemon Bitcoin Core starting $ bitcoind -regtest -daemon Error: Bitcoin Core is probably already running. $ bitcoind -regtest -version Bitcoin Core version v0.18.99.0-e90478f43e-dirty $ bitcoin-cli -regtest help stop stop Request a graceful shutdown of Bitcoin Core. $ bitcoin-cli -regtest stop Bitcoin Core stopping ``` ACKs for top commit: practicalswift: ACKe90478f43e
(read code which looks good) practicalswift: ACKe90478f43e
-- diff looks correct fjahr: utACKe90478f
michaelfolkson: ACKe90478f43e
. Tested command outputs and as described. ariard: Tested ACKe90478f
fanquake: ACKe90478f43e
Tree-SHA512: 9ee584d260b5c224463318a51c2856a7c0e463be039fea072e5d5bab8898f0043b3930cf887a47aafd0f3447adb551b5e47a4e98ebdefc6cdb8e77edde0347b0
195 lines
6 KiB
C++
195 lines
6 KiB
C++
// Copyright (c) 2009-2010 Satoshi Nakamoto
|
|
// Copyright (c) 2009-2019 The Bitcoin Core developers
|
|
// Distributed under the MIT software license, see the accompanying
|
|
// file COPYING or http://www.opensource.org/licenses/mit-license.php.
|
|
|
|
#if defined(HAVE_CONFIG_H)
|
|
#include <config/bitcoin-config.h>
|
|
#endif
|
|
|
|
#include <chainparams.h>
|
|
#include <clientversion.h>
|
|
#include <compat.h>
|
|
#include <fs.h>
|
|
#include <init.h>
|
|
#include <interfaces/chain.h>
|
|
#include <noui.h>
|
|
#include <shutdown.h>
|
|
#include <ui_interface.h>
|
|
#include <util/strencodings.h>
|
|
#include <util/system.h>
|
|
#include <util/threadnames.h>
|
|
#include <util/translation.h>
|
|
|
|
#include <functional>
|
|
|
|
const std::function<std::string(const char*)> G_TRANSLATION_FUN = nullptr;
|
|
|
|
/* Introduction text for doxygen: */
|
|
|
|
/*! \mainpage Developer documentation
|
|
*
|
|
* \section intro_sec Introduction
|
|
*
|
|
* This is the developer documentation of the reference client for an experimental new digital currency called Bitcoin,
|
|
* which enables instant payments to anyone, anywhere in the world. Bitcoin uses peer-to-peer technology to operate
|
|
* with no central authority: managing transactions and issuing money are carried out collectively by the network.
|
|
*
|
|
* The software is a community-driven open source project, released under the MIT license.
|
|
*
|
|
* See https://github.com/bitcoin/bitcoin and https://bitcoincore.org/ for further information about the project.
|
|
*
|
|
* \section Navigation
|
|
* Use the buttons <code>Namespaces</code>, <code>Classes</code> or <code>Files</code> at the top of the page to start navigating the code.
|
|
*/
|
|
|
|
static void WaitForShutdown()
|
|
{
|
|
while (!ShutdownRequested())
|
|
{
|
|
MilliSleep(200);
|
|
}
|
|
Interrupt();
|
|
}
|
|
|
|
//////////////////////////////////////////////////////////////////////////////
|
|
//
|
|
// Start
|
|
//
|
|
static bool AppInit(int argc, char* argv[])
|
|
{
|
|
InitInterfaces interfaces;
|
|
interfaces.chain = interfaces::MakeChain();
|
|
|
|
bool fRet = false;
|
|
|
|
util::ThreadRename("init");
|
|
|
|
//
|
|
// Parameters
|
|
//
|
|
// If Qt is used, parameters/bitcoin.conf are parsed in qt/bitcoin.cpp's main()
|
|
SetupServerArgs();
|
|
std::string error;
|
|
if (!gArgs.ParseParameters(argc, argv, error)) {
|
|
return InitError(strprintf("Error parsing command line arguments: %s\n", error));
|
|
}
|
|
|
|
// Process help and version before taking care about datadir
|
|
if (HelpRequested(gArgs) || gArgs.IsArgSet("-version")) {
|
|
std::string strUsage = PACKAGE_NAME " version " + FormatFullVersion() + "\n";
|
|
|
|
if (gArgs.IsArgSet("-version"))
|
|
{
|
|
strUsage += FormatParagraph(LicenseInfo()) + "\n";
|
|
}
|
|
else
|
|
{
|
|
strUsage += "\nUsage: bitcoind [options] Start " PACKAGE_NAME "\n";
|
|
strUsage += "\n" + gArgs.GetHelpMessage();
|
|
}
|
|
|
|
tfm::format(std::cout, "%s", strUsage.c_str());
|
|
return true;
|
|
}
|
|
|
|
try
|
|
{
|
|
if (!CheckDataDirOption()) {
|
|
return InitError(strprintf("Specified data directory \"%s\" does not exist.\n", gArgs.GetArg("-datadir", "")));
|
|
}
|
|
if (!gArgs.ReadConfigFiles(error, true)) {
|
|
return InitError(strprintf("Error reading configuration file: %s\n", error));
|
|
}
|
|
// Check for -testnet or -regtest parameter (Params() calls are only valid after this clause)
|
|
try {
|
|
SelectParams(gArgs.GetChainName());
|
|
} catch (const std::exception& e) {
|
|
return InitError(strprintf("%s\n", e.what()));
|
|
}
|
|
|
|
// Error out when loose non-argument tokens are encountered on command line
|
|
for (int i = 1; i < argc; i++) {
|
|
if (!IsSwitchChar(argv[i][0])) {
|
|
return InitError(strprintf("Command line contains unexpected token '%s', see bitcoind -h for a list of options.\n", argv[i]));
|
|
}
|
|
}
|
|
|
|
// -server defaults to true for bitcoind but not for the GUI so do this here
|
|
gArgs.SoftSetBoolArg("-server", true);
|
|
// Set this early so that parameter interactions go to console
|
|
InitLogging();
|
|
InitParameterInteraction();
|
|
if (!AppInitBasicSetup())
|
|
{
|
|
// InitError will have been called with detailed error, which ends up on console
|
|
return false;
|
|
}
|
|
if (!AppInitParameterInteraction())
|
|
{
|
|
// InitError will have been called with detailed error, which ends up on console
|
|
return false;
|
|
}
|
|
if (!AppInitSanityChecks())
|
|
{
|
|
// InitError will have been called with detailed error, which ends up on console
|
|
return false;
|
|
}
|
|
if (gArgs.GetBoolArg("-daemon", false))
|
|
{
|
|
#if HAVE_DECL_DAEMON
|
|
#if defined(MAC_OSX)
|
|
#pragma GCC diagnostic push
|
|
#pragma GCC diagnostic ignored "-Wdeprecated-declarations"
|
|
#endif
|
|
tfm::format(std::cout, PACKAGE_NAME " starting\n");
|
|
|
|
// Daemonize
|
|
if (daemon(1, 0)) { // don't chdir (1), do close FDs (0)
|
|
return InitError(strprintf("daemon() failed: %s\n", strerror(errno)));
|
|
}
|
|
#if defined(MAC_OSX)
|
|
#pragma GCC diagnostic pop
|
|
#endif
|
|
#else
|
|
return InitError("-daemon is not supported on this operating system\n");
|
|
#endif // HAVE_DECL_DAEMON
|
|
}
|
|
// Lock data directory after daemonization
|
|
if (!AppInitLockDataDirectory())
|
|
{
|
|
// If locking the data directory failed, exit immediately
|
|
return false;
|
|
}
|
|
fRet = AppInitMain(interfaces);
|
|
}
|
|
catch (const std::exception& e) {
|
|
PrintExceptionContinue(&e, "AppInit()");
|
|
} catch (...) {
|
|
PrintExceptionContinue(nullptr, "AppInit()");
|
|
}
|
|
|
|
if (!fRet)
|
|
{
|
|
Interrupt();
|
|
} else {
|
|
WaitForShutdown();
|
|
}
|
|
Shutdown(interfaces);
|
|
|
|
return fRet;
|
|
}
|
|
|
|
int main(int argc, char* argv[])
|
|
{
|
|
#ifdef WIN32
|
|
util::WinCmdLineArgs winArgs;
|
|
std::tie(argc, argv) = winArgs.get();
|
|
#endif
|
|
SetupEnvironment();
|
|
|
|
// Connect bitcoind signal handlers
|
|
noui_connect();
|
|
|
|
return (AppInit(argc, argv) ? EXIT_SUCCESS : EXIT_FAILURE);
|
|
}
|