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

Some events that contained target parameter weren't printed to correct

window (eg. end of bans).


git-svn-id: http://svn.irssi.org/repos/irssi/trunk@2511 dbcabf3a-b0e7-0310-adc4-f8d773084564
This commit is contained in:
Timo Sirainen 2002-02-17 20:20:52 +00:00 committed by cras
parent 4646cb7ec9
commit b8eff2d3b2

View File

@ -33,8 +33,8 @@
#include "printtext.h" #include "printtext.h"
#include "fe-channels.h" #include "fe-channels.h"
static void event_received(IRC_SERVER_REC *server, const char *data, static void print_event_received(IRC_SERVER_REC *server, const char *data,
const char *nick, const char *addr); const char *nick, int target_param);
static char *last_away_nick = NULL; static char *last_away_nick = NULL;
static char *last_away_msg = NULL; static char *last_away_msg = NULL;
@ -414,7 +414,7 @@ static void event_whois_registered(IRC_SERVER_REC *server, const char *data,
IRCTXT_WHOIS_REGISTERED, nick); IRCTXT_WHOIS_REGISTERED, nick);
} else { } else {
/* or /USERIP reply in undernet.. */ /* or /USERIP reply in undernet.. */
event_received(server, data, orignick, addr); print_event_received(server, data, orignick, FALSE);
} }
g_free(params); g_free(params);
} }
@ -469,7 +469,7 @@ static void event_whois_realhost(IRC_SERVER_REC *server, const char *data,
IRCTXT_WHOIS_REALHOST, nick, hostname, ""); IRCTXT_WHOIS_REALHOST, nick, hostname, "");
} else { } else {
/* OPN's dancer uses for end of /MAP */ /* OPN's dancer uses for end of /MAP */
event_received(server, data, orignick, addr); print_event_received(server, data, orignick, FALSE);
} }
g_free(params); g_free(params);
} }
@ -500,7 +500,7 @@ static void event_whois_realhost327(IRC_SERVER_REC *server, const char *data,
printformat(server, nick, MSGLEVEL_CRAP, printformat(server, nick, MSGLEVEL_CRAP,
IRCTXT_WHOIS_REALHOST, nick, hostname, ip); IRCTXT_WHOIS_REALHOST, nick, hostname, ip);
} else { } else {
event_received(server, data, orignick, addr); print_event_received(server, data, orignick, FALSE);
} }
g_free(params); g_free(params);
} }
@ -522,7 +522,7 @@ static void event_whois_usermode(IRC_SERVER_REC *server, const char *data,
} else { } else {
/* some servers use this as motd too.. /* some servers use this as motd too..
and OPN's dancer for /MAP */ and OPN's dancer for /MAP */
event_received(server, data, orignick, addr); print_event_received(server, data, orignick, FALSE);
} }
g_free(params); g_free(params);
} }
@ -641,7 +641,7 @@ static void event_target_unavailable(IRC_SERVER_REC *server, const char *data,
chanrec = irc_channel_find(server, target); chanrec = irc_channel_find(server, target);
if (chanrec != NULL && chanrec->joined) { if (chanrec != NULL && chanrec->joined) {
/* dalnet - can't change nick while being banned */ /* dalnet - can't change nick while being banned */
event_received(server, data, nick, addr); print_event_received(server, data, nick, FALSE);
} else { } else {
/* channel is unavailable. */ /* channel is unavailable. */
printformat(server, NULL, MSGLEVEL_CRAP, printformat(server, NULL, MSGLEVEL_CRAP,
@ -759,17 +759,17 @@ static void event_not_chanop(IRC_SERVER_REC *server, const char *data)
} }
static void event_numeric(IRC_SERVER_REC *server, const char *data, static void event_numeric(IRC_SERVER_REC *server, const char *data,
const char *nick, const char *addr) const char *nick)
{ {
data = strchr(data, ' '); data = strchr(data, ' ');
if (data != NULL) if (data != NULL)
event_received(server, data+1, nick, addr); print_event_received(server, data+1, nick, FALSE);
} }
static void event_received(IRC_SERVER_REC *server, const char *data, static void print_event_received(IRC_SERVER_REC *server, const char *data,
const char *nick, const char *addr) const char *nick, int target_param)
{ {
char *args, *ptr; char *target, *args, *ptr;
g_return_if_fail(data != NULL); g_return_if_fail(data != NULL);
@ -779,6 +779,19 @@ static void event_received(IRC_SERVER_REC *server, const char *data,
return; return;
ptr++; ptr++;
if (!target_param)
target = NULL;
else {
/* target parameter */
target = ptr;
ptr = strchr(target, ' ');
if (ptr == NULL)
return;
target = g_strndup(target, (int) (ptr-target));
ptr++;
}
/* param1 param2 ... :last parameter */ /* param1 param2 ... :last parameter */
if (*ptr == ':') { if (*ptr == ':') {
/* only one parameter */ /* only one parameter */
@ -792,14 +805,26 @@ static void event_received(IRC_SERVER_REC *server, const char *data,
if (nick == NULL || server->real_address == NULL || if (nick == NULL || server->real_address == NULL ||
strcmp(nick, server->real_address) == 0) strcmp(nick, server->real_address) == 0)
printtext(server, NULL, MSGLEVEL_CRAP, "%s", args); printtext(server, target, MSGLEVEL_CRAP, "%s", args);
else { else {
printformat(server, NULL, MSGLEVEL_CRAP, printformat(server, target, MSGLEVEL_CRAP,
IRCTXT_DEFAULT_EVENT, nick, args); IRCTXT_DEFAULT_EVENT, nick, args);
} }
g_free(args); g_free(args);
} }
static void event_received(IRC_SERVER_REC *server, const char *data,
const char *nick)
{
print_event_received(server, data, nick, FALSE);
}
static void event_target_received(IRC_SERVER_REC *server, const char *data,
const char *nick)
{
print_event_received(server, data, nick, TRUE);
}
static void event_motd(IRC_SERVER_REC *server, const char *data, static void event_motd(IRC_SERVER_REC *server, const char *data,
const char *nick, const char *addr) const char *nick, const char *addr)
{ {
@ -809,7 +834,7 @@ static void event_motd(IRC_SERVER_REC *server, const char *data,
time(NULL)-3 <= server->real_connect_time) time(NULL)-3 <= server->real_connect_time)
return; return;
event_received(server, data, nick, addr); print_event_received(server, data, nick, FALSE);
} }
static void sig_empty(void) static void sig_empty(void)
@ -892,11 +917,11 @@ void fe_events_numeric_init(void)
signal_add("event 438", (SIGNAL_FUNC) event_received); signal_add("event 438", (SIGNAL_FUNC) event_received);
signal_add("event 465", (SIGNAL_FUNC) event_received); signal_add("event 465", (SIGNAL_FUNC) event_received);
signal_add("event 368", (SIGNAL_FUNC) event_received); signal_add("event 368", (SIGNAL_FUNC) event_target_received);
signal_add("event 347", (SIGNAL_FUNC) event_received); signal_add("event 347", (SIGNAL_FUNC) event_target_received);
signal_add("event 349", (SIGNAL_FUNC) event_received); signal_add("event 349", (SIGNAL_FUNC) event_target_received);
signal_add("event 442", (SIGNAL_FUNC) event_received); signal_add("event 442", (SIGNAL_FUNC) event_target_received);
signal_add("event 477", (SIGNAL_FUNC) event_received); signal_add("event 477", (SIGNAL_FUNC) event_target_received);
} }
void fe_events_numeric_deinit(void) void fe_events_numeric_deinit(void)
@ -975,9 +1000,9 @@ void fe_events_numeric_deinit(void)
signal_remove("event 438", (SIGNAL_FUNC) event_received); signal_remove("event 438", (SIGNAL_FUNC) event_received);
signal_remove("event 465", (SIGNAL_FUNC) event_received); signal_remove("event 465", (SIGNAL_FUNC) event_received);
signal_remove("event 368", (SIGNAL_FUNC) event_received); signal_remove("event 368", (SIGNAL_FUNC) event_target_received);
signal_remove("event 347", (SIGNAL_FUNC) event_received); signal_remove("event 347", (SIGNAL_FUNC) event_target_received);
signal_remove("event 349", (SIGNAL_FUNC) event_received); signal_remove("event 349", (SIGNAL_FUNC) event_target_received);
signal_remove("event 442", (SIGNAL_FUNC) event_received); signal_remove("event 442", (SIGNAL_FUNC) event_target_received);
signal_remove("event 477", (SIGNAL_FUNC) event_received); signal_remove("event 477", (SIGNAL_FUNC) event_target_received);
} }