summaryrefslogtreecommitdiff
path: root/src/plugins/irc
diff options
context:
space:
mode:
authorSébastien Helleu <flashcode@flashtux.org>2020-08-05 20:05:36 +0200
committerSébastien Helleu <flashcode@flashtux.org>2020-08-05 20:05:36 +0200
commit0cc5df664955cafab8334d7abc3dfd6dc8bc77cd (patch)
treeae805a153fa5a19cfa911f1a599fcf54df12925c /src/plugins/irc
parent36c55f6973b233c17c6e5baaf46be2e0fb334bb6 (diff)
downloadweechat-0cc5df664955cafab8334d7abc3dfd6dc8bc77cd.zip
irc: send all channels in a single JOIN command when reconnecting to the server (closes #1551)
Diffstat (limited to 'src/plugins/irc')
-rw-r--r--src/plugins/irc/irc-server.c117
1 files changed, 96 insertions, 21 deletions
diff --git a/src/plugins/irc/irc-server.c b/src/plugins/irc/irc-server.c
index 5918ba027..e98749518 100644
--- a/src/plugins/irc/irc-server.c
+++ b/src/plugins/irc/irc-server.c
@@ -5311,39 +5311,114 @@ irc_server_autojoin_create_buffers (struct t_irc_server *server)
}
/*
+ * Build the arguments for JOIN command using channels in server, only if the
+ * channel is not in "part" state (/part command issued).
+ *
+ * The arguments have the following format, where keys are optional (this is
+ * the syntax of JOIN command in IRC protocol):
+ *
+ * #channel1,#channel2,#channel3 key1,key2
+ *
+ * Note: result must be freed after use.
+ */
+
+char *
+irc_server_build_autojoin (struct t_irc_server *server)
+{
+ struct t_irc_channel *ptr_channel;
+ char **channels_with_key, **channels_others, **keys;
+
+ channels_with_key = NULL;
+ channels_others = NULL;
+ keys = NULL;
+
+ channels_with_key = weechat_string_dyn_alloc (1024);
+ if (!channels_with_key)
+ goto error;
+ channels_others = weechat_string_dyn_alloc (1024);
+ if (!channels_others)
+ goto error;
+ keys = weechat_string_dyn_alloc (1024);
+ if (!keys)
+ goto error;
+
+ for (ptr_channel = server->channels; ptr_channel;
+ ptr_channel = ptr_channel->next_channel)
+ {
+ if ((ptr_channel->type == IRC_CHANNEL_TYPE_CHANNEL)
+ && !ptr_channel->part)
+ {
+ if (ptr_channel->key)
+ {
+ /* add channel with key and the key */
+ if (*channels_with_key[0])
+ weechat_string_dyn_concat (channels_with_key, ",");
+ weechat_string_dyn_concat (channels_with_key, ptr_channel->name);
+ if (*keys[0])
+ weechat_string_dyn_concat (keys, ",");
+ weechat_string_dyn_concat (keys, ptr_channel->key);
+ }
+ else
+ {
+ /* add channel without key */
+ if (*channels_others[0])
+ weechat_string_dyn_concat (channels_others, ",");
+ weechat_string_dyn_concat (channels_others, ptr_channel->name);
+ }
+ }
+ }
+
+ /*
+ * concatenate channels_with_key + channels_others + keys
+ * into channels_with_key
+ */
+ if (*channels_others[0])
+ {
+ if (*channels_with_key[0])
+ weechat_string_dyn_concat (channels_with_key, ",");
+ weechat_string_dyn_concat (channels_with_key, *channels_others);
+ }
+ if (*keys[0])
+ {
+ weechat_string_dyn_concat (channels_with_key, " ");
+ weechat_string_dyn_concat (channels_with_key, *keys);
+ }
+
+ weechat_string_dyn_free (channels_others, 1);
+ weechat_string_dyn_free (keys, 1);
+
+ return weechat_string_dyn_free (channels_with_key, 0);
+
+error:
+ if (channels_with_key)
+ weechat_string_dyn_free (channels_with_key, 1);
+ if (channels_others)
+ weechat_string_dyn_free (channels_others, 1);
+ if (keys)
+ weechat_string_dyn_free (keys, 1);
+ return NULL;
+}
+
+/*
* Autojoins (or auto-rejoins) channels.
*/
void
irc_server_autojoin_channels (struct t_irc_server *server)
{
- struct t_irc_channel *ptr_channel;
char *autojoin;
/* auto-join after disconnection (only rejoins opened channels) */
if (!server->disable_autojoin && server->reconnect_join && server->channels)
{
- for (ptr_channel = server->channels; ptr_channel;
- ptr_channel = ptr_channel->next_channel)
+ autojoin = irc_server_build_autojoin (server);
+ if (autojoin)
{
- if ((ptr_channel->type == IRC_CHANNEL_TYPE_CHANNEL)
- && !ptr_channel->part)
- {
- if (ptr_channel->key)
- {
- irc_server_sendf (server,
- IRC_SERVER_SEND_OUTQ_PRIO_HIGH, NULL,
- "JOIN %s %s",
- ptr_channel->name, ptr_channel->key);
- }
- else
- {
- irc_server_sendf (server,
- IRC_SERVER_SEND_OUTQ_PRIO_HIGH, NULL,
- "JOIN %s",
- ptr_channel->name);
- }
- }
+ irc_server_sendf (server,
+ IRC_SERVER_SEND_OUTQ_PRIO_HIGH, NULL,
+ "JOIN %s",
+ autojoin);
+ free (autojoin);
}
server->reconnect_join = 0;
}