aboutsummaryrefslogtreecommitdiff
path: root/src/daemon/daemon.cpp
diff options
context:
space:
mode:
authorRiccardo Spagni <ric@spagni.net>2015-06-14 13:09:47 +0200
committerRiccardo Spagni <ric@spagni.net>2015-06-14 13:09:53 +0200
commit1595187ae2d97e0720ab2ac309f9b4784137d79f (patch)
treeb723732ed3c3d44b818360a8f177a8c728969039 /src/daemon/daemon.cpp
parentMerge pull request #318 (diff)
parentdaemon: fix an exit crash (diff)
downloadmonero-1595187ae2d97e0720ab2ac309f9b4784137d79f.tar.xz
Merge pull request #320
f9b361b daemon: fix an exit crash (moneromooo-monero)
Diffstat (limited to 'src/daemon/daemon.cpp')
-rw-r--r--src/daemon/daemon.cpp11
1 files changed, 10 insertions, 1 deletions
diff --git a/src/daemon/daemon.cpp b/src/daemon/daemon.cpp
index 2bd592611..6a5943c8b 100644
--- a/src/daemon/daemon.cpp
+++ b/src/daemon/daemon.cpp
@@ -126,7 +126,7 @@ bool t_daemon::run(bool interactive)
if (interactive)
{
rpc_commands = new daemonize::t_command_server(0, 0, false, mp_internals->rpc.get_server());
- rpc_commands->start_handling(std::bind(&daemonize::t_daemon::stop, this));
+ rpc_commands->start_handling(std::bind(&daemonize::t_daemon::stop_p2p, this));
}
mp_internals->p2p.run(); // blocks until p2p goes down
@@ -163,4 +163,13 @@ void t_daemon::stop()
mp_internals.reset(nullptr); // Ensure resources are cleaned up before we return
}
+void t_daemon::stop_p2p()
+{
+ if (nullptr == mp_internals)
+ {
+ throw std::runtime_error{"Can't send stop signal to a stopped daemon"};
+ }
+ mp_internals->p2p.get().send_stop_signal();
+}
+
} // namespace daemonize