diff options
author | Sébastien Helleu <flashcode@flashtux.org> | 2022-04-24 22:08:32 +0200 |
---|---|---|
committer | Sébastien Helleu <flashcode@flashtux.org> | 2022-04-24 22:09:19 +0200 |
commit | d4d8117461c20b075332bb3d2a1fc8493d92a9d7 (patch) | |
tree | e504c6e8be502068e11aac49eb956d8c415758ba /src | |
parent | 4d8df89bb5b56bd3ca7b281726722f9d21fefdf8 (diff) | |
download | weechat-d4d8117461c20b075332bb3d2a1fc8493d92a9d7.zip |
irc: remove channel from autojoin option when manually closing a buffer
Diffstat (limited to 'src')
-rw-r--r-- | src/plugins/irc/irc-buffer.c | 15 | ||||
-rw-r--r-- | src/plugins/irc/irc.c | 5 | ||||
-rw-r--r-- | src/plugins/irc/irc.h | 1 |
3 files changed, 20 insertions, 1 deletions
diff --git a/src/plugins/irc/irc-buffer.c b/src/plugins/irc/irc-buffer.c index 1cb129c8d..f29b5ffe2 100644 --- a/src/plugins/irc/irc-buffer.c +++ b/src/plugins/irc/irc-buffer.c @@ -30,6 +30,7 @@ #include "irc-channel.h" #include "irc-command.h" #include "irc-config.h" +#include "irc-join.h" #include "irc-raw.h" #include "irc-server.h" @@ -181,6 +182,20 @@ irc_buffer_close_cb (const void *pointer, void *data, { if (ptr_channel) { + /* + * remove channel from autojoin if autojoin_dynamic is set, + * still connected to server and not quitting/upgrading WeeChat + */ + if (ptr_server + && IRC_SERVER_OPTION_BOOLEAN(ptr_server, + IRC_SERVER_OPTION_AUTOJOIN_DYNAMIC) + && ptr_server->is_connected + && !irc_signal_quit_received + && !irc_signal_upgrade_received) + { + irc_join_remove_channel_from_autojoin (ptr_server, + ptr_channel->name); + } /* send PART for channel if its buffer is closed */ if ((ptr_channel->type == IRC_CHANNEL_TYPE_CHANNEL) && (ptr_channel->nicks)) diff --git a/src/plugins/irc/irc.c b/src/plugins/irc/irc.c index e51a8f05f..e0c892dae 100644 --- a/src/plugins/irc/irc.c +++ b/src/plugins/irc/irc.c @@ -58,7 +58,8 @@ struct t_weechat_plugin *weechat_irc_plugin = NULL; struct t_hook *irc_hook_timer = NULL; -int irc_signal_upgrade_received = 0; /* signal "upgrade" received ? */ +int irc_signal_quit_received = 0; /* signal "quit" received? */ +int irc_signal_upgrade_received = 0; /* signal "upgrade" received? */ /* @@ -77,6 +78,8 @@ irc_signal_quit_cb (const void *pointer, void *data, (void) data; (void) signal; + irc_signal_quit_received = 1; + if (strcmp (type_data, WEECHAT_HOOK_SIGNAL_STRING) == 0) { for (ptr_server = irc_servers; ptr_server; diff --git a/src/plugins/irc/irc.h b/src/plugins/irc/irc.h index cc1ecefb1..519ac1685 100644 --- a/src/plugins/irc/irc.h +++ b/src/plugins/irc/irc.h @@ -26,6 +26,7 @@ extern struct t_weechat_plugin *weechat_irc_plugin; +extern int irc_signal_quit_received; extern int irc_signal_upgrade_received; #endif /* WEECHAT_PLUGIN_IRC_H */ |