X-Git-Url: https://git.quassel-irc.org/?p=quassel.git;a=blobdiff_plain;f=src%2Fcommon%2Fquassel.cpp;h=2e1e46a5c5463a480b198d9db48009fe1f18cd99;hp=6671bc4757af375cc814add2f7d44597f3bdcce7;hb=b06a827aea68b050bf23c37e0162189a94595ee9;hpb=620cd1aa35e05099b3f84400dd33afc207c98244 diff --git a/src/common/quassel.cpp b/src/common/quassel.cpp index 6671bc47..2e1e46a5 100644 --- a/src/common/quassel.cpp +++ b/src/common/quassel.cpp @@ -30,6 +30,7 @@ #include #include +#include #include #include #include @@ -72,6 +73,11 @@ Quassel::Quassel() // We catch SIGTERM and SIGINT (caused by Ctrl+C) to graceful shutdown Quassel. signal(SIGTERM, handleSignal); signal(SIGINT, handleSignal); +#ifndef Q_OS_WIN + // SIGHUP is used to reload configuration (i.e. SSL certificates) + // Windows does not support SIGHUP + signal(SIGHUP, handleSignal); +#endif } @@ -280,7 +286,7 @@ void Quassel::setupBuildInfo() _buildInfo.plainVersionString = QString("v%1 (dist-%2)") .arg(_buildInfo.baseVersion) .arg(_buildInfo.commitHash.left(7)); - _buildInfo.fancyVersionString = QString("v%1 (dist-%2)") + _buildInfo.fancyVersionString = QString("v%1 (dist-%2)") .arg(_buildInfo.baseVersion) .arg(_buildInfo.commitHash.left(7)) .arg(_buildInfo.commitHash); @@ -298,7 +304,7 @@ void Quassel::setupBuildInfo() _buildInfo.plainVersionString = QString("v%1 (%2git-%3%4)") .arg(_buildInfo.baseVersion, distance, rx.cap(3), rx.cap(4)); if (!_buildInfo.commitHash.isEmpty()) { - _buildInfo.fancyVersionString = QString("v%1 (%2git-%3%4)") + _buildInfo.fancyVersionString = QString("v%1 (%2git-%3%4)") .arg(_buildInfo.baseVersion, distance, rx.cap(3), rx.cap(4), _buildInfo.commitHash); } } @@ -323,6 +329,20 @@ void Quassel::handleSignal(int sig) else QCoreApplication::quit(); break; +#ifndef Q_OS_WIN +// Windows does not support SIGHUP + case SIGHUP: + // Most applications use this as the 'configuration reload' command, e.g. nginx uses it for + // graceful reloading of processes. + if (_instance) { + // If the instance exists, reload the configuration + quInfo() << "Caught signal" << SIGHUP <<"- reloading configuration"; + if (_instance->reloadConfig()) { + quInfo() << "Successfully reloaded configuration"; + } + } + break; +#endif case SIGABRT: case SIGSEGV: #ifndef Q_OS_WIN