diff options
author | Shauren <shauren.trinity@gmail.com> | 2014-07-23 19:04:07 +0200 |
---|---|---|
committer | Shauren <shauren.trinity@gmail.com> | 2014-07-23 19:04:07 +0200 |
commit | 42eeec12bfdf548b15a2f85d586ef037eab88a00 (patch) | |
tree | 45e1d6253fe54c661e229edc404b605c45ea19b9 /src/server/worldserver/Main.cpp | |
parent | a7476a7898e435a78201d53605b0cfedb4573a78 (diff) |
Core/Mains: Handle SIGBREAK to achieve clean shutdown when users click X button on windows
Diffstat (limited to 'src/server/worldserver/Main.cpp')
-rw-r--r-- | src/server/worldserver/Main.cpp | 15 |
1 files changed, 5 insertions, 10 deletions
diff --git a/src/server/worldserver/Main.cpp b/src/server/worldserver/Main.cpp index 0c051eae37a..87eb3bae074 100644 --- a/src/server/worldserver/Main.cpp +++ b/src/server/worldserver/Main.cpp @@ -158,6 +158,9 @@ extern int main(int argc, char** argv) // Set signal handlers (this must be done before starting io_service threads, because otherwise they would unblock and exit) boost::asio::signal_set signals(_ioService, SIGINT, SIGTERM); +#if PLATFORM == PLATFORM_WINDOWS + signals.add(SIGBREAK); +#endif signals.async_wait(SignalHandler); // Start the Boost based thread pool @@ -367,18 +370,10 @@ void WorldUpdateLoop() } } -void SignalHandler(const boost::system::error_code& error, int signalNumber) +void SignalHandler(const boost::system::error_code& error, int /*signalNumber*/) { if (!error) - { - switch (signalNumber) - { - case SIGINT: - case SIGTERM: - World::StopNow(SHUTDOWN_EXIT_CODE); - break; - } - } + World::StopNow(SHUTDOWN_EXIT_CODE); } void FreezeDetectorHandler(const boost::system::error_code& error) |