]> arthur.barton.de Git - ngircd-alex.git/commitdiff
- NICK korrigiert.
authorAlexander Barton <alex@barton.de>
Sun, 17 Feb 2002 17:18:59 +0000 (17:18 +0000)
committerAlexander Barton <alex@barton.de>
Sun, 17 Feb 2002 17:18:59 +0000 (17:18 +0000)
ChangeLog
src/ngircd/irc.c
src/ngircd/irc.h

index c0c21def87a20b3bee2d065364cc5b0282e04ec3..5d9041552812ebec1f91cbe87240670538a45b73 100644 (file)
--- a/ChangeLog
+++ b/ChangeLog
                         -- ChangeLog / Aenderungen --
 
 
                         -- ChangeLog / Aenderungen --
 
 
+ngIRCd 0.2.x, xx.02.2002
+
+  - NICK korrigiert: es werden nun auch alle "betroffenen" User informiert.
+
 ngIRCd 0.2.0, 15.02.2002
 
   - Nicknames und Channel-Namen werden etwas besser auf Gueltigkeit ueber-
 ngIRCd 0.2.0, 15.02.2002
 
   - Nicknames und Channel-Namen werden etwas besser auf Gueltigkeit ueber-
@@ -95,4 +99,4 @@ ngIRCd 0.0.1, 31.12.2001
 
 
 -- 
 
 
 -- 
-$Id: ChangeLog,v 1.17 2002/02/15 14:35:55 alex Exp $
+$Id: ChangeLog,v 1.18 2002/02/17 17:18:59 alex Exp $
index cf25001a56c57dd3dfff40d77be30dd61e070beb..12754d903c24d18f8a81501ea4ab956595fbd9f6 100644 (file)
@@ -9,11 +9,14 @@
  * Naehere Informationen entnehmen Sie bitter der Datei COPYING. Eine Liste
  * der an ngIRCd beteiligten Autoren finden Sie in der Datei AUTHORS.
  *
  * Naehere Informationen entnehmen Sie bitter der Datei COPYING. Eine Liste
  * der an ngIRCd beteiligten Autoren finden Sie in der Datei AUTHORS.
  *
- * $Id: irc.c,v 1.57 2002/02/13 23:05:29 alex Exp $
+ * $Id: irc.c,v 1.58 2002/02/17 17:18:59 alex Exp $
  *
  * irc.c: IRC-Befehle
  *
  * $Log: irc.c,v $
  *
  * irc.c: IRC-Befehle
  *
  * $Log: irc.c,v $
+ * Revision 1.58  2002/02/17 17:18:59  alex
+ * - NICK korrigiert.
+ *
  * Revision 1.57  2002/02/13 23:05:29  alex
  * - Nach Connect eines Users werden LUSERS-Informationen angezeigt.
  *
  * Revision 1.57  2002/02/13 23:05:29  alex
  * - Nach Connect eines Users werden LUSERS-Informationen angezeigt.
  *
