+
+ IRC_WriteStrServersPrefixFlag( ExceptOf, Prefix, '\0', "%s", buffer );
+} /* IRC_WriteStrServersPrefix */
+
+
+#ifdef PROTOTYPES
+GLOBAL void
+IRC_WriteStrServersPrefixFlag(CLIENT *ExceptOf, CLIENT *Prefix, char Flag,
+ const char *Format, ...)
+#else
+GLOBAL void
+IRC_WriteStrServersPrefixFlag(ExceptOf, Prefix, Flag, Format, va_alist)
+CLIENT *ExceptOf;
+CLIENT *Prefix;
+char Flag;
+const char *Format;
+va_dcl
+#endif
+{
+ char buffer[1000];
+ va_list ap;
+
+ assert( Format != NULL );
+ assert( Prefix != NULL );
+
+#ifdef PROTOTYPES
+ va_start( ap, Format );
+#else
+ va_start( ap );
+#endif
+ vsnprintf( buffer, 1000, Format, ap );
+ va_end( ap );
+
+ IRC_WriteStrServersPrefixFlag_CB(ExceptOf, Prefix, Flag,
+ cb_writeStrServersPrefixFlag, buffer);
+} /* IRC_WriteStrServersPrefixFlag */
+
+
+GLOBAL void
+IRC_WriteStrServersPrefixFlag_CB(CLIENT *ExceptOf, CLIENT *Prefix, char Flag,
+ void (*callback)(CLIENT *, CLIENT *, void *), void *cb_data)
+{
+ CLIENT *c;
+
+ c = Client_First();
+ while(c) {
+ if (Client_Type(c) == CLIENT_SERVER && Client_Conn(c) > NONE &&
+ c != Client_ThisServer() && c != ExceptOf) {
+ /* Found a target server, do the flags match? */
+ if (Flag == '\0' || strchr(Client_Flags(c), Flag))
+ callback(c, Prefix, cb_data);