From 84c1f1572d2f41c8c41b9456e5c9eb690b4f5613 Mon Sep 17 00:00:00 2001 From: Valentin Lorentz Date: Fri, 20 Sep 2019 21:23:49 +0200 Subject: [PATCH] Don't temporarily set msg.channel to invalid values. This causes issue when multiple command threads deal with the same message. --- src/irclib.py | 12 ++++++------ 1 file changed, 6 insertions(+), 6 deletions(-) diff --git a/src/irclib.py b/src/irclib.py index f38e20ff3..af3d42967 100644 --- a/src/irclib.py +++ b/src/irclib.py @@ -886,15 +886,15 @@ class Irc(IrcCommandDispatcher, log.Firewalled): self._setMsgChannel(msg) def _setMsgChannel(self, msg): + channel = None if msg.args: - msg.channel = msg.args[0] + channel = msg.args[0] if msg.command in ('NOTICE', 'PRIVMSG') and \ not conf.supybot.protocols.irc.strictRfc(): - msg.channel = self.stripChannelPrefix(msg.channel) - if not self.isChannel(msg.channel): - msg.channel = None - else: - msg.channel = None + channel = self.stripChannelPrefix(channel) + if not self.isChannel(channel): + channel = None + msg.channel = channel def stripChannelPrefix(self, channel): statusmsg_chars = self.state.supported.get('statusmsg', '')