@@ -326,10 +329,10 @@ GLOBAL BOOLEAN IRC_WriteStrChannel( CLIENT *Client, CHANNEL *Chan, BOOLEAN Remot
 GLOBAL BOOLEAN IRC_WriteStrChannelPrefix( CLIENT *Client, CHANNEL *Chan, CLIENT *Prefix, BOOLEAN Remote, CHAR *Format, ... )
 {
        CHAR buffer[1000];
 GLOBAL BOOLEAN IRC_WriteStrChannelPrefix( CLIENT *Client, CHANNEL *Chan, CLIENT *Prefix, BOOLEAN Remote, CHAR *Format, ... )
 {
        CHAR buffer[1000];
-       BOOLEAN sock[MAX_CONNECTIONS], ok = CONNECTED, i;
+       BOOLEAN sock[MAX_CONNECTIONS], ok = CONNECTED;
        CL2CHAN *cl2chan;
        CLIENT *c;
        CL2CHAN *cl2chan;
        CLIENT *c;
-       INT s;
+       INT s, i;
        va_list ap;
 
        assert( Client != NULL );
        va_list ap;
 
        assert( Client != NULL );
@@ -422,6 +425,74 @@ GLOBAL VOID IRC_WriteStrServersPrefix( CLIENT *ExceptOf, CLIENT *Prefix, CHAR *F
 } /* IRC_WriteStrServersPrefix */
 
 
 } /* IRC_WriteStrServersPrefix */
 
 
+GLOBAL BOOLEAN IRC_WriteStrRelatedPrefix( CLIENT *Client, CLIENT *Prefix, BOOLEAN Remote, CHAR *Format, ... )
+{
+       BOOLEAN sock[MAX_CONNECTIONS], ok = CONNECTED;
+       CL2CHAN *chan_cl2chan, *cl2chan;
+       CHAR buffer[1000];
+       CHANNEL *chan;
+       va_list ap;
+       CLIENT *c;
+       INT i, s;
+
+       assert( Client != NULL );
+       assert( Prefix != NULL );
+       assert( Format != NULL );
+
+       va_start( ap, Format );
+       vsnprintf( buffer, 1000, Format, ap );
+       va_end( ap );
+
+       /* initialisieren */
+       for( i = 0; i < MAX_CONNECTIONS; i++ ) sock[i] = FALSE;
+
+       /* An alle Clients, die in einem Channel mit dem "Ausloeser" sind,
+        * den Text schicken. An Remote-Server aber jeweils nur einmal. */
+       chan_cl2chan = Channel_FirstChannelOf( Client );
+       while( chan_cl2chan )
+       {
+               /* Channel des Users durchsuchen */
+               chan = Channel_GetChannel( chan_cl2chan );
+               cl2chan = Channel_FirstMember( chan );
+               while( cl2chan )
+               {
+                       c = Channel_GetClient( cl2chan );
+                       if( ! Remote )
+                       {
+                               if( Client_Conn( c ) <= NONE ) c = NULL;
+                               else if( Client_Type( c ) == CLIENT_SERVER ) c = NULL;
+                       }
+                       if( c ) c = Client_NextHop( c );
+
+                       if( c && ( c != Client ))
+                       {
+                               /* Ok, anderer Client */
+                               s = Client_Conn( c );
+                               assert( s >= 0 );
+                               assert( s < MAX_CONNECTIONS );
+                               sock[s] = TRUE;
+                       }
+                       cl2chan = Channel_NextMember( chan, cl2chan );
+               }
+               
+               /* naechsten Channel */
+               chan_cl2chan = Channel_NextChannelOf( Client, chan_cl2chan );
+       }
+
+       /* Senden ... */
+       for( i = 0; i < MAX_CONNECTIONS; i++ )
+       {
+               if( sock[i] )
+               {
+                       ok = Conn_WriteStr( i, ":%s %s", Client_ID( Prefix ), buffer );
+                       if( ! ok ) break;
+               }
+       }
+       return ok;
+} /* IRC_WriteStrRelatedPrefix */
+
+
+
 GLOBAL BOOLEAN IRC_PASS( CLIENT *Client, REQUEST *Req )
 {
        assert( Client != NULL );
 GLOBAL BOOLEAN IRC_PASS( CLIENT *Client, REQUEST *Req )
 {
        assert( Client != NULL );
@@ -779,13 +850,14 @@ GLOBAL BOOLEAN IRC_NICK( CLIENT *Client, REQUEST *Req )
                        /* Nick-Aenderung: allen mitteilen! */
                        Log( LOG_INFO, "User \"%s\" changed nick: \"%s\" -> \"%s\".", Client_Mask( target ), Client_ID( target ), Req->argv[0] );
                        IRC_WriteStrClient( Client, "NICK :%s", Req->argv[0] );
                        /* Nick-Aenderung: allen mitteilen! */
                        Log( LOG_INFO, "User \"%s\" changed nick: \"%s\" -> \"%s\".", Client_Mask( target ), Client_ID( target ), Req->argv[0] );
                        IRC_WriteStrClient( Client, "NICK :%s", Req->argv[0] );
-                       IRC_WriteStrServersPrefix( NULL, Client, "NICK :%s", Req->argv[0] );
+                       IRC_WriteStrRelatedPrefix( Client, Client, TRUE, "NICK :%s", Req->argv[0] );
                }
                else if( Client_Type( Client ) == CLIENT_SERVER )
                {
                        /* Nick-Aenderung: allen mitteilen! */
                        Log( LOG_DEBUG, "User \"%s\" changed nick: \"%s\" -> \"%s\".", Client_Mask( target ), Client_ID( target ), Req->argv[0] );
                        IRC_WriteStrServersPrefix( Client, target, "NICK :%s", Req->argv[0] );
                }
                else if( Client_Type( Client ) == CLIENT_SERVER )
                {
                        /* Nick-Aenderung: allen mitteilen! */
                        Log( LOG_DEBUG, "User \"%s\" changed nick: \"%s\" -> \"%s\".", Client_Mask( target ), Client_ID( target ), Req->argv[0] );
                        IRC_WriteStrServersPrefix( Client, target, "NICK :%s", Req->argv[0] );
+                       IRC_WriteStrRelatedPrefix( target, target, FALSE, "NICK :%s", Req->argv[0] );
                }
        
                /* Client-Nick registrieren */
                }
        
                /* Client-Nick registrieren */
index c1294972347d14b78507a82d2eaedc4faad37ac4..7d66adc1a0bf221415e844e94d05ec9bcd40f6b2 100644 (file)
@@ -9,11 +9,14 @@
  * Naehere Informationen entnehmen Sie bitter der Datei COPYING. Eine Liste
  * der an ngIRCd beteiligten Autoren finden Sie in der Datei AUTHORS.
  *
  * Naehere Informationen entnehmen Sie bitter der Datei COPYING. Eine Liste
  * der an ngIRCd beteiligten Autoren finden Sie in der Datei AUTHORS.
  *
- * $Id: irc.h,v 1.21 2002/01/27 21:53:57 alex Exp $
+ * $Id: irc.h,v 1.22 2002/02/17 17:18:59 alex Exp $
  *
  * irc.h: IRC-Befehle (Header)
  *
  * $Log: irc.h,v $
  *
  * irc.h: IRC-Befehle (Header)
  *
  * $Log: irc.h,v $
+ * Revision 1.22  2002/02/17 17:18:59  alex
+ * - NICK korrigiert.
+ *
  * Revision 1.21  2002/01/27 21:53:57  alex
  * - IRC_WriteStrServersPrefixID() und IRC_WriteStrClientPrefixID() wieder entfernt.
  *
  * Revision 1.21  2002/01/27 21:53:57  alex
  * - IRC_WriteStrServersPrefixID() und IRC_WriteStrClientPrefixID() wieder entfernt.
  *
@@ -104,6 +107,7 @@ GLOBAL BOOLEAN IRC_WriteStrChannel( CLIENT *Client, CHANNEL *Chan, BOOLEAN Remot
 GLOBAL BOOLEAN IRC_WriteStrChannelPrefix( CLIENT *Client, CHANNEL *Chan, CLIENT *Prefix, BOOLEAN Remote, CHAR *Format, ... );
 GLOBAL VOID IRC_WriteStrServers( CLIENT *ExceptOf, CHAR *Format, ... );
 GLOBAL VOID IRC_WriteStrServersPrefix( CLIENT *ExceptOf, CLIENT *Prefix, CHAR *Format, ... );
 GLOBAL BOOLEAN IRC_WriteStrChannelPrefix( CLIENT *Client, CHANNEL *Chan, CLIENT *Prefix, BOOLEAN Remote, CHAR *Format, ... );
 GLOBAL VOID IRC_WriteStrServers( CLIENT *ExceptOf, CHAR *Format, ... );
 GLOBAL VOID IRC_WriteStrServersPrefix( CLIENT *ExceptOf, CLIENT *Prefix, CHAR *Format, ... );
+GLOBAL BOOLEAN IRC_WriteStrRelatedPrefix( CLIENT *Client, CLIENT *Prefix, BOOLEAN Remote, CHAR *Format, ... );
 
 GLOBAL BOOLEAN IRC_PASS( CLIENT *Client, REQUEST *Req );
 GLOBAL BOOLEAN IRC_NICK( CLIENT *Client, REQUEST *Req );
 
 GLOBAL BOOLEAN IRC_PASS( CLIENT *Client, REQUEST *Req );
 GLOBAL BOOLEAN IRC_NICK( CLIENT *Client, REQUEST *Req );