summaryrefslogtreecommitdiff
path: root/src/irc/core/channel-rejoin.c
diff options
context:
space:
mode:
authorJilles Tjoelker <jilles@irssi.org>2007-06-03 13:08:47 +0000
committerjilles <jilles@dbcabf3a-b0e7-0310-adc4-f8d773084564>2007-06-03 13:08:47 +0000
commitc0674522aec98aaf588e524ba35ec352f4ff7710 (patch)
tree2023af21f7fb92d1c431ddf2dfdfc2046cd92653 /src/irc/core/channel-rejoin.c
parent273152762f4fe784344ee2a62ea90050fc1f3b8d (diff)
downloadirssi-c0674522aec98aaf588e524ba35ec352f4ff7710.zip
- Repair channels_rejoin_unavailable. Enabled by default,
this retries joins that failed because of netsplits (channel temporarily unavailable (437), duplicate channel) A few servers abuse 437 for juped channels which should not be retried, you should disable channels_rejoin_unavailable if this is a problem. - Display 437 and 407 numerics if channels_rejoin_unavailable is not enabled. Bug #495 git-svn-id: http://svn.irssi.org/repos/irssi/trunk@4537 dbcabf3a-b0e7-0310-adc4-f8d773084564
Diffstat (limited to 'src/irc/core/channel-rejoin.c')
-rw-r--r--src/irc/core/channel-rejoin.c28
1 files changed, 17 insertions, 11 deletions
diff --git a/src/irc/core/channel-rejoin.c b/src/irc/core/channel-rejoin.c
index a89ed21c..30e60d19 100644
--- a/src/irc/core/channel-rejoin.c
+++ b/src/irc/core/channel-rejoin.c
@@ -68,20 +68,23 @@ static REJOIN_REC *rejoin_find(IRC_SERVER_REC *server, const char *channel)
#define channel_have_key(chan) \
((chan) != NULL && (chan)->key != NULL && (chan)->key[0] != '\0')
-static void channel_rejoin(IRC_SERVER_REC *server, const char *channel)
+static int channel_rejoin(IRC_SERVER_REC *server, const char *channel)
{
IRC_CHANNEL_REC *chanrec;
REJOIN_REC *rec;
- g_return_if_fail(IS_IRC_SERVER(server));
- g_return_if_fail(channel != NULL);
-
- if (!settings_get_bool("channels_rejoin_unavailable"))
- return;
+ g_return_val_if_fail(IS_IRC_SERVER(server), 0);
+ g_return_val_if_fail(channel != NULL, 0);
chanrec = irc_channel_find(server, channel);
- if (chanrec == NULL || chanrec->joined) return;
+ if (chanrec == NULL || chanrec->joined) return 0;
+ if (!settings_get_bool("channels_rejoin_unavailable")) {
+ chanrec->left = TRUE;
+ channel_destroy(CHANNEL(chanrec));
+ return 0;
+ }
+
rec = rejoin_find(server, channel);
if (rec != NULL) {
/* already exists */
@@ -105,6 +108,7 @@ static void channel_rejoin(IRC_SERVER_REC *server, const char *channel)
chanrec->left = TRUE;
channel_destroy(CHANNEL(chanrec));
+ return 1;
}
static void event_duplicate_channel(IRC_SERVER_REC *server, const char *data)
@@ -128,8 +132,9 @@ static void event_duplicate_channel(IRC_SERVER_REC *server, const char *data)
note that this same 407 is sent when trying to
create !!channel that already exists so we don't
want to try rejoining then. */
- channel_rejoin(server, channel);
- signal_stop();
+ if (channel_rejoin(server, channel)) {
+ signal_stop();
+ }
}
}
@@ -152,8 +157,9 @@ static void event_target_unavailable(IRC_SERVER_REC *server, const char *data)
} else {
/* channel is unavailable - try to join again
a bit later */
- channel_rejoin(server, channel);
- signal_stop();
+ if (channel_rejoin(server, channel)) {
+ signal_stop();
+ }
}
}