Move GetWarnings() into its own file.
This commit is contained in:
parent
e3ba0ef956
commit
749be013f5
9 changed files with 116 additions and 89 deletions
|
@ -154,6 +154,7 @@ BITCOIN_CORE_H = \
|
||||||
wallet/rpcwallet.h \
|
wallet/rpcwallet.h \
|
||||||
wallet/wallet.h \
|
wallet/wallet.h \
|
||||||
wallet/walletdb.h \
|
wallet/walletdb.h \
|
||||||
|
warnings.h \
|
||||||
zmq/zmqabstractnotifier.h \
|
zmq/zmqabstractnotifier.h \
|
||||||
zmq/zmqconfig.h\
|
zmq/zmqconfig.h\
|
||||||
zmq/zmqnotificationinterface.h \
|
zmq/zmqnotificationinterface.h \
|
||||||
|
@ -305,6 +306,7 @@ libbitcoin_common_a_SOURCES = \
|
||||||
scheduler.cpp \
|
scheduler.cpp \
|
||||||
script/sign.cpp \
|
script/sign.cpp \
|
||||||
script/standard.cpp \
|
script/standard.cpp \
|
||||||
|
warnings.cpp \
|
||||||
$(BITCOIN_CORE_H)
|
$(BITCOIN_CORE_H)
|
||||||
|
|
||||||
# util: shared between all executables.
|
# util: shared between all executables.
|
||||||
|
|
|
@ -41,6 +41,7 @@
|
||||||
#ifdef ENABLE_WALLET
|
#ifdef ENABLE_WALLET
|
||||||
#include "wallet/wallet.h"
|
#include "wallet/wallet.h"
|
||||||
#endif
|
#endif
|
||||||
|
#include "warnings.h"
|
||||||
#include <stdint.h>
|
#include <stdint.h>
|
||||||
#include <stdio.h>
|
#include <stdio.h>
|
||||||
#include <memory>
|
#include <memory>
|
||||||
|
|
|
@ -30,6 +30,7 @@
|
||||||
#include "scheduler.h"
|
#include "scheduler.h"
|
||||||
#include "ui_interface.h"
|
#include "ui_interface.h"
|
||||||
#include "util.h"
|
#include "util.h"
|
||||||
|
#include "warnings.h"
|
||||||
|
|
||||||
#ifdef ENABLE_WALLET
|
#ifdef ENABLE_WALLET
|
||||||
#include "wallet/wallet.h"
|
#include "wallet/wallet.h"
|
||||||
|
|
|
@ -13,6 +13,7 @@
|
||||||
#include "ui_interface.h"
|
#include "ui_interface.h"
|
||||||
#include "util.h"
|
#include "util.h"
|
||||||
#include "utilstrencodings.h"
|
#include "utilstrencodings.h"
|
||||||
|
#include "warnings.h"
|
||||||
|
|
||||||
#include <boost/foreach.hpp>
|
#include <boost/foreach.hpp>
|
||||||
|
|
||||||
|
|
80
src/util.cpp
80
src/util.cpp
|
@ -108,11 +108,6 @@ bool fDebug = false;
|
||||||
bool fPrintToConsole = false;
|
bool fPrintToConsole = false;
|
||||||
bool fPrintToDebugLog = true;
|
bool fPrintToDebugLog = true;
|
||||||
|
|
||||||
CCriticalSection cs_warnings;
|
|
||||||
string strMiscWarning;
|
|
||||||
bool fLargeWorkForkFound = false;
|
|
||||||
bool fLargeWorkInvalidChainFound = false;
|
|
||||||
|
|
||||||
bool fLogTimestamps = DEFAULT_LOGTIMESTAMPS;
|
bool fLogTimestamps = DEFAULT_LOGTIMESTAMPS;
|
||||||
bool fLogTimeMicros = DEFAULT_LOGTIMEMICROS;
|
bool fLogTimeMicros = DEFAULT_LOGTIMEMICROS;
|
||||||
bool fLogIPs = DEFAULT_LOGIPS;
|
bool fLogIPs = DEFAULT_LOGIPS;
|
||||||
|
@ -813,78 +808,3 @@ std::string CopyrightHolders(const std::string& strPrefix)
|
||||||
}
|
}
|
||||||
return strCopyrightHolders;
|
return strCopyrightHolders;
|
||||||
}
|
}
|
||||||
|
|
||||||
void SetMiscWarning(const std::string& strWarning)
|
|
||||||
{
|
|
||||||
LOCK(cs_warnings);
|
|
||||||
strMiscWarning = strWarning;
|
|
||||||
}
|
|
||||||
|
|
||||||
void SetfLargeWorkForkFound(bool flag)
|
|
||||||
{
|
|
||||||
LOCK(cs_warnings);
|
|
||||||
fLargeWorkForkFound = flag;
|
|
||||||
}
|
|
||||||
|
|
||||||
bool GetfLargeWorkForkFound()
|
|
||||||
{
|
|
||||||
LOCK(cs_warnings);
|
|
||||||
return fLargeWorkForkFound;
|
|
||||||
}
|
|
||||||
|
|
||||||
void SetfLargeWorkInvalidChainFound(bool flag)
|
|
||||||
{
|
|
||||||
LOCK(cs_warnings);
|
|
||||||
fLargeWorkInvalidChainFound = flag;
|
|
||||||
}
|
|
||||||
|
|
||||||
bool GetfLargeWorkInvalidChainFound()
|
|
||||||
{
|
|
||||||
LOCK(cs_warnings);
|
|
||||||
return fLargeWorkInvalidChainFound;
|
|
||||||
}
|
|
||||||
|
|
||||||
std::string GetWarnings(const std::string& strFor)
|
|
||||||
{
|
|
||||||
string strStatusBar;
|
|
||||||
string strRPC;
|
|
||||||
string strGUI;
|
|
||||||
const string uiAlertSeperator = "<hr />";
|
|
||||||
|
|
||||||
LOCK(cs_warnings);
|
|
||||||
|
|
||||||
if (!CLIENT_VERSION_IS_RELEASE) {
|
|
||||||
strStatusBar = "This is a pre-release test build - use at your own risk - do not use for mining or merchant applications";
|
|
||||||
strGUI = _("This is a pre-release test build - use at your own risk - do not use for mining or merchant applications");
|
|
||||||
}
|
|
||||||
|
|
||||||
if (GetBoolArg("-testsafemode", DEFAULT_TESTSAFEMODE))
|
|
||||||
strStatusBar = strRPC = strGUI = "testsafemode enabled";
|
|
||||||
|
|
||||||
// Misc warnings like out of disk space and clock is wrong
|
|
||||||
if (strMiscWarning != "")
|
|
||||||
{
|
|
||||||
strStatusBar = strMiscWarning;
|
|
||||||
strGUI += (strGUI.empty() ? "" : uiAlertSeperator) + strMiscWarning;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (fLargeWorkForkFound)
|
|
||||||
{
|
|
||||||
strStatusBar = strRPC = "Warning: The network does not appear to fully agree! Some miners appear to be experiencing issues.";
|
|
||||||
strGUI += (strGUI.empty() ? "" : uiAlertSeperator) + _("Warning: The network does not appear to fully agree! Some miners appear to be experiencing issues.");
|
|
||||||
}
|
|
||||||
else if (fLargeWorkInvalidChainFound)
|
|
||||||
{
|
|
||||||
strStatusBar = strRPC = "Warning: We do not appear to fully agree with our peers! You may need to upgrade, or other nodes may need to upgrade.";
|
|
||||||
strGUI += (strGUI.empty() ? "" : uiAlertSeperator) + _("Warning: We do not appear to fully agree with our peers! You may need to upgrade, or other nodes may need to upgrade.");
|
|
||||||
}
|
|
||||||
|
|
||||||
if (strFor == "gui")
|
|
||||||
return strGUI;
|
|
||||||
else if (strFor == "statusbar")
|
|
||||||
return strStatusBar;
|
|
||||||
else if (strFor == "rpc")
|
|
||||||
return strRPC;
|
|
||||||
assert(!"GetWarnings(): invalid parameter");
|
|
||||||
return "error";
|
|
||||||
}
|
|
||||||
|
|
|
@ -47,8 +47,6 @@ extern bool fDebug;
|
||||||
extern bool fPrintToConsole;
|
extern bool fPrintToConsole;
|
||||||
extern bool fPrintToDebugLog;
|
extern bool fPrintToDebugLog;
|
||||||
|
|
||||||
static const bool DEFAULT_TESTSAFEMODE = false;
|
|
||||||
|
|
||||||
extern bool fLogTimestamps;
|
extern bool fLogTimestamps;
|
||||||
extern bool fLogTimeMicros;
|
extern bool fLogTimeMicros;
|
||||||
extern bool fLogIPs;
|
extern bool fLogIPs;
|
||||||
|
@ -226,11 +224,4 @@ template <typename Callable> void TraceThread(const char* name, Callable func)
|
||||||
|
|
||||||
std::string CopyrightHolders(const std::string& strPrefix);
|
std::string CopyrightHolders(const std::string& strPrefix);
|
||||||
|
|
||||||
void SetMiscWarning(const std::string& strWarning);
|
|
||||||
void SetfLargeWorkForkFound(bool flag);
|
|
||||||
bool GetfLargeWorkForkFound();
|
|
||||||
void SetfLargeWorkInvalidChainFound(bool flag);
|
|
||||||
bool GetfLargeWorkInvalidChainFound();
|
|
||||||
std::string GetWarnings(const std::string& strFor);
|
|
||||||
|
|
||||||
#endif // BITCOIN_UTIL_H
|
#endif // BITCOIN_UTIL_H
|
||||||
|
|
|
@ -34,6 +34,7 @@
|
||||||
#include "utilstrencodings.h"
|
#include "utilstrencodings.h"
|
||||||
#include "validationinterface.h"
|
#include "validationinterface.h"
|
||||||
#include "versionbits.h"
|
#include "versionbits.h"
|
||||||
|
#include "warnings.h"
|
||||||
|
|
||||||
#include <atomic>
|
#include <atomic>
|
||||||
#include <sstream>
|
#include <sstream>
|
||||||
|
|
89
src/warnings.cpp
Normal file
89
src/warnings.cpp
Normal file
|
@ -0,0 +1,89 @@
|
||||||
|
// Copyright (c) 2009-2010 Satoshi Nakamoto
|
||||||
|
// Copyright (c) 2009-2016 The Bitcoin Core developers
|
||||||
|
// Distributed under the MIT software license, see the accompanying
|
||||||
|
// file COPYING or http://www.opensource.org/licenses/mit-license.php.
|
||||||
|
|
||||||
|
#include "sync.h"
|
||||||
|
#include "clientversion.h"
|
||||||
|
#include "util.h"
|
||||||
|
#include "warnings.h"
|
||||||
|
|
||||||
|
CCriticalSection cs_warnings;
|
||||||
|
std::string strMiscWarning;
|
||||||
|
bool fLargeWorkForkFound = false;
|
||||||
|
bool fLargeWorkInvalidChainFound = false;
|
||||||
|
|
||||||
|
void SetMiscWarning(const std::string& strWarning)
|
||||||
|
{
|
||||||
|
LOCK(cs_warnings);
|
||||||
|
strMiscWarning = strWarning;
|
||||||
|
}
|
||||||
|
|
||||||
|
void SetfLargeWorkForkFound(bool flag)
|
||||||
|
{
|
||||||
|
LOCK(cs_warnings);
|
||||||
|
fLargeWorkForkFound = flag;
|
||||||
|
}
|
||||||
|
|
||||||
|
bool GetfLargeWorkForkFound()
|
||||||
|
{
|
||||||
|
LOCK(cs_warnings);
|
||||||
|
return fLargeWorkForkFound;
|
||||||
|
}
|
||||||
|
|
||||||
|
void SetfLargeWorkInvalidChainFound(bool flag)
|
||||||
|
{
|
||||||
|
LOCK(cs_warnings);
|
||||||
|
fLargeWorkInvalidChainFound = flag;
|
||||||
|
}
|
||||||
|
|
||||||
|
bool GetfLargeWorkInvalidChainFound()
|
||||||
|
{
|
||||||
|
LOCK(cs_warnings);
|
||||||
|
return fLargeWorkInvalidChainFound;
|
||||||
|
}
|
||||||
|
|
||||||
|
std::string GetWarnings(const std::string& strFor)
|
||||||
|
{
|
||||||
|
std::string strStatusBar;
|
||||||
|
std::string strRPC;
|
||||||
|
std::string strGUI;
|
||||||
|
const std::string uiAlertSeperator = "<hr />";
|
||||||
|
|
||||||
|
LOCK(cs_warnings);
|
||||||
|
|
||||||
|
if (!CLIENT_VERSION_IS_RELEASE) {
|
||||||
|
strStatusBar = "This is a pre-release test build - use at your own risk - do not use for mining or merchant applications";
|
||||||
|
strGUI = _("This is a pre-release test build - use at your own risk - do not use for mining or merchant applications");
|
||||||
|
}
|
||||||
|
|
||||||
|
if (GetBoolArg("-testsafemode", DEFAULT_TESTSAFEMODE))
|
||||||
|
strStatusBar = strRPC = strGUI = "testsafemode enabled";
|
||||||
|
|
||||||
|
// Misc warnings like out of disk space and clock is wrong
|
||||||
|
if (strMiscWarning != "")
|
||||||
|
{
|
||||||
|
strStatusBar = strMiscWarning;
|
||||||
|
strGUI += (strGUI.empty() ? "" : uiAlertSeperator) + strMiscWarning;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (fLargeWorkForkFound)
|
||||||
|
{
|
||||||
|
strStatusBar = strRPC = "Warning: The network does not appear to fully agree! Some miners appear to be experiencing issues.";
|
||||||
|
strGUI += (strGUI.empty() ? "" : uiAlertSeperator) + _("Warning: The network does not appear to fully agree! Some miners appear to be experiencing issues.");
|
||||||
|
}
|
||||||
|
else if (fLargeWorkInvalidChainFound)
|
||||||
|
{
|
||||||
|
strStatusBar = strRPC = "Warning: We do not appear to fully agree with our peers! You may need to upgrade, or other nodes may need to upgrade.";
|
||||||
|
strGUI += (strGUI.empty() ? "" : uiAlertSeperator) + _("Warning: We do not appear to fully agree with our peers! You may need to upgrade, or other nodes may need to upgrade.");
|
||||||
|
}
|
||||||
|
|
||||||
|
if (strFor == "gui")
|
||||||
|
return strGUI;
|
||||||
|
else if (strFor == "statusbar")
|
||||||
|
return strStatusBar;
|
||||||
|
else if (strFor == "rpc")
|
||||||
|
return strRPC;
|
||||||
|
assert(!"GetWarnings(): invalid parameter");
|
||||||
|
return "error";
|
||||||
|
}
|
21
src/warnings.h
Normal file
21
src/warnings.h
Normal file
|
@ -0,0 +1,21 @@
|
||||||
|
// Copyright (c) 2009-2010 Satoshi Nakamoto
|
||||||
|
// Copyright (c) 2009-2016 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_WARNINGS_H
|
||||||
|
#define BITCOIN_WARNINGS_H
|
||||||
|
|
||||||
|
#include <stdlib.h>
|
||||||
|
#include <string>
|
||||||
|
|
||||||
|
void SetMiscWarning(const std::string& strWarning);
|
||||||
|
void SetfLargeWorkForkFound(bool flag);
|
||||||
|
bool GetfLargeWorkForkFound();
|
||||||
|
void SetfLargeWorkInvalidChainFound(bool flag);
|
||||||
|
bool GetfLargeWorkInvalidChainFound();
|
||||||
|
std::string GetWarnings(const std::string& strFor);
|
||||||
|
|
||||||
|
static const bool DEFAULT_TESTSAFEMODE = false;
|
||||||
|
|
||||||
|
#endif // BITCOIN_WARNINGS_H
|
Loading…
Reference in a new issue