X-Git-Url: https://arthur.barton.de/cgi-bin/gitweb.cgi?a=blobdiff_plain;f=src%2Fngircd%2Fngircd.c;h=73d4ca990acc408ca3c1c287f8f3a2c2c35d8462;hb=78a6e3c67136e32ba71abe58a7f755400db595e8;hp=3710c4de80a3ac882dbff9f338b0989f8a19682d;hpb=ff280ce496d37978ddd912ff2fbe43d391c28463;p=ngircd-alex.git diff --git a/src/ngircd/ngircd.c b/src/ngircd/ngircd.c index 3710c4de..73d4ca99 100644 --- a/src/ngircd/ngircd.c +++ b/src/ngircd/ngircd.c @@ -9,11 +9,24 @@ * 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.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. @@ -34,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. */ @@ -50,9 +63,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 +90,29 @@ GLOBAL INT main( INT argc, CONST CHAR *argv[] ) /* 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( ! NGIRCd_Quit ) { - Conn_Handler( ); + Conn_Handler( 5 ); } /* Alles abmelden */ Conn_Exit( ); + Client_Exit( ); + Channel_Exit( ); + IRC_Exit( ); + Parse_Exit( ); Conf_Exit( ); Log_Exit( ); @@ -103,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 */