mirror of
https://github.com/osmarks/ngircd.git
synced 2025-01-28 16:24:44 +00:00
- Netz-Splits werden nun als soche ausgegeben.
This commit is contained in:
parent
df09e7afd3
commit
dce77559fa
@ -9,7 +9,7 @@
|
|||||||
* Naehere Informationen entnehmen Sie bitter der Datei COPYING. Eine Liste
|
* Naehere Informationen entnehmen Sie bitter der Datei COPYING. Eine Liste
|
||||||
* der an ngIRCd beteiligten Autoren finden Sie in der Datei AUTHORS.
|
* der an ngIRCd beteiligten Autoren finden Sie in der Datei AUTHORS.
|
||||||
*
|
*
|
||||||
* $Id: client.c,v 1.45 2002/03/10 17:15:20 alex Exp $
|
* $Id: client.c,v 1.46 2002/03/10 22:03:20 alex Exp $
|
||||||
*
|
*
|
||||||
* client.c: Management aller Clients
|
* client.c: Management aller Clients
|
||||||
*
|
*
|
||||||
@ -21,6 +21,9 @@
|
|||||||
* Server gewesen, so existiert eine entsprechende CONNECTION-Struktur.
|
* Server gewesen, so existiert eine entsprechende CONNECTION-Struktur.
|
||||||
*
|
*
|
||||||
* $Log: client.c,v $
|
* $Log: client.c,v $
|
||||||
|
* Revision 1.46 2002/03/10 22:03:20 alex
|
||||||
|
* - Netz-Splits werden nun als soche ausgegeben.
|
||||||
|
*
|
||||||
* Revision 1.45 2002/03/10 17:15:20 alex
|
* Revision 1.45 2002/03/10 17:15:20 alex
|
||||||
* - der Bindestrich ("-") ist nun auch in Nicknames erlaubt.
|
* - der Bindestrich ("-") ist nun auch in Nicknames erlaubt.
|
||||||
*
|
*
|
||||||
@ -324,7 +327,7 @@ GLOBAL VOID Client_Destroy( CLIENT *Client, CHAR *LogMsg, CHAR *FwdMsg )
|
|||||||
/* Client entfernen. */
|
/* Client entfernen. */
|
||||||
|
|
||||||
CLIENT *last, *c;
|
CLIENT *last, *c;
|
||||||
CHAR *txt;
|
CHAR msg[LINE_LEN], *txt;
|
||||||
|
|
||||||
assert( Client != NULL );
|
assert( Client != NULL );
|
||||||
|
|
||||||
@ -332,19 +335,28 @@ GLOBAL VOID Client_Destroy( CLIENT *Client, CHAR *LogMsg, CHAR *FwdMsg )
|
|||||||
else txt = FwdMsg;
|
else txt = FwdMsg;
|
||||||
if( ! txt ) txt = "Reason unknown.";
|
if( ! txt ) txt = "Reason unknown.";
|
||||||
|
|
||||||
|
if( Client->type == CLIENT_SERVER )
|
||||||
|
{
|
||||||
|
/* Netz-Split-Nachricht vorbereiten */
|
||||||
|
sprintf( msg, "%s | %s", Client_ID( Client ), Client_ID( Client_TopServer( Client ) ? Client_TopServer( Client ) : Client_ThisServer( )));
|
||||||
|
}
|
||||||
|
|
||||||
last = NULL;
|
last = NULL;
|
||||||
c = My_Clients;
|
c = My_Clients;
|
||||||
while( c )
|
while( c )
|
||||||
{
|
{
|
||||||
if(( Client->type == CLIENT_SERVER ) && ( c->introducer == Client ) && ( c != Client ))
|
if(( Client->type == CLIENT_SERVER ) && ( c->introducer == Client ) && ( c != Client ))
|
||||||
{
|
{
|
||||||
Client_Destroy( c, LogMsg, FwdMsg );
|
/* der Client, der geloescht wird ist ein Server. Der Client, den wir gerade
|
||||||
|
* pruefen, ist ein Child von diesem und muss daher auch entfernt werden */
|
||||||
|
Client_Destroy( c, NULL, msg);
|
||||||
last = NULL;
|
last = NULL;
|
||||||
c = My_Clients;
|
c = My_Clients;
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
if( c == Client )
|
if( c == Client )
|
||||||
{
|
{
|
||||||
|
/* Wir haben den Client gefunden: entfernen */
|
||||||
if( last ) last->next = c->next;
|
if( last ) last->next = c->next;
|
||||||
else My_Clients = c->next;
|
else My_Clients = c->next;
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user