X-Git-Url: https://git.quassel-irc.org/?p=quassel.git;a=blobdiff_plain;f=src%2Fcommon%2Fircchannel.cpp;h=6673a79904c761ed21aa81207188082107937459;hp=c111b9fa9fe14fcab54f89ca5440939a391a89ae;hb=4aea5769f4c155234394957aa55360f111c12cbb;hpb=ba1c9e7925671c1393e0ff6b140f68a3dc1fe3cf diff --git a/src/common/ircchannel.cpp b/src/common/ircchannel.cpp index c111b9fa..6673a799 100644 --- a/src/common/ircchannel.cpp +++ b/src/common/ircchannel.cpp @@ -178,7 +178,15 @@ void IrcChannel::joinIrcUsers(const QList &users, const QStringList & for (int i = 0; i < users.count(); i++) { ircuser = users[i]; if (!ircuser || _userModes.contains(ircuser)) { - addUserMode(ircuser, modes[i]); + if (modes[i].count() > 1) { + // Multiple modes received, do it one at a time + // TODO Better way of syncing this without breaking protocol? + for (int i_m = 0; i_m < modes[i].count(); ++i_m) { + addUserMode(ircuser, modes[i][i_m]); + } + } else { + addUserMode(ircuser, modes[i]); + } continue; } @@ -190,6 +198,9 @@ void IrcChannel::joinIrcUsers(const QList &users, const QStringList & // If you wonder why there is no counterpart to ircUserJoined: // the joins are propagated by the ircuser. The signal ircUserJoined is only for convenience + // Also update the IRC user's record of modes; this allows easier tracking + ircuser->addUserModes(modes[i]); + newNicks << ircuser->nick(); newModes << modes[i]; newUsers << ircuser; @@ -280,6 +291,8 @@ void IrcChannel::addUserMode(IrcUser *ircuser, const QString &mode) if (!_userModes[ircuser].contains(mode)) { _userModes[ircuser] += mode; + // Also update the IRC user's record of modes; this allows easier tracking + ircuser->addUserModes(mode); QString nick = ircuser->nick(); SYNC_OTHER(addUserMode, ARG(nick), ARG(mode)) emit ircUserModeAdded(ircuser, mode); @@ -301,6 +314,8 @@ void IrcChannel::removeUserMode(IrcUser *ircuser, const QString &mode) if (_userModes[ircuser].contains(mode)) { _userModes[ircuser].remove(mode); + // Also update the IRC user's record of modes; this allows easier tracking + ircuser->removeUserModes(mode); QString nick = ircuser->nick(); SYNC_OTHER(removeUserMode, ARG(nick), ARG(mode)); emit ircUserModeRemoved(ircuser, mode);