summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--src/irc/core/channels-query.c15
1 files changed, 10 insertions, 5 deletions
diff --git a/src/irc/core/channels-query.c b/src/irc/core/channels-query.c
index bbb7eb8b..731e5bd2 100644
--- a/src/irc/core/channels-query.c
+++ b/src/irc/core/channels-query.c
@@ -444,12 +444,12 @@ static void event_end_of_who(IRC_SERVER_REC *server, const char *data)
SERVER_QUERY_REC *rec;
GSList *tmp, *next;
char *params, *channel;
- int failed;
+ int failed, multiple;
g_return_if_fail(data != NULL);
params = event_get_params(data, 2, NULL, &channel);
- server->one_endofwho = strchr(channel, ',') != NULL;
+ multiple = strchr(channel, ',') != NULL;
failed = FALSE;
rec = server->chanqueries;
@@ -457,19 +457,24 @@ static void event_end_of_who(IRC_SERVER_REC *server, const char *data)
IRC_CHANNEL_REC *chanrec = tmp->data;
next = tmp->next;
- if (chanrec->ownnick->host == NULL && !server->one_endofwho) {
+ if (chanrec->ownnick->host == NULL && multiple &&
+ !server->one_endofwho) {
/* we should receive our own host for each channel.
However, some servers really are stupid enough
not to reply anything to /WHO requests.. */
failed = TRUE;
- } else {
+ } else if (chanrec->ownnick->host != NULL ||
+ server->one_endofwho) {
chanrec->wholist = TRUE;
signal_emit("channel wholist", 1, chanrec);
channel_got_query(chanrec, CHANNEL_QUERY_WHO);
}
}
- if (server->one_endofwho && failed) {
+ if (multiple)
+ server->one_endofwho = TRUE;
+
+ if (failed) {
/* server didn't understand multiple WHO replies,
send them again separately */
query_current_error(server);