1
0
mirror of https://github.com/osmarks/ngircd.git synced 2025-01-23 05:46:51 +00:00

Fix Handling of quit messages: always send only one QUIT message.

This commit is contained in:
Florian Westphal 2005-06-04 11:53:24 +00:00
parent ae98008c1c
commit 517321807e
2 changed files with 6 additions and 3 deletions

View File

@ -11,6 +11,8 @@
ngIRCd CVSHEAD ngIRCd CVSHEAD
- Fix handling of QUIT Messages: send only one message, even if client
is member of multiple channels.
- Don't exit server if closing of a socket fails; instead ignore it and - Don't exit server if closing of a socket fails; instead ignore it and
pray that this will be "the right thing" ... pray that this will be "the right thing" ...
- Implemented the IRC function "WHOWAS". - Implemented the IRC function "WHOWAS".
@ -601,4 +603,4 @@ ngIRCd 0.0.1, 31.12.2001
-- --
$Id: ChangeLog,v 1.271 2005/05/22 23:55:57 alex Exp $ $Id: ChangeLog,v 1.272 2005/06/04 11:53:24 fw Exp $

View File

@ -17,7 +17,7 @@
#include "portab.h" #include "portab.h"
static char UNUSED id[] = "$Id: channel.c,v 1.47 2005/04/27 07:34:25 alex Exp $"; static char UNUSED id[] = "$Id: channel.c,v 1.48 2005/06/04 11:53:25 fw Exp $";
#include "imp.h" #include "imp.h"
#include <assert.h> #include <assert.h>
@ -248,6 +248,8 @@ Channel_Quit( CLIENT *Client, char *Reason )
assert( Client != NULL ); assert( Client != NULL );
assert( Reason != NULL ); assert( Reason != NULL );
IRC_WriteStrRelatedPrefix( Client, Client, false, "QUIT :%s", Reason );
c = My_Channels; c = My_Channels;
while( c ) while( c )
{ {
@ -807,7 +809,6 @@ Remove_Client( int Type, CHANNEL *Chan, CLIENT *Client, CLIENT *Origin, char *Re
/* QUIT: andere Server wurden bereits informiert, vgl. Client_Destroy(); /* QUIT: andere Server wurden bereits informiert, vgl. Client_Destroy();
* hier also "nur" noch alle User in betroffenen Channeln infomieren */ * hier also "nur" noch alle User in betroffenen Channeln infomieren */
assert( InformServer == false ); assert( InformServer == false );
IRC_WriteStrChannelPrefix( Origin, c, Origin, false, "QUIT :%s", Reason );
Log( LOG_DEBUG, "User \"%s\" left channel \"%s\" (%s).", Client_Mask( Client ), c->name, Reason ); Log( LOG_DEBUG, "User \"%s\" left channel \"%s\" (%s).", Client_Mask( Client ), c->name, Reason );
break; break;
case REMOVE_KICK: case REMOVE_KICK: