1
0
mirror of https://github.com/irssi/irssi.git synced 2024-12-04 14:46:39 -05:00

Implement CHANTYPES support

This commit is contained in:
LemonBoy 2015-05-15 16:42:51 +02:00
parent c122a2a226
commit 16c71cf1fb
23 changed files with 57 additions and 55 deletions

View File

@ -18,7 +18,7 @@
(SERVER_CONNECT(conn) ? TRUE : FALSE) (SERVER_CONNECT(conn) ? TRUE : FALSE)
#define server_ischannel(server, channel) \ #define server_ischannel(server, channel) \
(server)->ischannel(server, channel) ((server)->ischannel(server, channel))
/* all strings should be either NULL or dynamically allocated */ /* all strings should be either NULL or dynamically allocated */
/* address and nick are mandatory, rest are optional */ /* address and nick are mandatory, rest are optional */

View File

@ -44,7 +44,7 @@ static void dcc_request(CHAT_DCC_REC *dcc)
if (!IS_DCC_CHAT(dcc)) return; if (!IS_DCC_CHAT(dcc)) return;
printformat(dcc->server, NULL, MSGLEVEL_DCC, printformat(dcc->server, NULL, MSGLEVEL_DCC,
ischannel(*dcc->target) ? IRCTXT_DCC_CHAT_CHANNEL : server_ischannel(SERVER(dcc->server), dcc->target) ? IRCTXT_DCC_CHAT_CHANNEL :
IRCTXT_DCC_CHAT, dcc->id, dcc->addrstr, IRCTXT_DCC_CHAT, dcc->id, dcc->addrstr,
dcc->port, dcc->target); dcc->port, dcc->target);
} }

View File

@ -21,6 +21,7 @@
#include "module.h" #include "module.h"
#include "signals.h" #include "signals.h"
#include "levels.h" #include "levels.h"
#include "servers.h"
#include "irc.h" #include "irc.h"
#include "dcc-file.h" #include "dcc-file.h"
@ -35,12 +36,12 @@ static void dcc_request(GET_DCC_REC *dcc)
{ {
char *sizestr; char *sizestr;
if (!IS_DCC_GET(dcc)) return; if (!IS_DCC_GET(dcc)) return;
sizestr = dcc_get_size_str(dcc->size); sizestr = dcc_get_size_str(dcc->size);
printformat(dcc->server, NULL, MSGLEVEL_DCC, printformat(dcc->server, NULL, MSGLEVEL_DCC,
ischannel(*dcc->target) ? IRCTXT_DCC_SEND_CHANNEL : server_ischannel(SERVER(dcc->server), dcc->target) ? IRCTXT_DCC_SEND_CHANNEL :
IRCTXT_DCC_SEND, dcc->nick, dcc->addrstr, IRCTXT_DCC_SEND, dcc->nick, dcc->addrstr,
dcc->port, dcc->arg, sizestr, dcc->target); dcc->port, dcc->arg, sizestr, dcc->target);

View File

@ -49,7 +49,7 @@ static void ctcp_default_msg(IRC_SERVER_REC *server, const char *data,
data = p+1; data = p+1;
} }
printformat(server, ischannel(*target) ? target : nick, MSGLEVEL_CTCPS, printformat(server, server_ischannel(SERVER(server), target) ? target : nick, MSGLEVEL_CTCPS,
IRCTXT_CTCP_REQUESTED_UNKNOWN, IRCTXT_CTCP_REQUESTED_UNKNOWN,
nick, addr, cmd, data, target); nick, addr, cmd, data, target);
g_free(cmd); g_free(cmd);
@ -113,8 +113,8 @@ static void ctcp_default_reply(IRC_SERVER_REC *server, const char *data,
ctcpdata = ptr+1; ctcpdata = ptr+1;
} }
printformat(server, ischannel(*target) ? target : nick, MSGLEVEL_CTCPS, printformat(server, server_ischannel(SERVER(server), target) ? target : nick, MSGLEVEL_CTCPS,
ischannel(*target) ? IRCTXT_CTCP_REPLY_CHANNEL : server_ischannel(SERVER(server), target) ? IRCTXT_CTCP_REPLY_CHANNEL :
IRCTXT_CTCP_REPLY, ctcp, nick, ctcpdata, target); IRCTXT_CTCP_REPLY, ctcp, nick, ctcpdata, target);
g_free(ctcp); g_free(ctcp);
} }
@ -137,7 +137,7 @@ static void ctcp_ping_reply(IRC_SERVER_REC *server, const char *data,
g_get_current_time(&tv); g_get_current_time(&tv);
usecs = get_timeval_diff(&tv, &tv2); usecs = get_timeval_diff(&tv, &tv2);
printformat(server, ischannel(*target) ? target : nick, MSGLEVEL_CTCPS, printformat(server, server_ischannel(SERVER(server), target) ? target : nick, MSGLEVEL_CTCPS,
IRCTXT_CTCP_PING_REPLY, nick, usecs/1000, usecs%1000); IRCTXT_CTCP_PING_REPLY, nick, usecs/1000, usecs%1000);
} }

View File

@ -400,7 +400,7 @@ static void event_target_unavailable(IRC_SERVER_REC *server, const char *data,
g_return_if_fail(data != NULL); g_return_if_fail(data != NULL);
params = event_get_params(data, 2, NULL, &target); params = event_get_params(data, 2, NULL, &target);
if (!ischannel(*target)) { if (!server_ischannel(SERVER(server), target)) {
/* nick unavailable */ /* nick unavailable */
printformat(server, NULL, MSGLEVEL_CRAP, printformat(server, NULL, MSGLEVEL_CRAP,
IRCTXT_NICK_UNAVAILABLE, target); IRCTXT_NICK_UNAVAILABLE, target);
@ -583,7 +583,7 @@ static void print_event_received(IRC_SERVER_REC *server, const char *data,
return; return;
ptr++; ptr++;
if (ischannel(*data)) /* directed at channel */ if (server_ischannel(SERVER(server), data)) /* directed at channel */
target = g_strndup(data, (int)(ptr - data - 1)); target = g_strndup(data, (int)(ptr - data - 1));
else if (!target_param || *ptr == ':' || (ptr2 = strchr(ptr, ' ')) == NULL) else if (!target_param || *ptr == ':' || (ptr2 = strchr(ptr, ' ')) == NULL)
target = NULL; target = NULL;

View File

@ -52,15 +52,15 @@ static void event_privmsg(IRC_SERVER_REC *server, const char *data,
params = event_get_params(data, 2 | PARAM_FLAG_GETREST, &target, &msg); params = event_get_params(data, 2 | PARAM_FLAG_GETREST, &target, &msg);
if (nick == NULL) nick = server->real_address; if (nick == NULL) nick = server->real_address;
if (addr == NULL) addr = ""; if (addr == NULL) addr = "";
if (*target == '@' && ischannel(target[1])) { if (*target == '@' && server_ischannel(SERVER(server), &target[1])) {
/* Hybrid 6 feature, send msg to all ops in channel */ /* Hybrid 6 feature, send msg to all ops in channel */
recoded = recode_in(SERVER(server), msg, target+1); recoded = recode_in(SERVER(server), msg, target+1);
signal_emit("message irc op_public", 5, signal_emit("message irc op_public", 5,
server, recoded, nick, addr, server, recoded, nick, addr,
get_visible_target(server, target+1)); get_visible_target(server, target+1));
} else { } else {
recoded = recode_in(SERVER(server), msg, ischannel(*target) ? target : nick); recoded = recode_in(SERVER(server), msg, server_ischannel(SERVER(server), target) ? target : nick);
signal_emit(ischannel(*target) ? signal_emit(server_ischannel(SERVER(server), target) ?
"message public" : "message private", 5, "message public" : "message private", 5,
server, recoded, nick, addr, server, recoded, nick, addr,
get_visible_target(server, target)); get_visible_target(server, target));

View File

@ -46,7 +46,7 @@ static void sig_event_forward(SERVER_REC *server, const char *data,
char *params, *from, *to; char *params, *from, *to;
params = event_get_params(data, 3, NULL, &from, &to); params = event_get_params(data, 3, NULL, &from, &to);
if (from != NULL && to != NULL && ischannel(*from) && ischannel(*to)) { if (from != NULL && to != NULL && server_ischannel(server, *from) && server_ischannel(server, *to)) {
channel = irc_channel_find(server, from); channel = irc_channel_find(server, from);
if (channel != NULL && irc_channel_find(server, to) == NULL) { if (channel != NULL && irc_channel_find(server, to) == NULL) {
window_bind_add(window_item_window(channel), window_bind_add(window_item_window(channel),

View File

@ -57,7 +57,7 @@ static const char *skip_target(IRC_SERVER_REC *server, const char *target)
break; break;
}; };
if(ischannel(target[i])) if(server_ischannel(SERVER(server), &target[i]))
target += i; target += i;
return target; return target;
@ -136,7 +136,7 @@ static void sig_message_own_action(IRC_SERVER_REC *server, const char *msg,
oldtarget = target; oldtarget = target;
target = skip_target(IRC_SERVER(server), target); target = skip_target(IRC_SERVER(server), target);
if (ischannel(*target)) if (server_ischannel(SERVER(server), target))
item = irc_channel_find(server, target); item = irc_channel_find(server, target);
else else
item = irc_query_find(server, target); item = irc_query_find(server, target);
@ -146,7 +146,7 @@ static void sig_message_own_action(IRC_SERVER_REC *server, const char *msg,
printformat(server, target, printformat(server, target,
MSGLEVEL_ACTIONS | MSGLEVEL_NOHILIGHT | MSGLEVEL_NO_ACT | MSGLEVEL_ACTIONS | MSGLEVEL_NOHILIGHT | MSGLEVEL_NO_ACT |
(ischannel(*target) ? MSGLEVEL_PUBLIC : MSGLEVEL_MSGS), (server_ischannel(SERVER(server), target) ? MSGLEVEL_PUBLIC : MSGLEVEL_MSGS),
item != NULL && oldtarget == target ? IRCTXT_OWN_ACTION : IRCTXT_OWN_ACTION_TARGET, item != NULL && oldtarget == target ? IRCTXT_OWN_ACTION : IRCTXT_OWN_ACTION_TARGET,
server->nick, msg, oldtarget); server->nick, msg, oldtarget);
g_free_not_null(freemsg); g_free_not_null(freemsg);
@ -166,7 +166,7 @@ static void sig_message_irc_action(IRC_SERVER_REC *server, const char *msg,
target = skip_target(IRC_SERVER(server), target); target = skip_target(IRC_SERVER(server), target);
level = MSGLEVEL_ACTIONS | level = MSGLEVEL_ACTIONS |
(ischannel(*target) ? MSGLEVEL_PUBLIC : MSGLEVEL_MSGS); (server_ischannel(SERVER(server), target) ? MSGLEVEL_PUBLIC : MSGLEVEL_MSGS);
if (ignore_check(SERVER(server), nick, address, target, msg, level)) if (ignore_check(SERVER(server), nick, address, target, msg, level))
return; return;
@ -175,7 +175,7 @@ static void sig_message_irc_action(IRC_SERVER_REC *server, const char *msg,
level | MSGLEVEL_NO_ACT)) level | MSGLEVEL_NO_ACT))
level |= MSGLEVEL_NO_ACT; level |= MSGLEVEL_NO_ACT;
if (ischannel(*target)) { if (server_ischannel(SERVER(server), target)) {
item = irc_channel_find(server, target); item = irc_channel_find(server, target);
} else { } else {
own = (!g_strcmp0(nick, server->nick)); own = (!g_strcmp0(nick, server->nick));
@ -185,7 +185,7 @@ static void sig_message_irc_action(IRC_SERVER_REC *server, const char *msg,
if (settings_get_bool("emphasis")) if (settings_get_bool("emphasis"))
msg = freemsg = expand_emphasis(item, msg); msg = freemsg = expand_emphasis(item, msg);
if (ischannel(*target)) { if (server_ischannel(SERVER(server), target)) {
/* channel action */ /* channel action */
if (window_item_is_active(item) && target == oldtarget) { if (window_item_is_active(item) && target == oldtarget) {
/* message to active channel in window */ /* message to active channel in window */
@ -245,16 +245,16 @@ static void sig_message_irc_notice(SERVER_REC *server, const char *msg,
} }
if (ignore_check(server, nick, address, if (ignore_check(server, nick, address,
ischannel(*target) ? target : NULL, server_ischannel(SERVER(server), target) ? target : NULL,
msg, level)) msg, level))
return; return;
if (ignore_check(server, nick, address, if (ignore_check(server, nick, address,
ischannel(*target) ? target : NULL, server_ischannel(SERVER(server), target) ? target : NULL,
msg, level | MSGLEVEL_NO_ACT)) msg, level | MSGLEVEL_NO_ACT))
level |= MSGLEVEL_NO_ACT; level |= MSGLEVEL_NO_ACT;
if (ischannel(*target)) { if (server_ischannel(SERVER(server), target)) {
/* notice in some channel */ /* notice in some channel */
printformat(server, target, level, printformat(server, target, level,
IRCTXT_NOTICE_PUBLIC, nick, oldtarget, msg); IRCTXT_NOTICE_PUBLIC, nick, oldtarget, msg);
@ -283,7 +283,7 @@ static void sig_message_irc_ctcp(IRC_SERVER_REC *server, const char *cmd,
oldtarget = target; oldtarget = target;
target = skip_target(server, target); target = skip_target(server, target);
printformat(server, ischannel(*target) ? target : nick, MSGLEVEL_CTCPS, printformat(server, server_ischannel(SERVER(server), target) ? target : nick, MSGLEVEL_CTCPS,
IRCTXT_CTCP_REQUESTED, nick, addr, cmd, data, oldtarget); IRCTXT_CTCP_REQUESTED, nick, addr, cmd, data, oldtarget);
} }

View File

@ -63,7 +63,7 @@ static void event_privmsg(SERVER_REC *server, const char *data,
g_return_if_fail(data != NULL); g_return_if_fail(data != NULL);
if (nick == NULL || address == NULL || ischannel(*data) || if (nick == NULL || address == NULL || server_ischannel(server, data) ||
!settings_get_bool("query_track_nick_changes")) !settings_get_bool("query_track_nick_changes"))
return; return;

View File

@ -168,7 +168,7 @@ static void sig_message_mode(IRC_SERVER_REC *server, const char *channel,
mode, MSGLEVEL_MODES)) mode, MSGLEVEL_MODES))
return; return;
if (!ischannel(*channel)) { if (!server_ischannel(SERVER(server), channel)) {
/* user mode change */ /* user mode change */
printformat(server, NULL, MSGLEVEL_MODES, printformat(server, NULL, MSGLEVEL_MODES,
IRCTXT_USERMODE_CHANGE, mode, channel); IRCTXT_USERMODE_CHANGE, mode, channel);

View File

@ -400,7 +400,7 @@ static void msg_mode(IRC_SERVER_REC *server, const char *channel,
int show; int show;
g_return_if_fail(data != NULL); g_return_if_fail(data != NULL);
if (!ischannel(*channel) || addr != NULL) if (!server_ischannel(SERVER(server), channel) || addr != NULL)
return; return;
params = event_get_params(data, 2 | PARAM_FLAG_GETREST, params = event_get_params(data, 2 | PARAM_FLAG_GETREST,

View File

@ -186,7 +186,7 @@ static void command_set_ban(const char *data, IRC_SERVER_REC *server,
if (!cmd_get_params(data, &free_arg, 2 | PARAM_FLAG_OPTCHAN | PARAM_FLAG_GETREST, if (!cmd_get_params(data, &free_arg, 2 | PARAM_FLAG_OPTCHAN | PARAM_FLAG_GETREST,
item, &channel, &nicks)) return; item, &channel, &nicks)) return;
if (!ischannel(*channel)) cmd_param_error(CMDERR_NOT_JOINED); if (!server_ischannel(SERVER(server), channel)) cmd_param_error(CMDERR_NOT_JOINED);
if (*nicks == '\0') { if (*nicks == '\0') {
if (g_strcmp0(data, "*") != 0) if (g_strcmp0(data, "*") != 0)
cmd_param_error(CMDERR_NOT_ENOUGH_PARAMS); cmd_param_error(CMDERR_NOT_ENOUGH_PARAMS);

View File

@ -149,7 +149,7 @@ static void event_target_unavailable(IRC_SERVER_REC *server, const char *data)
g_return_if_fail(data != NULL); g_return_if_fail(data != NULL);
params = event_get_params(data, 2, NULL, &channel); params = event_get_params(data, 2, NULL, &channel);
if (ischannel(*channel)) { if (server_ischannel(SERVER(server), channel)) {
chanrec = irc_channel_find(server, channel); chanrec = irc_channel_find(server, channel);
if (chanrec != NULL && chanrec->joined) { if (chanrec != NULL && chanrec->joined) {
/* dalnet event - can't change nick while /* dalnet event - can't change nick while

View File

@ -99,7 +99,7 @@ static void irc_channels_join(IRC_SERVER_REC *server, const char *data,
tmp = chanlist; tmp = chanlist;
for (;; tmp++) { for (;; tmp++) {
if (*tmp != NULL) { if (*tmp != NULL) {
channel = ischannel(**tmp) ? g_strdup(*tmp) : channel = server_ischannel(SERVER(server), *tmp) ? g_strdup(*tmp) :
g_strdup_printf("#%s", *tmp); g_strdup_printf("#%s", *tmp);
chanrec = irc_channel_find(server, channel); chanrec = irc_channel_find(server, channel);
@ -134,7 +134,7 @@ static void irc_channels_join(IRC_SERVER_REC *server, const char *data,
if (use_keys) if (use_keys)
cmdlen += outkeys->len; cmdlen += outkeys->len;
if (*tmpstr != NULL) if (*tmpstr != NULL)
cmdlen += ischannel(**tmpstr) ? strlen(*tmpstr) : cmdlen += server_ischannel(SERVER(server), *tmpstr) ? strlen(*tmpstr) :
strlen(*tmpstr)+1; strlen(*tmpstr)+1;
if (*tmpkey != NULL) if (*tmpkey != NULL)
cmdlen += strlen(*tmpkey); cmdlen += strlen(*tmpkey);

View File

@ -191,7 +191,7 @@ static void cmd_kick(const char *data, IRC_SERVER_REC *server, WI_ITEM_REC *item
return; return;
if (*channame == '\0' || *nicks == '\0') cmd_param_error(CMDERR_NOT_ENOUGH_PARAMS); if (*channame == '\0' || *nicks == '\0') cmd_param_error(CMDERR_NOT_ENOUGH_PARAMS);
if (!ischannel(*channame)) cmd_param_error(CMDERR_NOT_JOINED); if (!server_ischannel(SERVER(server), channame)) cmd_param_error(CMDERR_NOT_JOINED);
recoded = recode_out(SERVER(server), reason, channame); recoded = recode_out(SERVER(server), reason, channame);
g_string_printf(tmpstr, "KICK %s %s :%s", channame, nicks, recoded); g_string_printf(tmpstr, "KICK %s %s :%s", channame, nicks, recoded);

View File

@ -394,7 +394,7 @@ static void event_target_unavailable(IRC_SERVER_REC *server, const char *data)
g_return_if_fail(data != NULL); g_return_if_fail(data != NULL);
params = event_get_params(data, 2, NULL, &channel); params = event_get_params(data, 2, NULL, &channel);
if (!ischannel(*channel)) { if (!server_ischannel(SERVER(server), channel)) {
/* nick is unavailable. */ /* nick is unavailable. */
event_nick_in_use(server, data); event_nick_in_use(server, data);
} }

View File

@ -60,8 +60,8 @@ static void check_query_changes(IRC_SERVER_REC *server, const char *nick,
{ {
QUERY_REC *query; QUERY_REC *query;
if (ischannel(*target)) if (server_ischannel(SERVER(server), target))
return; return;
query = irc_query_find(server, nick); query = irc_query_find(server, nick);
if (query == NULL) if (query == NULL)

View File

@ -71,13 +71,20 @@ static int isnickflag_func(SERVER_REC *server, char flag)
static int ischannel_func(SERVER_REC *server, const char *data) static int ischannel_func(SERVER_REC *server, const char *data)
{ {
if (*data == '@') { IRC_SERVER_REC *irc_server = (IRC_SERVER_REC *) server;
/* @#channel, @+#channel */ char *chantypes;
data++;
if (*data == '+' && ischannel(data[1])) chantypes = g_hash_table_lookup(irc_server->isupport, "chantypes");
return 1; if (chantypes == NULL)
} chantypes = "#&!+"; /* normal, local, secure, modeless */
return ischannel(*data);
/* @#channel, @+#channel */
if (data[0] == '@' && data[1] == '+')
data += 2;
else if (data[0] == '@')
data += 1;
return strchr(chantypes, *data) != NULL;
} }
static char **split_line(const SERVER_REC *server, const char *line, static char **split_line(const SERVER_REC *server, const char *line,

View File

@ -22,12 +22,6 @@ typedef struct _REDIRECT_REC REDIRECT_REC;
#define isnickflag(server, a) \ #define isnickflag(server, a) \
(server->prefix[(int)(unsigned char) a] != '\0') (server->prefix[(int)(unsigned char) a] != '\0')
#define ischannel(a) \
((a) == '#' || /* normal */ \
(a) == '&' || /* local */ \
(a) == '!' || /* secure */ \
(a) == '+') /* modeless */
#define IS_IRC_ITEM(rec) (IS_IRC_CHANNEL(rec) || IS_IRC_QUERY(rec)) #define IS_IRC_ITEM(rec) (IS_IRC_CHANNEL(rec) || IS_IRC_QUERY(rec))
#define IRC_PROTOCOL (chat_protocol_lookup("IRC")) #define IRC_PROTOCOL (chat_protocol_lookup("IRC"))

View File

@ -488,7 +488,7 @@ static void event_mode(IRC_SERVER_REC *server, const char *data,
params = event_get_params(data, 2 | PARAM_FLAG_GETREST, params = event_get_params(data, 2 | PARAM_FLAG_GETREST,
&channel, &mode); &channel, &mode);
if (!ischannel(*channel)) { if (!server_ischannel(SERVER(server), channel)) {
/* user mode change */ /* user mode change */
parse_user_mode(server, mode); parse_user_mode(server, mode);
} else { } else {
@ -536,7 +536,7 @@ static void sig_req_usermode_change(IRC_SERVER_REC *server, const char *data,
params = event_get_params(data, 2 | PARAM_FLAG_GETREST, params = event_get_params(data, 2 | PARAM_FLAG_GETREST,
&target, &mode); &target, &mode);
if (!ischannel(*target)) { if (!server_ischannel(SERVER(server), target)) {
/* we requested a user mode change, save this */ /* we requested a user mode change, save this */
mode = modes_join(NULL, server->wanted_usermode, mode, FALSE); mode = modes_join(NULL, server->wanted_usermode, mode, FALSE);
g_free_not_null(server->wanted_usermode); g_free_not_null(server->wanted_usermode);
@ -856,7 +856,7 @@ static void cmd_mode(const char *data, IRC_SERVER_REC *server,
target = chanrec->name; target = chanrec->name;
irc_send_cmdv(server, "MODE %s", target); irc_send_cmdv(server, "MODE %s", target);
} else if (ischannel(*target)) } else if (server_ischannel(SERVER(server), target))
channel_set_mode(server, target, mode); channel_set_mode(server, target, mode);
else { else {
if (g_ascii_strcasecmp(target, server->nick) == 0) { if (g_ascii_strcasecmp(target, server->nick) == 0) {

View File

@ -51,7 +51,7 @@ static void sig_dcc_request(GET_DCC_REC *dcc, const char *nickaddr)
/* Unless specifically said in dcc_autoget_masks, don't do autogets /* Unless specifically said in dcc_autoget_masks, don't do autogets
sent to channels. */ sent to channels. */
if (*masks == '\0' && dcc->target != NULL && ischannel(*dcc->target)) if (*masks == '\0' && dcc->target != NULL && server_ischannel(SERVER(dcc->server), dcc->target))
return; return;
/* don't autoget files beginning with a dot, if download dir is /* don't autoget files beginning with a dot, if download dir is

View File

@ -250,7 +250,7 @@ static void flood_privmsg(IRC_SERVER_REC *server, const char *data,
params = event_get_params(data, 2, &target, &text); params = event_get_params(data, 2, &target, &text);
level = ischannel(*target) ? MSGLEVEL_PUBLIC : MSGLEVEL_MSGS; level = server_ischannel(SERVER(server), target) ? MSGLEVEL_PUBLIC : MSGLEVEL_MSGS;
if (addr != NULL && !ignore_check(SERVER(server), nick, addr, target, text, level)) if (addr != NULL && !ignore_check(SERVER(server), nick, addr, target, text, level))
flood_newmsg(server, level, nick, addr, target); flood_newmsg(server, level, nick, addr, target);
@ -287,7 +287,7 @@ static void flood_ctcp(IRC_SERVER_REC *server, const char *data,
return; return;
level = g_ascii_strncasecmp(data, "ACTION ", 7) != 0 ? MSGLEVEL_CTCPS : level = g_ascii_strncasecmp(data, "ACTION ", 7) != 0 ? MSGLEVEL_CTCPS :
(ischannel(*target) ? MSGLEVEL_PUBLIC : MSGLEVEL_MSGS); (server_ischannel(SERVER(server), target) ? MSGLEVEL_PUBLIC : MSGLEVEL_MSGS);
if (!ignore_check(SERVER(server), nick, addr, target, data, level)) if (!ignore_check(SERVER(server), nick, addr, target, data, level))
flood_newmsg(server, level, nick, addr, target); flood_newmsg(server, level, nick, addr, target);
} }

View File

@ -262,7 +262,7 @@ static void handle_client_cmd(CLIENT_REC *client, char *cmd, char *args,
ignore_next = TRUE; ignore_next = TRUE;
if (*msg != '\001' || msg[strlen(msg)-1] != '\001') { if (*msg != '\001' || msg[strlen(msg)-1] != '\001') {
signal_emit(ischannel(*target) ? signal_emit(server_ischannel(SERVER(client->server), target) ?
"message own_public" : "message own_private", 4, "message own_public" : "message own_private", 4,
client->server, msg, target, target); client->server, msg, target, target);
} else if (strncmp(msg+1, "ACTION ", 7) == 0) { } else if (strncmp(msg+1, "ACTION ", 7) == 0) {