summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--src/fe-common/irc/fe-events-numeric.c2
-rw-r--r--src/irc/core/irc-commands.c54
2 files changed, 40 insertions, 16 deletions
diff --git a/src/fe-common/irc/fe-events-numeric.c b/src/fe-common/irc/fe-events-numeric.c
index e42b5e22..a99d6ac3 100644
--- a/src/fe-common/irc/fe-events-numeric.c
+++ b/src/fe-common/irc/fe-events-numeric.c
@@ -502,7 +502,7 @@ static void event_end_of_whowas(const char *data, IRC_SERVER_REC *server)
g_return_if_fail(data != NULL);
params = event_get_params(data, 2, NULL, &nick);
- printformat(server, NULL, MSGLEVEL_CRAP, IRCTXT_END_OF_WHOWAS, nick);
+ if (server->whowas_found) printformat(server, NULL, MSGLEVEL_CRAP, IRCTXT_END_OF_WHOWAS, nick);
g_free(params);
}
diff --git a/src/irc/core/irc-commands.c b/src/irc/core/irc-commands.c
index 24b969ed..a344931b 100644
--- a/src/irc/core/irc-commands.c
+++ b/src/irc/core/irc-commands.c
@@ -452,10 +452,29 @@ static void cmd_names(const char *data, IRC_SERVER_REC *server, WI_IRC_REC *item
irc_send_cmdv(server, "NAMES %s", data);
}
+static char *get_redirect_nicklist(const char *nicks, int *free)
+{
+ char *str, *ret;
+
+ if (strchr(nicks, ',') == NULL) {
+ *free = FALSE;
+ return (char *) nicks;
+ }
+
+ *free = TRUE;
+
+ str = g_strdup(nicks);
+ g_strdelimit(str, ",", ' ');
+ ret = g_strconcat(str, " ", nicks, NULL);
+ g_free(str);
+
+ return ret;
+}
+
static void cmd_whois(const char *data, IRC_SERVER_REC *server)
{
- char *params, *qserver, *query, *nicks;
- int one_nick;
+ char *params, *qserver, *query;
+ int free_nick;
g_return_if_fail(data != NULL);
if (server == NULL || !server->connected || !irc_server_check(server))
@@ -467,31 +486,25 @@ static void cmd_whois(const char *data, IRC_SERVER_REC *server)
params = cmd_get_params(data, 1, &query);
qserver = "";
}
-
if (*query == '\0') query = server->nick;
if (*qserver == '\0')
g_string_sprintf(tmpstr, "WHOIS %s", query);
else
g_string_sprintf(tmpstr, "WHOIS %s %s", qserver, query);
+
+ server->whois_found = FALSE;
irc_send_cmd_split(server, tmpstr->str, 2, server->max_whois_in_cmd);
/* do automatic /WHOWAS if any of the nicks wasn't found */
- one_nick = strchr(query, ',') == NULL;
- if (!one_nick) {
- nicks = g_strdup(query);
- g_strdelimit(query, ",", ' ');
- query = g_strconcat(nicks, " ", query, NULL);
- g_free(nicks);
- }
+ query = get_redirect_nicklist(query, &free_nick);
- server->whois_found = FALSE;
server_redirect_event((SERVER_REC *) server, query, 2,
"event 318", "event 318", 1,
"event 402", "event 402", -1,
"event 311", "whois event", 1,
"event 401", "whois not found", 1, NULL);
- if (!one_nick) g_free(query);
+ if (free_nick) g_free(query);
g_free(params);
}
@@ -526,15 +539,26 @@ static void event_whowas(const char *data, IRC_SERVER_REC *server, const char *n
static void cmd_whowas(const char *data, IRC_SERVER_REC *server)
{
+ char *params, *nicks, *count;
+ int free_nick;
+
g_return_if_fail(data != NULL);
if (server == NULL || !server->connected || !irc_server_check(server))
cmd_return_error(CMDERR_NOT_CONNECTED);
- while (*data == ' ') data++;
- if (*data == '\0') data = server->nick;
+ params = cmd_get_params(data, 2, &nicks, &count);
+ if (*nicks == '\0') nicks = server->nick;
- irc_send_cmdv(server, "WHOWAS %s", data);
server->whowas_found = FALSE;
+ irc_send_cmdv(server, *count == '\0' ? "WHOWAS %s" :
+ "WHOWAS %s %s", nicks, count);
+
+ nicks = get_redirect_nicklist(nicks, &free_nick);
+ server_redirect_event((SERVER_REC *) server, nicks, 1,
+ "event 369", "event 369", 1,
+ "event 314", "whowas event", 1, NULL);
+ if (free_nick) g_free(nicks);
+ g_free(params);
}
static void cmd_ping(const char *data, IRC_SERVER_REC *server, WI_IRC_REC *item)