X-Git-Url: https://git.m6w6.name/?a=blobdiff_plain;f=util%2Fsignal.cc;h=8e63016fddde41a5cd140ea27d2551b1f9ce4d2b;hb=bd8a989e9f0d0c115ae771732c9199589e3043fd;hp=c28a4bc44dee04ec4941fc7cabad1008cf545526;hpb=a1f2b0b98e03369ed051b232f1fc33ed1d611b16;p=awesomized%2Flibmemcached diff --git a/util/signal.cc b/util/signal.cc index c28a4bc4..8e63016f 100644 --- a/util/signal.cc +++ b/util/signal.cc @@ -34,7 +34,7 @@ * */ -#include +#include #include #include @@ -101,6 +101,19 @@ void SignalThread::test() assert(sigismember(&set, SIGUSR2)); } +void SignalThread::sighup(signal_callback_fn* arg) +{ + _sighup= arg; +} + +void SignalThread::sighup() +{ + if (_sighup) + { + _sighup(); + } +} + SignalThread::~SignalThread() { if (not is_shutdown()) @@ -142,6 +155,10 @@ static void *sig_thread(void *arg) case SIGUSR2: break; + case SIGHUP: + context->sighup(); + break; + case SIGABRT: case SIGINT: case SIGQUIT: @@ -172,7 +189,9 @@ static void *sig_thread(void *arg) SignalThread::SignalThread(bool exit_on_signal_arg) : _exit_on_signal(exit_on_signal_arg), magic_memory(MAGIC_MEMORY), - thread(pthread_self()) + __shutdown(SHUTDOWN_RUNNING), + thread(pthread_self()), + _sighup(NULL) { pthread_mutex_init(&shutdown_mutex, NULL); sigemptyset(&set);