mirror of
https://github.com/bitcoin/bitcoin.git
synced 2025-01-26 19:23:26 -03:00
Merge #13634: ui: Compile boost::signals2 only once
fa5ce27385
ui: Compile boost:signals2 only once (MarcoFalke)
Pull request description:
ui is one of the modules that poison other modules with `boost/signals2` headers. This moves the include to the cpp file and uses a forward declaration in the header.
Locally this speeds up the incremental build (building everything that uses the ui module) with gcc by ~5% for me. Gcc uses ~5% less memory.
Would be nice if someone could verify the numbers roughly.
I presume the improvements will be more pronounced if the other models would stop exposing the boost header as well.
Tree-SHA512: 078360eba330ddbca4268bd8552927eae242a239e18dfded25ec20be72650a68cd83af7ac160690249b943d33ae35d15df1313f1f60a0c28b9526853aa7d1e40
This commit is contained in:
commit
ddc3ec92b0
5 changed files with 95 additions and 34 deletions
12
src/init.cpp
12
src/init.cpp
|
@ -328,12 +328,12 @@ static void registerSignalHandler(int signal, void(*handler)(int))
|
||||||
|
|
||||||
static void OnRPCStarted()
|
static void OnRPCStarted()
|
||||||
{
|
{
|
||||||
uiInterface.NotifyBlockTip.connect(&RPCNotifyBlockChange);
|
uiInterface.NotifyBlockTip_connect(&RPCNotifyBlockChange);
|
||||||
}
|
}
|
||||||
|
|
||||||
static void OnRPCStopped()
|
static void OnRPCStopped()
|
||||||
{
|
{
|
||||||
uiInterface.NotifyBlockTip.disconnect(&RPCNotifyBlockChange);
|
uiInterface.NotifyBlockTip_disconnect(&RPCNotifyBlockChange);
|
||||||
RPCNotifyBlockChange(false, nullptr);
|
RPCNotifyBlockChange(false, nullptr);
|
||||||
g_best_block_cv.notify_all();
|
g_best_block_cv.notify_all();
|
||||||
LogPrint(BCLog::RPC, "RPC stopped.\n");
|
LogPrint(BCLog::RPC, "RPC stopped.\n");
|
||||||
|
@ -1287,7 +1287,7 @@ bool AppInitMain()
|
||||||
*/
|
*/
|
||||||
if (gArgs.GetBoolArg("-server", false))
|
if (gArgs.GetBoolArg("-server", false))
|
||||||
{
|
{
|
||||||
uiInterface.InitMessage.connect(SetRPCWarmupStatus);
|
uiInterface.InitMessage_connect(SetRPCWarmupStatus);
|
||||||
if (!AppInitServers())
|
if (!AppInitServers())
|
||||||
return InitError(_("Unable to start HTTP server. See debug log for details."));
|
return InitError(_("Unable to start HTTP server. See debug log for details."));
|
||||||
}
|
}
|
||||||
|
@ -1644,13 +1644,13 @@ bool AppInitMain()
|
||||||
// Either install a handler to notify us when genesis activates, or set fHaveGenesis directly.
|
// Either install a handler to notify us when genesis activates, or set fHaveGenesis directly.
|
||||||
// No locking, as this happens before any background thread is started.
|
// No locking, as this happens before any background thread is started.
|
||||||
if (chainActive.Tip() == nullptr) {
|
if (chainActive.Tip() == nullptr) {
|
||||||
uiInterface.NotifyBlockTip.connect(BlockNotifyGenesisWait);
|
uiInterface.NotifyBlockTip_connect(BlockNotifyGenesisWait);
|
||||||
} else {
|
} else {
|
||||||
fHaveGenesis = true;
|
fHaveGenesis = true;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (gArgs.IsArgSet("-blocknotify"))
|
if (gArgs.IsArgSet("-blocknotify"))
|
||||||
uiInterface.NotifyBlockTip.connect(BlockNotifyCallback);
|
uiInterface.NotifyBlockTip_connect(BlockNotifyCallback);
|
||||||
|
|
||||||
std::vector<fs::path> vImportFiles;
|
std::vector<fs::path> vImportFiles;
|
||||||
for (const std::string& strFile : gArgs.GetArgs("-loadblock")) {
|
for (const std::string& strFile : gArgs.GetArgs("-loadblock")) {
|
||||||
|
@ -1668,7 +1668,7 @@ bool AppInitMain()
|
||||||
while (!fHaveGenesis && !ShutdownRequested()) {
|
while (!fHaveGenesis && !ShutdownRequested()) {
|
||||||
condvar_GenesisWait.wait_for(lock, std::chrono::milliseconds(500));
|
condvar_GenesisWait.wait_for(lock, std::chrono::milliseconds(500));
|
||||||
}
|
}
|
||||||
uiInterface.NotifyBlockTip.disconnect(BlockNotifyGenesisWait);
|
uiInterface.NotifyBlockTip_disconnect(BlockNotifyGenesisWait);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (ShutdownRequested()) {
|
if (ShutdownRequested()) {
|
||||||
|
|
|
@ -233,44 +233,44 @@ class NodeImpl : public Node
|
||||||
}
|
}
|
||||||
std::unique_ptr<Handler> handleInitMessage(InitMessageFn fn) override
|
std::unique_ptr<Handler> handleInitMessage(InitMessageFn fn) override
|
||||||
{
|
{
|
||||||
return MakeHandler(::uiInterface.InitMessage.connect(fn));
|
return MakeHandler(::uiInterface.InitMessage_connect(fn));
|
||||||
}
|
}
|
||||||
std::unique_ptr<Handler> handleMessageBox(MessageBoxFn fn) override
|
std::unique_ptr<Handler> handleMessageBox(MessageBoxFn fn) override
|
||||||
{
|
{
|
||||||
return MakeHandler(::uiInterface.ThreadSafeMessageBox.connect(fn));
|
return MakeHandler(::uiInterface.ThreadSafeMessageBox_connect(fn));
|
||||||
}
|
}
|
||||||
std::unique_ptr<Handler> handleQuestion(QuestionFn fn) override
|
std::unique_ptr<Handler> handleQuestion(QuestionFn fn) override
|
||||||
{
|
{
|
||||||
return MakeHandler(::uiInterface.ThreadSafeQuestion.connect(fn));
|
return MakeHandler(::uiInterface.ThreadSafeQuestion_connect(fn));
|
||||||
}
|
}
|
||||||
std::unique_ptr<Handler> handleShowProgress(ShowProgressFn fn) override
|
std::unique_ptr<Handler> handleShowProgress(ShowProgressFn fn) override
|
||||||
{
|
{
|
||||||
return MakeHandler(::uiInterface.ShowProgress.connect(fn));
|
return MakeHandler(::uiInterface.ShowProgress_connect(fn));
|
||||||
}
|
}
|
||||||
std::unique_ptr<Handler> handleLoadWallet(LoadWalletFn fn) override
|
std::unique_ptr<Handler> handleLoadWallet(LoadWalletFn fn) override
|
||||||
{
|
{
|
||||||
CHECK_WALLET(
|
CHECK_WALLET(
|
||||||
return MakeHandler(::uiInterface.LoadWallet.connect([fn](std::shared_ptr<CWallet> wallet) { fn(MakeWallet(wallet)); })));
|
return MakeHandler(::uiInterface.LoadWallet_connect([fn](std::shared_ptr<CWallet> wallet) { fn(MakeWallet(wallet)); })));
|
||||||
}
|
}
|
||||||
std::unique_ptr<Handler> handleNotifyNumConnectionsChanged(NotifyNumConnectionsChangedFn fn) override
|
std::unique_ptr<Handler> handleNotifyNumConnectionsChanged(NotifyNumConnectionsChangedFn fn) override
|
||||||
{
|
{
|
||||||
return MakeHandler(::uiInterface.NotifyNumConnectionsChanged.connect(fn));
|
return MakeHandler(::uiInterface.NotifyNumConnectionsChanged_connect(fn));
|
||||||
}
|
}
|
||||||
std::unique_ptr<Handler> handleNotifyNetworkActiveChanged(NotifyNetworkActiveChangedFn fn) override
|
std::unique_ptr<Handler> handleNotifyNetworkActiveChanged(NotifyNetworkActiveChangedFn fn) override
|
||||||
{
|
{
|
||||||
return MakeHandler(::uiInterface.NotifyNetworkActiveChanged.connect(fn));
|
return MakeHandler(::uiInterface.NotifyNetworkActiveChanged_connect(fn));
|
||||||
}
|
}
|
||||||
std::unique_ptr<Handler> handleNotifyAlertChanged(NotifyAlertChangedFn fn) override
|
std::unique_ptr<Handler> handleNotifyAlertChanged(NotifyAlertChangedFn fn) override
|
||||||
{
|
{
|
||||||
return MakeHandler(::uiInterface.NotifyAlertChanged.connect(fn));
|
return MakeHandler(::uiInterface.NotifyAlertChanged_connect(fn));
|
||||||
}
|
}
|
||||||
std::unique_ptr<Handler> handleBannedListChanged(BannedListChangedFn fn) override
|
std::unique_ptr<Handler> handleBannedListChanged(BannedListChangedFn fn) override
|
||||||
{
|
{
|
||||||
return MakeHandler(::uiInterface.BannedListChanged.connect(fn));
|
return MakeHandler(::uiInterface.BannedListChanged_connect(fn));
|
||||||
}
|
}
|
||||||
std::unique_ptr<Handler> handleNotifyBlockTip(NotifyBlockTipFn fn) override
|
std::unique_ptr<Handler> handleNotifyBlockTip(NotifyBlockTipFn fn) override
|
||||||
{
|
{
|
||||||
return MakeHandler(::uiInterface.NotifyBlockTip.connect([fn](bool initial_download, const CBlockIndex* block) {
|
return MakeHandler(::uiInterface.NotifyBlockTip_connect([fn](bool initial_download, const CBlockIndex* block) {
|
||||||
fn(initial_download, block->nHeight, block->GetBlockTime(),
|
fn(initial_download, block->nHeight, block->GetBlockTime(),
|
||||||
GuessVerificationProgress(Params().TxData(), block));
|
GuessVerificationProgress(Params().TxData(), block));
|
||||||
}));
|
}));
|
||||||
|
@ -278,7 +278,7 @@ class NodeImpl : public Node
|
||||||
std::unique_ptr<Handler> handleNotifyHeaderTip(NotifyHeaderTipFn fn) override
|
std::unique_ptr<Handler> handleNotifyHeaderTip(NotifyHeaderTipFn fn) override
|
||||||
{
|
{
|
||||||
return MakeHandler(
|
return MakeHandler(
|
||||||
::uiInterface.NotifyHeaderTip.connect([fn](bool initial_download, const CBlockIndex* block) {
|
::uiInterface.NotifyHeaderTip_connect([fn](bool initial_download, const CBlockIndex* block) {
|
||||||
fn(initial_download, block->nHeight, block->GetBlockTime(),
|
fn(initial_download, block->nHeight, block->GetBlockTime(),
|
||||||
GuessVerificationProgress(Params().TxData(), block));
|
GuessVerificationProgress(Params().TxData(), block));
|
||||||
}));
|
}));
|
||||||
|
|
|
@ -52,7 +52,7 @@ static void noui_InitMessage(const std::string& message)
|
||||||
void noui_connect()
|
void noui_connect()
|
||||||
{
|
{
|
||||||
// Connect bitcoind signal handlers
|
// Connect bitcoind signal handlers
|
||||||
uiInterface.ThreadSafeMessageBox.connect(noui_ThreadSafeMessageBox);
|
uiInterface.ThreadSafeMessageBox_connect(noui_ThreadSafeMessageBox);
|
||||||
uiInterface.ThreadSafeQuestion.connect(noui_ThreadSafeQuestion);
|
uiInterface.ThreadSafeQuestion_connect(noui_ThreadSafeQuestion);
|
||||||
uiInterface.InitMessage.connect(noui_InitMessage);
|
uiInterface.InitMessage_connect(noui_InitMessage);
|
||||||
}
|
}
|
||||||
|
|
|
@ -5,8 +5,60 @@
|
||||||
#include <ui_interface.h>
|
#include <ui_interface.h>
|
||||||
#include <util.h>
|
#include <util.h>
|
||||||
|
|
||||||
|
#include <boost/signals2/last_value.hpp>
|
||||||
|
#include <boost/signals2/signal.hpp>
|
||||||
|
|
||||||
CClientUIInterface uiInterface;
|
CClientUIInterface uiInterface;
|
||||||
|
|
||||||
|
struct UISignals {
|
||||||
|
boost::signals2::signal<CClientUIInterface::ThreadSafeMessageBoxSig, boost::signals2::last_value<bool>> ThreadSafeMessageBox;
|
||||||
|
boost::signals2::signal<CClientUIInterface::ThreadSafeQuestionSig, boost::signals2::last_value<bool>> ThreadSafeQuestion;
|
||||||
|
boost::signals2::signal<CClientUIInterface::InitMessageSig> InitMessage;
|
||||||
|
boost::signals2::signal<CClientUIInterface::NotifyNumConnectionsChangedSig> NotifyNumConnectionsChanged;
|
||||||
|
boost::signals2::signal<CClientUIInterface::NotifyNetworkActiveChangedSig> NotifyNetworkActiveChanged;
|
||||||
|
boost::signals2::signal<CClientUIInterface::NotifyAlertChangedSig> NotifyAlertChanged;
|
||||||
|
boost::signals2::signal<CClientUIInterface::LoadWalletSig> LoadWallet;
|
||||||
|
boost::signals2::signal<CClientUIInterface::ShowProgressSig> ShowProgress;
|
||||||
|
boost::signals2::signal<CClientUIInterface::NotifyBlockTipSig> NotifyBlockTip;
|
||||||
|
boost::signals2::signal<CClientUIInterface::NotifyHeaderTipSig> NotifyHeaderTip;
|
||||||
|
boost::signals2::signal<CClientUIInterface::BannedListChangedSig> BannedListChanged;
|
||||||
|
} g_ui_signals;
|
||||||
|
|
||||||
|
#define ADD_SIGNALS_IMPL_WRAPPER(signal_name) \
|
||||||
|
boost::signals2::connection CClientUIInterface::signal_name##_connect(std::function<signal_name##Sig> fn) \
|
||||||
|
{ \
|
||||||
|
return g_ui_signals.signal_name.connect(fn); \
|
||||||
|
} \
|
||||||
|
void CClientUIInterface::signal_name##_disconnect(std::function<signal_name##Sig> fn) \
|
||||||
|
{ \
|
||||||
|
return g_ui_signals.signal_name.disconnect(&fn); \
|
||||||
|
}
|
||||||
|
|
||||||
|
ADD_SIGNALS_IMPL_WRAPPER(ThreadSafeMessageBox);
|
||||||
|
ADD_SIGNALS_IMPL_WRAPPER(ThreadSafeQuestion);
|
||||||
|
ADD_SIGNALS_IMPL_WRAPPER(InitMessage);
|
||||||
|
ADD_SIGNALS_IMPL_WRAPPER(NotifyNumConnectionsChanged);
|
||||||
|
ADD_SIGNALS_IMPL_WRAPPER(NotifyNetworkActiveChanged);
|
||||||
|
ADD_SIGNALS_IMPL_WRAPPER(NotifyAlertChanged);
|
||||||
|
ADD_SIGNALS_IMPL_WRAPPER(LoadWallet);
|
||||||
|
ADD_SIGNALS_IMPL_WRAPPER(ShowProgress);
|
||||||
|
ADD_SIGNALS_IMPL_WRAPPER(NotifyBlockTip);
|
||||||
|
ADD_SIGNALS_IMPL_WRAPPER(NotifyHeaderTip);
|
||||||
|
ADD_SIGNALS_IMPL_WRAPPER(BannedListChanged);
|
||||||
|
|
||||||
|
bool CClientUIInterface::ThreadSafeMessageBox(const std::string& message, const std::string& caption, unsigned int style) { return g_ui_signals.ThreadSafeMessageBox(message, caption, style); }
|
||||||
|
bool CClientUIInterface::ThreadSafeQuestion(const std::string& message, const std::string& non_interactive_message, const std::string& caption, unsigned int style) { return g_ui_signals.ThreadSafeQuestion(message, non_interactive_message, caption, style); }
|
||||||
|
void CClientUIInterface::InitMessage(const std::string& message) { return g_ui_signals.InitMessage(message); }
|
||||||
|
void CClientUIInterface::NotifyNumConnectionsChanged(int newNumConnections) { return g_ui_signals.NotifyNumConnectionsChanged(newNumConnections); }
|
||||||
|
void CClientUIInterface::NotifyNetworkActiveChanged(bool networkActive) { return g_ui_signals.NotifyNetworkActiveChanged(networkActive); }
|
||||||
|
void CClientUIInterface::NotifyAlertChanged() { return g_ui_signals.NotifyAlertChanged(); }
|
||||||
|
void CClientUIInterface::LoadWallet(std::shared_ptr<CWallet> wallet) { return g_ui_signals.LoadWallet(wallet); }
|
||||||
|
void CClientUIInterface::ShowProgress(const std::string& title, int nProgress, bool resume_possible) { return g_ui_signals.ShowProgress(title, nProgress, resume_possible); }
|
||||||
|
void CClientUIInterface::NotifyBlockTip(bool b, const CBlockIndex* i) { return g_ui_signals.NotifyBlockTip(b, i); }
|
||||||
|
void CClientUIInterface::NotifyHeaderTip(bool b, const CBlockIndex* i) { return g_ui_signals.NotifyHeaderTip(b, i); }
|
||||||
|
void CClientUIInterface::BannedListChanged() { return g_ui_signals.BannedListChanged(); }
|
||||||
|
|
||||||
|
|
||||||
bool InitError(const std::string& str)
|
bool InitError(const std::string& str)
|
||||||
{
|
{
|
||||||
uiInterface.ThreadSafeMessageBox(str, "", CClientUIInterface::MSG_ERROR);
|
uiInterface.ThreadSafeMessageBox(str, "", CClientUIInterface::MSG_ERROR);
|
||||||
|
|
|
@ -6,15 +6,18 @@
|
||||||
#ifndef BITCOIN_UI_INTERFACE_H
|
#ifndef BITCOIN_UI_INTERFACE_H
|
||||||
#define BITCOIN_UI_INTERFACE_H
|
#define BITCOIN_UI_INTERFACE_H
|
||||||
|
|
||||||
|
#include <functional>
|
||||||
#include <memory>
|
#include <memory>
|
||||||
#include <stdint.h>
|
#include <stdint.h>
|
||||||
#include <string>
|
#include <string>
|
||||||
|
|
||||||
#include <boost/signals2/last_value.hpp>
|
|
||||||
#include <boost/signals2/signal.hpp>
|
|
||||||
|
|
||||||
class CWallet;
|
class CWallet;
|
||||||
class CBlockIndex;
|
class CBlockIndex;
|
||||||
|
namespace boost {
|
||||||
|
namespace signals2 {
|
||||||
|
class connection;
|
||||||
|
}
|
||||||
|
} // namespace boost
|
||||||
|
|
||||||
/** General change type (added, updated, removed). */
|
/** General change type (added, updated, removed). */
|
||||||
enum ChangeType
|
enum ChangeType
|
||||||
|
@ -72,43 +75,49 @@ public:
|
||||||
MSG_ERROR = (ICON_ERROR | BTN_OK | MODAL)
|
MSG_ERROR = (ICON_ERROR | BTN_OK | MODAL)
|
||||||
};
|
};
|
||||||
|
|
||||||
|
#define ADD_SIGNALS_DECL_WRAPPER(signal_name, rtype, args...) \
|
||||||
|
rtype signal_name(args); \
|
||||||
|
using signal_name##Sig = rtype(args); \
|
||||||
|
boost::signals2::connection signal_name##_connect(std::function<signal_name##Sig> fn); \
|
||||||
|
void signal_name##_disconnect(std::function<signal_name##Sig> fn);
|
||||||
|
|
||||||
/** Show message box. */
|
/** Show message box. */
|
||||||
boost::signals2::signal<bool (const std::string& message, const std::string& caption, unsigned int style), boost::signals2::last_value<bool> > ThreadSafeMessageBox;
|
ADD_SIGNALS_DECL_WRAPPER(ThreadSafeMessageBox, bool, const std::string& message, const std::string& caption, unsigned int style);
|
||||||
|
|
||||||
/** If possible, ask the user a question. If not, falls back to ThreadSafeMessageBox(noninteractive_message, caption, style) and returns false. */
|
/** If possible, ask the user a question. If not, falls back to ThreadSafeMessageBox(noninteractive_message, caption, style) and returns false. */
|
||||||
boost::signals2::signal<bool (const std::string& message, const std::string& noninteractive_message, const std::string& caption, unsigned int style), boost::signals2::last_value<bool> > ThreadSafeQuestion;
|
ADD_SIGNALS_DECL_WRAPPER(ThreadSafeQuestion, bool, const std::string& message, const std::string& noninteractive_message, const std::string& caption, unsigned int style);
|
||||||
|
|
||||||
/** Progress message during initialization. */
|
/** Progress message during initialization. */
|
||||||
boost::signals2::signal<void (const std::string &message)> InitMessage;
|
ADD_SIGNALS_DECL_WRAPPER(InitMessage, void, const std::string& message);
|
||||||
|
|
||||||
/** Number of network connections changed. */
|
/** Number of network connections changed. */
|
||||||
boost::signals2::signal<void (int newNumConnections)> NotifyNumConnectionsChanged;
|
ADD_SIGNALS_DECL_WRAPPER(NotifyNumConnectionsChanged, void, int newNumConnections);
|
||||||
|
|
||||||
/** Network activity state changed. */
|
/** Network activity state changed. */
|
||||||
boost::signals2::signal<void (bool networkActive)> NotifyNetworkActiveChanged;
|
ADD_SIGNALS_DECL_WRAPPER(NotifyNetworkActiveChanged, void, bool networkActive);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Status bar alerts changed.
|
* Status bar alerts changed.
|
||||||
*/
|
*/
|
||||||
boost::signals2::signal<void ()> NotifyAlertChanged;
|
ADD_SIGNALS_DECL_WRAPPER(NotifyAlertChanged, void, );
|
||||||
|
|
||||||
/** A wallet has been loaded. */
|
/** A wallet has been loaded. */
|
||||||
boost::signals2::signal<void (std::shared_ptr<CWallet> wallet)> LoadWallet;
|
ADD_SIGNALS_DECL_WRAPPER(LoadWallet, void, std::shared_ptr<CWallet> wallet);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Show progress e.g. for verifychain.
|
* Show progress e.g. for verifychain.
|
||||||
* resume_possible indicates shutting down now will result in the current progress action resuming upon restart.
|
* resume_possible indicates shutting down now will result in the current progress action resuming upon restart.
|
||||||
*/
|
*/
|
||||||
boost::signals2::signal<void (const std::string &title, int nProgress, bool resume_possible)> ShowProgress;
|
ADD_SIGNALS_DECL_WRAPPER(ShowProgress, void, const std::string& title, int nProgress, bool resume_possible);
|
||||||
|
|
||||||
/** New block has been accepted */
|
/** New block has been accepted */
|
||||||
boost::signals2::signal<void (bool, const CBlockIndex *)> NotifyBlockTip;
|
ADD_SIGNALS_DECL_WRAPPER(NotifyBlockTip, void, bool, const CBlockIndex*);
|
||||||
|
|
||||||
/** Best header has changed */
|
/** Best header has changed */
|
||||||
boost::signals2::signal<void (bool, const CBlockIndex *)> NotifyHeaderTip;
|
ADD_SIGNALS_DECL_WRAPPER(NotifyHeaderTip, void, bool, const CBlockIndex*);
|
||||||
|
|
||||||
/** Banlist did change. */
|
/** Banlist did change. */
|
||||||
boost::signals2::signal<void (void)> BannedListChanged;
|
ADD_SIGNALS_DECL_WRAPPER(BannedListChanged, void, void);
|
||||||
};
|
};
|
||||||
|
|
||||||
/** Show warning message **/
|
/** Show warning message **/
|
||||||
|
|
Loading…
Add table
Reference in a new issue