+ STATIC CHAR version[126];
+
+#ifdef CVSDATE
+ sprintf( version, "%s %s(%s)-%s", PACKAGE, VERSION, CVSDATE, NGIRCd_VersionAddition( ));
+#else
+ sprintf( version, "%s %s-%s", PACKAGE, VERSION, NGIRCd_VersionAddition( ));
+#endif
+ return version;
+} /* NGIRCd_Version */
+
+
+GLOBAL CHAR *
+NGIRCd_VersionAddition( VOID )
+{
+ STATIC CHAR txt[64];
+
+ strcpy( txt, "" );
+
+#ifdef USE_SYSLOG
+ if( txt[0] ) strcat( txt, "+" );
+ strcat( txt, "SYSLOG" );
+#endif
+#ifdef USE_ZLIB
+ if( txt[0] ) strcat( txt, "+" );
+ strcat( txt, "ZLIB" );
+#endif
+#ifdef DEBUG
+ if( txt[0] ) strcat( txt, "+" );
+ strcat( txt, "DEBUG" );
+#endif
+#ifdef SNIFFER
+ if( txt[0] ) strcat( txt, "+" );
+ strcat( txt, "SNIFFER" );
+#endif
+#ifdef STRICT_RFC
+ if( txt[0] ) strcat( txt, "+" );
+ strcat( txt, "RFC" );
+#endif
+#ifdef IRCPLUS
+ if( txt[0] ) strcat( txt, "+" );
+ strcat( txt, "IRCPLUS" );
+#endif
+
+ if( txt[0] ) strcat( txt, "-" );
+ strcat( txt, TARGET_CPU );
+ strcat( txt, "/" );
+ strcat( txt, TARGET_VENDOR );
+ strcat( txt, "/" );
+ strcat( txt, TARGET_OS );
+
+ return txt;
+} /* NGIRCd_VersionAddition */
+
+
+GLOBAL VOID
+NGIRCd_Rehash( VOID )
+{
+ CHAR old_name[CLIENT_ID_LEN];
+
+ /* Alle Listen-Sockets schliessen */
+ Conn_ExitListeners( );
+
+ /* Alten Server-Namen merken */
+ strcpy( old_name, Conf_ServerName );
+
+ /* Konfiguration neu lesen ... */
+ Conf_Init( );
+
+ /* Alten Server-Namen wiederherstellen: dieser
+ * kann nicht zur Laufzeit geaendert werden ... */
+ if( strcmp( old_name, Conf_ServerName ) != 0 )
+ {
+ strcpy( Conf_ServerName, old_name );
+ Log( LOG_ERR, "Can't change \"ServerName\" on runtime! Ignored new name." );
+ }
+
+ /* neue pre-defined Channel anlegen: */
+ Channel_InitPredefined( );
+
+ /* Listen-Sockets neu anlegen: */
+ Conn_InitListeners( );
+
+ Log( LOG_INFO, "Re-reading of configuration done." );
+} /* NGIRCd_Rehash */
+
+
+LOCAL VOID
+Initialize_Signal_Handler( VOID )
+{
+ /* Signal-Handler initialisieren: einige Signale
+ * werden ignoriert, andere speziell behandelt. */
+
+#ifdef HAVE_SIGACTION
+ /* sigaction() ist vorhanden */
+
+ struct sigaction saction;
+
+ /* Signal-Struktur initialisieren */
+ memset( &saction, 0, sizeof( saction ));
+ saction.sa_handler = Signal_Handler;
+#ifdef SA_RESTART
+ saction.sa_flags |= SA_RESTART;
+#endif
+#ifdef SA_NOCLDWAIT
+ saction.sa_flags |= SA_NOCLDWAIT;
+#endif
+
+ /* Signal-Handler einhaengen */
+ sigaction( SIGINT, &saction, NULL );
+ sigaction( SIGQUIT, &saction, NULL );
+ sigaction( SIGTERM, &saction, NULL);
+ sigaction( SIGHUP, &saction, NULL);
+ sigaction( SIGCHLD, &saction, NULL);
+
+ /* einige Signale ignorieren */
+ saction.sa_handler = SIG_IGN;
+ sigaction( SIGPIPE, &saction, NULL );
+#else
+ /* kein sigaction() vorhanden */
+
+ /* Signal-Handler einhaengen */
+ signal( SIGINT, Signal_Handler );
+ signal( SIGQUIT, Signal_Handler );
+ signal( SIGTERM, Signal_Handler );
+ signal( SIGHUP, Signal_Handler );
+ signal( SIGCHLD, Signal_Handler );
+
+ /* einige Signale ignorieren */
+ signal( SIGPIPE, SIG_IGN );
+#endif
+} /* Initialize_Signal_Handler */
+
+
+LOCAL VOID
+Signal_Handler( INT Signal )
+{
+ /* Signal-Handler. Dieser wird aufgerufen, wenn eines der Signale eintrifft,
+ * fuer das wir uns registriert haben (vgl. Initialize_Signal_Handler). Die
+ * Nummer des eingetroffenen Signals wird der Funktion uebergeben. */
+