diff options
Diffstat (limited to 'src/irc')
-rw-r--r-- | src/irc/core/ctcp.c | 7 | ||||
-rw-r--r-- | src/irc/core/irc-queries.c | 29 |
2 files changed, 29 insertions, 7 deletions
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); } |