X-Git-Url: https://arthur.barton.de/cgi-bin/gitweb.cgi?p=ngircd-alex.git;a=blobdiff_plain;f=src%2Fngircd%2Fngircd.c;h=dc5d58931610160c2798fe02378388dc16f2560a;hp=73d4ca990acc408ca3c1c287f8f3a2c2c35d8462;hb=71f297097b0ad1ff09040dd35abf4d9931ce63e7;hpb=eb952e35ccf28aa4d60a944d5cb179025624fc46 diff --git a/src/ngircd/ngircd.c b/src/ngircd/ngircd.c index 73d4ca99..dc5d5893 100644 --- a/src/ngircd/ngircd.c +++ b/src/ngircd/ngircd.c @@ -1,19 +1,39 @@ /* * ngIRCd -- The Next Generation IRC Daemon - * Copyright (c)2001 by Alexander Barton (alex@barton.de) + * Copyright (c)2001,2002 by Alexander Barton (alex@barton.de) * * Dieses Programm ist freie Software. Sie koennen es unter den Bedingungen * der GNU General Public License (GPL), wie von der Free Software Foundation * herausgegeben, weitergeben und/oder modifizieren, entweder unter Version 2 * der Lizenz oder (wenn Sie es wuenschen) jeder spaeteren Version. * Naehere Informationen entnehmen Sie bitter der Datei COPYING. Eine Liste - * der an comBase beteiligten Autoren finden Sie in der Datei AUTHORS. + * der an ngIRCd beteiligten Autoren finden Sie in der Datei AUTHORS. * - * $Id: ngircd.c,v 1.10 2001/12/24 01:34:38 alex Exp $ + * $Id: ngircd.c,v 1.17 2002/01/02 02:51:16 alex Exp $ * * ngircd.c: Hier beginnt alles ;-) * * $Log: ngircd.c,v $ + * Revision 1.17 2002/01/02 02:51:16 alex + * - Signal-Handler fuer SIGCHLD: so sollten Zombies nicht mehr vorkommen. + * + * Revision 1.15 2001/12/31 02:18:51 alex + * - viele neue Befehle (WHOIS, ISON, OPER, DIE, RESTART), + * - neuen Header "defines.h" mit (fast) allen Konstanten. + * - Code Cleanups und viele "kleine" Aenderungen & Bugfixes. + * + * Revision 1.14 2001/12/30 19:26:12 alex + * - Unterstuetzung fuer die Konfigurationsdatei eingebaut. + * + * Revision 1.13 2001/12/30 11:42:00 alex + * - der Server meldet nun eine ordentliche "Start-Zeit". + * + * 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. * @@ -62,6 +82,9 @@ #include #include #include +#include +#include +#include #include "channel.h" #include "client.h" @@ -78,51 +101,61 @@ LOCAL VOID Initialize_Signal_Handler( VOID ); LOCAL VOID Signal_Handler( INT Signal ); +LOCAL VOID Initialize_Listen_Ports( VOID ); + 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( ! NGIRCd_Quit ) { - Conn_Handler( 5 ); - } - - /* Alles abmelden */ - Conn_Exit( ); - Client_Exit( ); - Channel_Exit( ); - IRC_Exit( ); - Parse_Exit( ); - Conf_Exit( ); - Log_Exit( ); - + /* Globale Variablen initialisieren */ + NGIRCd_Start = time( NULL ); + strftime( NGIRCd_StartStr, 64, "%a %b %d %Y at %H:%M:%S (%Z)", localtime( &NGIRCd_Start )); + NGIRCd_Restart = FALSE; + NGIRCd_Quit = FALSE; + + /* Module initialisieren */ + Log_Init( ); + Conf_Init( ); + Parse_Init( ); + IRC_Init( ); + Channel_Init( ); + Client_Init( ); + Conn_Init( ); + + /* Signal-Handler initialisieren */ + Initialize_Signal_Handler( ); + + /* Listen-Ports initialisieren */ + Initialize_Listen_Ports( ); + + /* Hauptschleife */ + while( TRUE ) + { + if( NGIRCd_Quit || NGIRCd_Restart ) break; + Conn_Handler( 5 ); + } + + /* Alles abmelden */ + Conn_Exit( ); + Client_Exit( ); + Channel_Exit( ); + IRC_Exit( ); + Parse_Exit( ); + Conf_Exit( ); + Log_Exit( ); + } return 0; } /* main */ 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; @@ -134,6 +167,7 @@ LOCAL VOID Initialize_Signal_Handler( VOID ) sigaction( SIGINT, &saction, NULL ); sigaction( SIGQUIT, &saction, NULL ); sigaction( SIGTERM, &saction, NULL); + sigaction( SIGCHLD, &saction, NULL); /* einige Signale ignorieren */ saction.sa_handler = SIG_IGN; @@ -153,9 +187,13 @@ 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; + case SIGCHLD: + /* Child-Prozess wurde beendet. Zombies vermeiden: */ + while( waitpid( -1, NULL, WNOHANG ) > 0); + break; default: /* unbekanntes bzw. unbehandeltes Signal */ Log( LOG_NOTICE, "Got signal %d! Ignored.", Signal ); @@ -163,4 +201,26 @@ LOCAL VOID Signal_Handler( INT Signal ) } /* Signal_Handler */ +LOCAL VOID Initialize_Listen_Ports( VOID ) +{ + /* Ports, auf denen der Server Verbindungen entgegennehmen + * soll, initialisieren */ + + INT created, i; + + created = 0; + for( i = 0; i < Conf_ListenPorts_Count; i++ ) + { + if( Conn_NewListener( Conf_ListenPorts[i] )) created++; + else Log( LOG_ERR, "Can't listen on port %d!", Conf_ListenPorts[i] ); + } + + if( created < 1 ) + { + Log( LOG_ALERT, "Server isn't listening on a single port!" ); + Log( LOG_ALERT, PACKAGE" exiting due to fatal errors!" ); + exit( 1 ); + } +} /* Initialize_Listen_Ports */ + /* -eof- */