X-Git-Url: https://arthur.barton.de/cgi-bin/gitweb.cgi?a=blobdiff_plain;f=src%2Fngircd%2Fngircd.c;h=1eb5e5479fdbdbf9928dd36fd4c9abeecdfaa1c8;hb=6fd126d6f42198a47df23459c9346a3346f9def0;hp=3710c4de80a3ac882dbff9f338b0989f8a19682d;hpb=ff280ce496d37978ddd912ff2fbe43d391c28463;p=ngircd-alex.git diff --git a/src/ngircd/ngircd.c b/src/ngircd/ngircd.c index 3710c4de..1eb5e547 100644 --- a/src/ngircd/ngircd.c +++ b/src/ngircd/ngircd.c @@ -9,11 +9,30 @@ * 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.6 2001/12/12 23:30:42 alex Exp $ + * $Id: ngircd.c,v 1.12 2001/12/29 03:07:36 alex Exp $ * * ngircd.c: Hier beginnt alles ;-) * * $Log: ngircd.c,v $ + * Revision 1.12 2001/12/29 03:07:36 alex + * - einige Loglevel geaendert. + * + * Revision 1.11 2001/12/26 14:45:37 alex + * - "Code Cleanups". + * + * 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. @@ -34,7 +53,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. */ @@ -50,9 +69,13 @@ #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" @@ -73,21 +96,30 @@ GLOBAL INT main( INT argc, CONST CHAR *argv[] ) /* Module initialisieren */ Log_Init( ); Conf_Init( ); + Parse_Init( ); + IRC_Init( ); + Channel_Init( ); + Client_Init( ); Conn_Init( ); + /* Signal-Handler initialisieren */ Initialize_Signal_Handler( ); - if( ! Conn_New_Listener( 6668 )) exit( 1 ); - + if( ! Conn_NewListener( 6668 )) exit( 1 ); + if( ! Conn_NewListener( 6669 )) Log( LOG_WARNING, "Can't create second listening socket!" ); /* Hauptschleife */ while( ! NGIRCd_Quit ) { - Conn_Handler( ); + Conn_Handler( 5 ); } /* Alles abmelden */ Conn_Exit( ); + Client_Exit( ); + Channel_Exit( ); + IRC_Exit( ); + Parse_Exit( ); Conf_Exit( ); Log_Exit( ); @@ -97,22 +129,23 @@ GLOBAL INT main( INT argc, CONST CHAR *argv[] ) LOCAL VOID Initialize_Signal_Handler( VOID ) { - /* Signal-Handler initialisieren: Strukturen anlegen und einhaengen :-) */ + /* Signal-Handler initialisieren: einige Signale + * werden ignoriert, andere speziell behandelt. */ struct sigaction saction; /* 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 */ @@ -128,7 +161,7 @@ LOCAL VOID Signal_Handler( INT Signal ) case SIGINT: case SIGQUIT: /* wir soll(t)en uns wohl beenden ... */ - Log( LOG_NOTICE, "Got signal %d, terminating now ...", Signal ); + Log( LOG_WARNING, "Got signal %d, terminating now ...", Signal ); NGIRCd_Quit = TRUE; break; default: