summaryrefslogtreecommitdiff
path: root/src/irc/core/channel-events.c
diff options
context:
space:
mode:
authorTimo Sirainen <cras@irssi.org>2002-05-17 14:49:15 +0000
committercras <cras@dbcabf3a-b0e7-0310-adc4-f8d773084564>2002-05-17 14:49:15 +0000
commitede752530eeae6136b1891f0fdebdea24ebde552 (patch)
tree5b6b73d7b81b6efb7a8d701feb4f07e6d85dffc0 /src/irc/core/channel-events.c
parentc8187a9a76c64ceab07298022b4447b5b82a03de (diff)
downloadirssi-ede752530eeae6136b1891f0fdebdea24ebde552.zip
new !channel support was buggy, as I tried it only with channel names having
less than 5 chars :) Now it works so that if you join !channel, you see it as !channel. If you join !ABCDEchannel, you'll again see that. git-svn-id: http://svn.irssi.org/repos/irssi/trunk@2802 dbcabf3a-b0e7-0310-adc4-f8d773084564
Diffstat (limited to 'src/irc/core/channel-events.c')
-rw-r--r--src/irc/core/channel-events.c21
1 files changed, 13 insertions, 8 deletions
diff --git a/src/irc/core/channel-events.c b/src/irc/core/channel-events.c
index a296938d..02fe0242 100644
--- a/src/irc/core/channel-events.c
+++ b/src/irc/core/channel-events.c
@@ -210,7 +210,7 @@ static IRC_CHANNEL_REC *channel_find_unjoined(IRC_SERVER_REC *server,
static void event_join(IRC_SERVER_REC *server, const char *data, const char *nick, const char *address)
{
- char *params, *channel, *tmp;
+ char *params, *channel, *tmp, *shortchan;
IRC_CHANNEL_REC *chanrec;
g_return_if_fail(data != NULL);
@@ -227,41 +227,46 @@ static void event_join(IRC_SERVER_REC *server, const char *data, const char *nic
tmp = strchr(channel, 7); /* ^G does something weird.. */
if (tmp != NULL) *tmp = '\0';
- if (*channel == '!') {
+ if (*channel != '!')
+ shortchan = NULL;
+ else {
/* !channels have 5 chars long identification string before
it's name, it's not known when /join is called so rename
!channel here to !ABCDEchannel */
- char *shortchan;
-
shortchan = g_strdup_printf("!%s", channel+6);
chanrec = channel_find_unjoined(server, shortchan);
if (chanrec != NULL) {
g_free(chanrec->name);
chanrec->name = g_strdup(channel);
}
-
- g_free(shortchan);
}
chanrec = irc_channel_find(server, channel);
if (chanrec != NULL && chanrec->joined) {
/* already joined this channel - this check was added
here because of broken irssi proxy :) */
+ g_free(shortchan);
g_free(params);
return;
}
- chanrec = channel_find_unjoined(server, channel);
+ if (chanrec == NULL) {
+ /* look again, because of the channel name cut issues. */
+ chanrec = channel_find_unjoined(server, channel);
+ }
+
if (chanrec == NULL) {
/* didn't get here with /join command.. */
- chanrec = irc_channel_create(server, channel, NULL, TRUE);
+ chanrec = irc_channel_create(server, channel, shortchan, TRUE);
}
+
chanrec->joined = TRUE;
if (strcmp(chanrec->name, channel) != 0) {
g_free(chanrec->name);
chanrec->name = g_strdup(channel);
}
+ g_free(shortchan);
g_free(params);
}