X-Git-Url: https://arthur.barton.de/cgi-bin/gitweb.cgi?a=blobdiff_plain;f=src%2Fngircd%2Fngircd.c;h=73d4ca990acc408ca3c1c287f8f3a2c2c35d8462;hb=0dc0308d234ba463f7449d17c88f114ca9f5185b;hp=308643592f8be3b29a6671239c5aa8d23ef8ddb2;hpb=418add93da4266b0dc62c7587eb8a91683d45088;p=ngircd-alex.git diff --git a/src/ngircd/ngircd.c b/src/ngircd/ngircd.c index 30864359..73d4ca99 100644 --- a/src/ngircd/ngircd.c +++ b/src/ngircd/ngircd.c @@ -9,11 +9,28 @@ * Naehere Informationen entnehmen Sie bitter der Datei COPYING. Eine Liste * der an comBase beteiligten Autoren finden Sie in der Datei AUTHORS. * - * $Id: ngircd.c,v 1.5 2001/12/12 17:21:21 alex Exp $ + * $Id: ngircd.c,v 1.10 2001/12/24 01:34:38 alex Exp $ * * ngircd.c: Hier beginnt alles ;-) * * $Log: ngircd.c,v $ + * Revision 1.10 2001/12/24 01:34:38 alex + * - Signal-Handler aufgeraeumt; u.a. SIGPIPE wird nun korrekt ignoriert. + * + * Revision 1.9 2001/12/21 22:24:50 alex + * - neues Modul "parse" wird initialisiert und abgemeldet. + * + * Revision 1.8 2001/12/14 08:15:26 alex + * - neue Module (irc, client, channel) werden an- und abgemeldet. + * - zweiter Listen-Socket wird zu Testzwecken konfiguriert. + * + * Revision 1.7 2001/12/13 01:31:46 alex + * - Conn_Handler() wird nun mit einem Timeout aufgerufen. + * + * Revision 1.6 2001/12/12 23:30:42 alex + * - Log-Meldungen an syslog angepasst. + * - NGIRCd_Quit ist nun das Flag zum Beenden des ngircd. + * * Revision 1.5 2001/12/12 17:21:21 alex * - mehr Unterfunktionen eingebaut, Modul besser strukturiert & dokumentiert. * - Anpassungen an neue Module. @@ -30,7 +47,7 @@ * - Test auf stdint.h (HAVE_STDINT_H) hinzugefuegt. * * Revision 1.1.1.1 2001/12/11 21:53:04 alex - * Imported sources to CVS. + * - Imported sources to CVS. */ @@ -46,17 +63,18 @@ #include #include +#include "channel.h" +#include "client.h" #include "conf.h" #include "conn.h" +#include "irc.h" #include "log.h" +#include "parse.h" #include #include "ngircd.h" -BOOLEAN do_quit_now = FALSE; /* TRUE: Hauptschleife beenden */ - - LOCAL VOID Initialize_Signal_Handler( VOID ); LOCAL VOID Signal_Handler( INT Signal ); @@ -66,24 +84,35 @@ GLOBAL INT main( INT argc, CONST CHAR *argv[] ) /* Datentypen der portab-Library ueberpruefen */ portab_check_types( ); + /* Globale Variablen initialisieren */ + NGIRCd_Quit = FALSE; + /* Module initialisieren */ Log_Init( ); Conf_Init( ); + Parse_Init( ); + IRC_Init( ); + Channel_Init( ); + Client_Init( ); Conn_Init( ); Initialize_Signal_Handler( ); if( ! Conn_New_Listener( 6668 )) exit( 1 ); - + if( ! Conn_New_Listener( 6669 )) Log( LOG_WARNING, "Can't create second listening socket!" ); /* Hauptschleife */ - while( ! do_quit_now ) + while( ! NGIRCd_Quit ) { - Conn_Handler( ); + Conn_Handler( 5 ); } /* Alles abmelden */ Conn_Exit( ); + Client_Exit( ); + Channel_Exit( ); + IRC_Exit( ); + Parse_Exit( ); Conf_Exit( ); Log_Exit( ); @@ -99,16 +128,16 @@ LOCAL VOID Initialize_Signal_Handler( VOID ) /* Signal-Struktur initialisieren */ memset( &saction, 0, sizeof( saction )); - saction.sa_handler = Signal_Handler; /* Signal-Handler einhaengen */ - sigaction( SIGALRM, &saction, NULL ); - sigaction( SIGHUP, &saction, NULL); + saction.sa_handler = Signal_Handler; sigaction( SIGINT, &saction, NULL ); sigaction( SIGQUIT, &saction, NULL ); sigaction( SIGTERM, &saction, NULL); - sigaction( SIGUSR1, &saction, NULL); - sigaction( SIGUSR2, &saction, NULL); + + /* einige Signale ignorieren */ + saction.sa_handler = SIG_IGN; + sigaction( SIGPIPE, &saction, NULL ); } /* Initialize_Signal_Handler */ @@ -124,12 +153,12 @@ LOCAL VOID Signal_Handler( INT Signal ) case SIGINT: case SIGQUIT: /* wir soll(t)en uns wohl beenden ... */ - Log( LOG_WARN, "Got signal %d, terminating now ...", Signal ); - do_quit_now = TRUE; + Log( LOG_NOTICE, "Got signal %d, terminating now ...", Signal ); + NGIRCd_Quit = TRUE; break; default: /* unbekanntes bzw. unbehandeltes Signal */ - Log( LOG_WARN, "Got signal %d! Ignored.", Signal ); + Log( LOG_NOTICE, "Got signal %d! Ignored.", Signal ); } } /* Signal_Handler */