+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 */
+
+
+