send: add negation argument to sendto_common_channels_local() and friends
This commit is contained in:
parent
8e9e22b4d3
commit
583f064fef
7 changed files with 21 additions and 17 deletions
|
@ -68,8 +68,8 @@ extern void sendto_channel_local_with_capability(int type, int caps, int negcaps
|
||||||
extern void sendto_channel_local_with_capability_butone(struct Client *, int type, int caps, int negcaps, struct Channel *,
|
extern void sendto_channel_local_with_capability_butone(struct Client *, int type, int caps, int negcaps, struct Channel *,
|
||||||
const char *, ...) AFP(6, 7);
|
const char *, ...) AFP(6, 7);
|
||||||
|
|
||||||
extern void sendto_common_channels_local(struct Client *, int cap, const char *, ...) AFP(3, 4);
|
extern void sendto_common_channels_local(struct Client *, int cap, int negcap, const char *, ...) AFP(4, 5);
|
||||||
extern void sendto_common_channels_local_butone(struct Client *, int cap, const char *, ...) AFP(3, 4);
|
extern void sendto_common_channels_local_butone(struct Client *, int cap, int negcap, const char *, ...) AFP(4, 5);
|
||||||
|
|
||||||
|
|
||||||
extern void sendto_match_butone(struct Client *, struct Client *,
|
extern void sendto_match_butone(struct Client *, struct Client *,
|
||||||
|
|
|
@ -712,7 +712,7 @@ change_local_nick(struct Client *client_p, struct Client *source_p,
|
||||||
source_p->name, nick, source_p->username, source_p->host);
|
source_p->name, nick, source_p->username, source_p->host);
|
||||||
|
|
||||||
/* send the nick change to the users channels */
|
/* send the nick change to the users channels */
|
||||||
sendto_common_channels_local(source_p, NOCAPS, ":%s!%s@%s NICK :%s",
|
sendto_common_channels_local(source_p, NOCAPS, NOCAPS, ":%s!%s@%s NICK :%s",
|
||||||
source_p->name, source_p->username, source_p->host, nick);
|
source_p->name, source_p->username, source_p->host, nick);
|
||||||
|
|
||||||
/* send the nick change to servers.. */
|
/* send the nick change to servers.. */
|
||||||
|
@ -773,7 +773,7 @@ change_remote_nick(struct Client *client_p, struct Client *source_p,
|
||||||
monitor_signoff(source_p);
|
monitor_signoff(source_p);
|
||||||
}
|
}
|
||||||
|
|
||||||
sendto_common_channels_local(source_p, NOCAPS, ":%s!%s@%s NICK :%s",
|
sendto_common_channels_local(source_p, NOCAPS, NOCAPS, ":%s!%s@%s NICK :%s",
|
||||||
source_p->name, source_p->username, source_p->host, nick);
|
source_p->name, source_p->username, source_p->host, nick);
|
||||||
|
|
||||||
if(source_p->user)
|
if(source_p->user)
|
||||||
|
|
|
@ -85,7 +85,7 @@ m_away(struct Client *client_p, struct Client *source_p, int parc, const char *p
|
||||||
":%s AWAY", use_id(source_p));
|
":%s AWAY", use_id(source_p));
|
||||||
free_away(source_p);
|
free_away(source_p);
|
||||||
|
|
||||||
sendto_common_channels_local_butone(source_p, CLICAP_AWAY_NOTIFY, ":%s!%s@%s AWAY",
|
sendto_common_channels_local_butone(source_p, CLICAP_AWAY_NOTIFY, NOCAPS, ":%s!%s@%s AWAY",
|
||||||
source_p->name, source_p->username, source_p->host);
|
source_p->name, source_p->username, source_p->host);
|
||||||
}
|
}
|
||||||
if(MyConnect(source_p))
|
if(MyConnect(source_p))
|
||||||
|
@ -119,7 +119,7 @@ m_away(struct Client *client_p, struct Client *source_p, int parc, const char *p
|
||||||
sendto_server(client_p, NULL, CAP_TS6, NOCAPS,
|
sendto_server(client_p, NULL, CAP_TS6, NOCAPS,
|
||||||
":%s AWAY :%s", use_id(source_p), source_p->user->away);
|
":%s AWAY :%s", use_id(source_p), source_p->user->away);
|
||||||
sendto_common_channels_local_butone(source_p,
|
sendto_common_channels_local_butone(source_p,
|
||||||
CLICAP_AWAY_NOTIFY,
|
CLICAP_AWAY_NOTIFY, NOCAPS,
|
||||||
":%s!%s@%s AWAY :%s",
|
":%s!%s@%s AWAY :%s",
|
||||||
source_p->name,
|
source_p->name,
|
||||||
source_p->username,
|
source_p->username,
|
||||||
|
|
|
@ -134,7 +134,7 @@ me_su(struct Client *client_p, struct Client *source_p,
|
||||||
else
|
else
|
||||||
rb_strlcpy(target_p->user->suser, parv[2], sizeof(target_p->user->suser));
|
rb_strlcpy(target_p->user->suser, parv[2], sizeof(target_p->user->suser));
|
||||||
|
|
||||||
sendto_common_channels_local_butone(target_p, CLICAP_ACCOUNT_NOTIFY, ":%s!%s@%s ACCOUNT %s",
|
sendto_common_channels_local_butone(target_p, CLICAP_ACCOUNT_NOTIFY, NOCAPS, ":%s!%s@%s ACCOUNT %s",
|
||||||
target_p->name, target_p->username, target_p->host,
|
target_p->name, target_p->username, target_p->host,
|
||||||
EmptyString(target_p->user->suser) ? "*" : target_p->user->suser);
|
EmptyString(target_p->user->suser) ? "*" : target_p->user->suser);
|
||||||
|
|
||||||
|
@ -258,7 +258,7 @@ doit:
|
||||||
target_p->name, parv[2], target_p->username,
|
target_p->name, parv[2], target_p->username,
|
||||||
target_p->host);
|
target_p->host);
|
||||||
|
|
||||||
sendto_common_channels_local(target_p, NOCAPS, ":%s!%s@%s NICK :%s",
|
sendto_common_channels_local(target_p, NOCAPS, NOCAPS, ":%s!%s@%s NICK :%s",
|
||||||
target_p->name, target_p->username,
|
target_p->name, target_p->username,
|
||||||
target_p->host, parv[2]);
|
target_p->host, parv[2]);
|
||||||
|
|
||||||
|
|
|
@ -666,7 +666,7 @@ resv_nick_fnc(const char *mask, const char *reason, int temp_time)
|
||||||
|
|
||||||
invalidate_bancache_user(client_p);
|
invalidate_bancache_user(client_p);
|
||||||
|
|
||||||
sendto_common_channels_local(client_p, NOCAPS, ":%s!%s@%s NICK :%s",
|
sendto_common_channels_local(client_p, NOCAPS, NOCAPS, ":%s!%s@%s NICK :%s",
|
||||||
client_p->name, client_p->username, client_p->host, nick);
|
client_p->name, client_p->username, client_p->host, nick);
|
||||||
sendto_server(client_p, NULL, CAP_TS6, NOCAPS, ":%s NICK %s :%ld",
|
sendto_server(client_p, NULL, CAP_TS6, NOCAPS, ":%s NICK %s :%ld",
|
||||||
use_id(client_p), nick, (long) client_p->tsinfo);
|
use_id(client_p), nick, (long) client_p->tsinfo);
|
||||||
|
@ -1185,7 +1185,7 @@ exit_generic_client(struct Client *client_p, struct Client *source_p, struct Cli
|
||||||
if(IsOper(source_p))
|
if(IsOper(source_p))
|
||||||
rb_dlinkFindDestroy(source_p, &oper_list);
|
rb_dlinkFindDestroy(source_p, &oper_list);
|
||||||
|
|
||||||
sendto_common_channels_local(source_p, NOCAPS, ":%s!%s@%s QUIT :%s",
|
sendto_common_channels_local(source_p, NOCAPS, NOCAPS, ":%s!%s@%s QUIT :%s",
|
||||||
source_p->name,
|
source_p->name,
|
||||||
source_p->username, source_p->host, comment);
|
source_p->username, source_p->host, comment);
|
||||||
|
|
||||||
|
|
|
@ -1431,7 +1431,7 @@ change_nick_user_host(struct Client *target_p, const char *nick, const char *use
|
||||||
vsnprintf(reason, 255, format, ap);
|
vsnprintf(reason, 255, format, ap);
|
||||||
va_end(ap);
|
va_end(ap);
|
||||||
|
|
||||||
sendto_common_channels_local_butone(target_p, NOCAPS, ":%s!%s@%s QUIT :%s",
|
sendto_common_channels_local_butone(target_p, NOCAPS, NOCAPS, ":%s!%s@%s QUIT :%s",
|
||||||
target_p->name, target_p->username, target_p->host,
|
target_p->name, target_p->username, target_p->host,
|
||||||
reason);
|
reason);
|
||||||
|
|
||||||
|
@ -1474,7 +1474,7 @@ change_nick_user_host(struct Client *target_p, const char *nick, const char *use
|
||||||
|
|
||||||
/* Resend away message to away-notify enabled clients. */
|
/* Resend away message to away-notify enabled clients. */
|
||||||
if (target_p->user->away)
|
if (target_p->user->away)
|
||||||
sendto_common_channels_local_butone(target_p, CLICAP_AWAY_NOTIFY, ":%s!%s@%s AWAY :%s",
|
sendto_common_channels_local_butone(target_p, CLICAP_AWAY_NOTIFY, NOCAPS, ":%s!%s@%s AWAY :%s",
|
||||||
nick, user, host,
|
nick, user, host,
|
||||||
target_p->user->away);
|
target_p->user->away);
|
||||||
|
|
||||||
|
@ -1486,7 +1486,7 @@ change_nick_user_host(struct Client *target_p, const char *nick, const char *use
|
||||||
}
|
}
|
||||||
else if(changed_case)
|
else if(changed_case)
|
||||||
{
|
{
|
||||||
sendto_common_channels_local(target_p, NOCAPS, ":%s!%s@%s NICK :%s",
|
sendto_common_channels_local(target_p, NOCAPS, NOCAPS, ":%s!%s@%s NICK :%s",
|
||||||
target_p->name, target_p->username,
|
target_p->name, target_p->username,
|
||||||
target_p->host, nick);
|
target_p->host, nick);
|
||||||
|
|
||||||
|
|
12
src/send.c
12
src/send.c
|
@ -778,6 +778,7 @@ sendto_channel_local_butone(struct Client *one, int type, struct Channel *chptr,
|
||||||
*
|
*
|
||||||
* inputs - pointer to client
|
* inputs - pointer to client
|
||||||
* - capability mask
|
* - capability mask
|
||||||
|
* - negated capability mask
|
||||||
* - pattern to send
|
* - pattern to send
|
||||||
* output - NONE
|
* output - NONE
|
||||||
* side effects - Sends a message to all people on local server who are
|
* side effects - Sends a message to all people on local server who are
|
||||||
|
@ -785,7 +786,7 @@ sendto_channel_local_butone(struct Client *one, int type, struct Channel *chptr,
|
||||||
* used by m_nick.c and exit_one_client.
|
* used by m_nick.c and exit_one_client.
|
||||||
*/
|
*/
|
||||||
void
|
void
|
||||||
sendto_common_channels_local(struct Client *user, int cap, const char *pattern, ...)
|
sendto_common_channels_local(struct Client *user, int cap, int negcap, const char *pattern, ...)
|
||||||
{
|
{
|
||||||
va_list args;
|
va_list args;
|
||||||
rb_dlink_node *ptr;
|
rb_dlink_node *ptr;
|
||||||
|
@ -817,7 +818,8 @@ sendto_common_channels_local(struct Client *user, int cap, const char *pattern,
|
||||||
|
|
||||||
if(IsIOError(target_p) ||
|
if(IsIOError(target_p) ||
|
||||||
target_p->serial == current_serial ||
|
target_p->serial == current_serial ||
|
||||||
!IsCapable(target_p, cap))
|
!IsCapable(target_p, cap) ||
|
||||||
|
!NotCapable(target_p, negcap))
|
||||||
continue;
|
continue;
|
||||||
|
|
||||||
target_p->serial = current_serial;
|
target_p->serial = current_serial;
|
||||||
|
@ -839,13 +841,14 @@ sendto_common_channels_local(struct Client *user, int cap, const char *pattern,
|
||||||
*
|
*
|
||||||
* inputs - pointer to client
|
* inputs - pointer to client
|
||||||
* - capability mask
|
* - capability mask
|
||||||
|
* - negated capability mask
|
||||||
* - pattern to send
|
* - pattern to send
|
||||||
* output - NONE
|
* output - NONE
|
||||||
* side effects - Sends a message to all people on local server who are
|
* side effects - Sends a message to all people on local server who are
|
||||||
* in same channel with user, except for user itself.
|
* in same channel with user, except for user itself.
|
||||||
*/
|
*/
|
||||||
void
|
void
|
||||||
sendto_common_channels_local_butone(struct Client *user, int cap, const char *pattern, ...)
|
sendto_common_channels_local_butone(struct Client *user, int cap, int negcap, const char *pattern, ...)
|
||||||
{
|
{
|
||||||
va_list args;
|
va_list args;
|
||||||
rb_dlink_node *ptr;
|
rb_dlink_node *ptr;
|
||||||
|
@ -879,7 +882,8 @@ sendto_common_channels_local_butone(struct Client *user, int cap, const char *pa
|
||||||
|
|
||||||
if(IsIOError(target_p) ||
|
if(IsIOError(target_p) ||
|
||||||
target_p->serial == current_serial ||
|
target_p->serial == current_serial ||
|
||||||
!IsCapable(target_p, cap))
|
!IsCapable(target_p, cap) ||
|
||||||
|
!NotCapable(target_p, negcap))
|
||||||
continue;
|
continue;
|
||||||
|
|
||||||
target_p->serial = current_serial;
|
target_p->serial = current_serial;
|
||||||
|
|
Loading…
Reference in a new issue