X-Git-Url: http://git.pk910.de/?p=NeonServV5.git;a=blobdiff_plain;f=src%2Fsignal.c;h=4e8f9a5d72f7a2a85ba77d186f549e5fd1e833a8;hp=4b13abe2b78af2d2ee4b7745ffc3e164c77debfd;hb=HEAD;hpb=0def65a9df6d9a295c064cba58af229b326f39fe diff --git a/src/signal.c b/src/signal.c index 4b13abe..4e8f9a5 100644 --- a/src/signal.c +++ b/src/signal.c @@ -1,4 +1,4 @@ -/* signal.c - NeonServ v5.3 +/* signal.c - NeonServ v5.6 * Copyright (C) 2011-2012 Philipp Kreil (pk910) * * This program is free software: you can redistribute it and/or modify @@ -18,13 +18,15 @@ #include "bots.h" #include "ChanNode.h" #include "ClientSocket.h" +#include "IOHandler.h" #include "ConfigParser.h" +#include "log.h" static void sigcrash(); static void sigexit(); void sighandler(int signum) { - putlog(LOGLEVEL_INFO, "Received Signal %d", signum); + printf_log("main", LOG_INFO, "Received Signal %d\n", signum); signal(signum, SIG_DFL); switch(signum) { case SIGABRT: @@ -48,7 +50,8 @@ void sighandler(int signum) { } static void sigcrash(int signum) { - char *coregen = ""; + char coregen[MAXLEN]; + coregen[0] = 0; char *signame; switch(signum) { case SIGSEGV: @@ -64,39 +67,30 @@ static void sigcrash(int signum) { signame = "SIGUNKNOWN"; break; } - putlog(LOGLEVEL_ERROR, "NeonServ process crashed (%s)", signame); + printf_log("main", LOG_ERROR, "NeonServ process crashed (%s)\n", signame); #ifndef WIN32 char gcore[50]; sprintf(gcore, "gcore %u", getpid()); - system(gcore); //generate core file - coregen = "core file generated."; - putlog(LOGLEVEL_ERROR | LOGLEVEL_INFO, "generated core file."); + int sysretn = system(gcore); //generate core file + sprintf(coregen, "core file generated. (%d)", sysretn); + printf_log("main", LOG_ERROR | LOG_INFO, "generated core file.\n"); #endif - char *alertchan = get_string_field("General.alertchan"); - if(alertchan) { - struct ChanNode *channel = getChanByName(alertchan); - struct ClientSocket *client; - if(channel && (client = getChannelBot(channel, 0))) { - putsock(client, "PRIVMSG %s :\00304NeonServ received signal %d (%s). %s", alertchan, signum, signame, coregen); - } - } //close all bots struct ClientSocket *bot; for(bot = getBots(SOCKET_FLAG_READY, NULL); bot; bot = getBots(SOCKET_FLAG_READY, bot)) { if((bot->flags & SOCKET_FLAG_CONNECTED)) { - close(bot->sock); - bot->flags &= SOCKET_FLAG_CONNECTED; + iohandler_close(bot->iofd); + bot->flags &= ~(SOCKET_FLAG_CONNECTED | SOCKET_FLAG_READY); + bot->iofd = NULL; } } - putlog(LOGLEVEL_INFO, "hard shutdown..."); - exit_daemon(); - usleep(1000000); + printf_log("main", LOG_INFO, "hard shutdown...\n"); + usleep(2000000); //hard restart - restart_process(); + restart_bot(1); + exit(0); } static void sigexit(int signum) { - cleanup(); - exit_daemon(); - exit(0); + stop_bot(); }