diff options
author | Timo Sirainen <cras@irssi.org> | 2002-01-10 18:02:22 +0000 |
---|---|---|
committer | cras <cras@dbcabf3a-b0e7-0310-adc4-f8d773084564> | 2002-01-10 18:02:22 +0000 |
commit | 9fffa58c203e37ff9a6cb853d40ce33a6edef6ea (patch) | |
tree | 544ac4f814b16e00ddfe319fd193eea14f89eb4b /src | |
parent | 7131ceb909c5ffc614a8a9b40e80449a468fd78c (diff) | |
download | irssi-9fffa58c203e37ff9a6cb853d40ce33a6edef6ea.zip |
Actions are now sent in "ctcp action" signal which is never ignored. "ctcp
msg action" doesn't work anymore nor does it show in "ctcp msg"s.
git-svn-id: http://svn.irssi.org/repos/irssi/trunk@2303 dbcabf3a-b0e7-0310-adc4-f8d773084564
Diffstat (limited to 'src')
-rw-r--r-- | src/fe-common/irc/fe-events.c | 24 | ||||
-rw-r--r-- | src/irc/core/ctcp.c | 7 | ||||
-rw-r--r-- | src/irc/core/irc-queries.c | 29 |
3 files changed, 36 insertions, 24 deletions
diff --git a/src/fe-common/irc/fe-events.c b/src/fe-common/irc/fe-events.c index a4758c1d..03f37f0c 100644 --- a/src/fe-common/irc/fe-events.c +++ b/src/fe-common/irc/fe-events.c @@ -66,18 +66,14 @@ static void event_privmsg(IRC_SERVER_REC *server, const char *data, g_free(params); } -/* we use "ctcp msg" here because "ctcp msg action" can be ignored with - /IGNORE * CTCPS, and we don't want that.. */ -static void ctcp_msg_check_action(IRC_SERVER_REC *server, const char *data, - const char *nick, const char *addr, - const char *target) +static void ctcp_action(IRC_SERVER_REC *server, const char *data, + const char *nick, const char *addr, + const char *target) { g_return_if_fail(data != NULL); - if (g_strncasecmp(data, "ACTION ", 7) == 0) { - signal_emit("message irc action", 5, - server, data+7, nick, addr, target); - } + signal_emit("message irc action", 5, + server, data, nick, addr, target); } static void event_notice(IRC_SERVER_REC *server, const char *data, @@ -414,15 +410,10 @@ static void event_received(IRC_SERVER_REC *server, const char *data, g_free(params); } -static void sig_empty(void) -{ -} - void fe_events_init(void) { signal_add("event privmsg", (SIGNAL_FUNC) event_privmsg); - signal_add("ctcp msg", (SIGNAL_FUNC) ctcp_msg_check_action); - signal_add("ctcp msg action", (SIGNAL_FUNC) sig_empty); + signal_add("ctcp action", (SIGNAL_FUNC) ctcp_action); signal_add("event notice", (SIGNAL_FUNC) event_notice); signal_add("event join", (SIGNAL_FUNC) event_join); signal_add("event part", (SIGNAL_FUNC) event_part); @@ -451,8 +442,7 @@ void fe_events_init(void) void fe_events_deinit(void) { signal_remove("event privmsg", (SIGNAL_FUNC) event_privmsg); - signal_remove("ctcp msg", (SIGNAL_FUNC) ctcp_msg_check_action); - signal_remove("ctcp msg action", (SIGNAL_FUNC) sig_empty); + signal_remove("ctcp action", (SIGNAL_FUNC) ctcp_action); signal_remove("event notice", (SIGNAL_FUNC) event_notice); signal_remove("event join", (SIGNAL_FUNC) event_join); signal_remove("event part", (SIGNAL_FUNC) event_part); diff --git a/src/irc/core/ctcp.c b/src/irc/core/ctcp.c index 51738438..5b52fb71 100644 --- a/src/irc/core/ctcp.c +++ b/src/irc/core/ctcp.c @@ -224,6 +224,13 @@ static void ctcp_msg(IRC_SERVER_REC *server, const char *data, { char *args, *str; + if (g_strncasecmp(data, "ACTION ", 7) == 0) { + /* special treatment for actions */ + signal_emit("ctcp action", 5, server, data+7, + nick, addr, target); + return; + } + if (ignore_check(SERVER(server), nick, addr, target, data, MSGLEVEL_CTCPS)) return; diff --git a/src/irc/core/irc-queries.c b/src/irc/core/irc-queries.c index 380b12ef..402aa75d 100644 --- a/src/irc/core/irc-queries.c +++ b/src/irc/core/irc-queries.c @@ -40,15 +40,10 @@ QUERY_REC *irc_query_create(const char *server_tag, return rec; } -static void event_privmsg(IRC_SERVER_REC *server, const char *data, - const char *nick, const char *address) +static void check_address_change(IRC_SERVER_REC *server, const char *nick, + const char *address, const char *target) { QUERY_REC *query; - char *params, *target, *msg; - - g_return_if_fail(data != NULL); - - params = event_get_params(data, 2 | PARAM_FLAG_GETREST, &target, &msg); if (address != NULL && !ischannel(*target)) { /* save nick's address to query */ @@ -57,10 +52,28 @@ static void event_privmsg(IRC_SERVER_REC *server, const char *data, strcmp(query->address, address) != 0)) query_change_address(query, address); } +} + +static void event_privmsg(IRC_SERVER_REC *server, const char *data, + const char *nick, const char *address) +{ + char *params, *target, *msg; + + g_return_if_fail(data != NULL); + params = event_get_params(data, 2 | PARAM_FLAG_GETREST, &target, &msg); + check_address_change(server, nick, address, target); g_free(params); } +static void ctcp_action(IRC_SERVER_REC *server, const char *msg, + const char *nick, const char *address, + const char *target) +{ + check_address_change(server, nick, address, target); +} + + static void event_nick(SERVER_REC *server, const char *data, const char *orignick) { @@ -78,11 +91,13 @@ static void event_nick(SERVER_REC *server, const char *data, void irc_queries_init(void) { signal_add_last("event privmsg", (SIGNAL_FUNC) event_privmsg); + signal_add_last("ctcp action", (SIGNAL_FUNC) ctcp_action); signal_add("event nick", (SIGNAL_FUNC) event_nick); } void irc_queries_deinit(void) { signal_remove("event privmsg", (SIGNAL_FUNC) event_privmsg); + signal_remove("ctcp action", (SIGNAL_FUNC) ctcp_action); signal_remove("event nick", (SIGNAL_FUNC) event_nick); } |