From f6c50615909c438b483a70967f77bc0771789f52 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?S=C3=A9bastien=20Helleu?= Date: Mon, 18 Mar 2019 20:39:42 +0100 Subject: irc: fix update of channels modes with arguments when joining a channel (closes #1324) --- src/plugins/irc/irc-mode.c | 2 ++ src/plugins/irc/irc-protocol.c | 10 ++++++---- 2 files changed, 8 insertions(+), 4 deletions(-) (limited to 'src/plugins') diff --git a/src/plugins/irc/irc-mode.c b/src/plugins/irc/irc-mode.c index 34a870aba..d05ae2318 100644 --- a/src/plugins/irc/irc-mode.c +++ b/src/plugins/irc/irc-mode.c @@ -342,11 +342,13 @@ irc_mode_channel_set (struct t_irc_server *server, argc = 0; argv = NULL; if (modes_arguments) + { argv = weechat_string_split (modes_arguments, " ", WEECHAT_STRING_SPLIT_STRIP_LEFT | WEECHAT_STRING_SPLIT_STRIP_RIGHT | WEECHAT_STRING_SPLIT_COLLAPSE_SEPS, 0, &argc); + } current_arg = 0; diff --git a/src/plugins/irc/irc-protocol.c b/src/plugins/irc/irc-protocol.c index 71c9aacab..f82edc339 100644 --- a/src/plugins/irc/irc-protocol.c +++ b/src/plugins/irc/irc-protocol.c @@ -3566,13 +3566,15 @@ IRC_PROTOCOL_CALLBACK(323) IRC_PROTOCOL_CALLBACK(324) { - const char *ptr_modes; + const char *ptr_modes, *ptr_modes_args; struct t_irc_channel *ptr_channel; + IRC_PROTOCOL_MIN_ARGS(4); + ptr_modes = (argc > 4) ? ((argv_eol[4][0] == ':') ? argv_eol[4] + 1 : argv_eol[4]) : NULL; - - IRC_PROTOCOL_MIN_ARGS(4); + ptr_modes_args = (argc > 5) ? + ((argv_eol[5][0] == ':') ? argv_eol[5] + 1 : argv_eol[5]) : NULL; ptr_channel = irc_channel_search (server, argv[3]); if (ptr_channel) @@ -3581,7 +3583,7 @@ IRC_PROTOCOL_CALLBACK(324) if (argc > 4) { (void) irc_mode_channel_set (server, ptr_channel, host, - ptr_modes, NULL); + ptr_modes, ptr_modes_args); } } if (!ptr_channel -- cgit v1.2.3