X-Git-Url: https://git.quassel-irc.org/?p=quassel.git;a=blobdiff_plain;f=src%2Fcommon%2Fircchannel.cpp;h=09323067151fbfec4da59e944413a8830933c6f2;hp=6673a79904c761ed21aa81207188082107937459;hb=299bb29099bdfac07f6b318b62f5f4c50d7493e3;hpb=de8cb8bb24c3bfd5600726e99acccb080a5beb87 diff --git a/src/common/ircchannel.cpp b/src/common/ircchannel.cpp index 6673a799..09323067 100644 --- a/src/common/ircchannel.cpp +++ b/src/common/ircchannel.cpp @@ -1,5 +1,5 @@ /*************************************************************************** - * Copyright (C) 2005-2015 by the Quassel Project * + * Copyright (C) 2005-2018 by the Quassel Project * * devel@quassel-irc.org * * * * This program is free software; you can redistribute it and/or modify * @@ -61,7 +61,7 @@ bool IrcChannel::isKnownUser(IrcUser *ircuser) const } if (!_userModes.contains(ircuser)) { - qWarning() << "Channel" << name() << "received data for unknown User" << ircuser->nick(); + // This can happen e.g. when disconnecting from a network, so don't log a warning return false; } @@ -170,6 +170,9 @@ void IrcChannel::joinIrcUsers(const QList &users, const QStringList & return; } + // Sort user modes first + const QStringList sortedModes = network()->sortPrefixModes(modes); + QStringList newNicks; QStringList newModes; QList newUsers; @@ -177,20 +180,22 @@ void IrcChannel::joinIrcUsers(const QList &users, const QStringList & IrcUser *ircuser; for (int i = 0; i < users.count(); i++) { ircuser = users[i]; - if (!ircuser || _userModes.contains(ircuser)) { - if (modes[i].count() > 1) { + if (!ircuser) + continue; + if (_userModes.contains(ircuser)) { + if (sortedModes[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]); + for (int i_m = 0; i_m < sortedModes[i].count(); ++i_m) { + addUserMode(ircuser, sortedModes[i][i_m]); } } else { - addUserMode(ircuser, modes[i]); + addUserMode(ircuser, sortedModes[i]); } continue; } - _userModes[ircuser] = modes[i]; + _userModes[ircuser] = sortedModes[i]; ircuser->joinChannel(this, true); connect(ircuser, SIGNAL(nickSet(QString)), this, SLOT(ircUserNickSet(QString))); @@ -198,11 +203,8 @@ 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]; + newModes << sortedModes[i]; newUsers << ircuser; } @@ -269,7 +271,8 @@ void IrcChannel::part(const QString &nick) void IrcChannel::setUserModes(IrcUser *ircuser, const QString &modes) { if (isKnownUser(ircuser)) { - _userModes[ircuser] = modes; + // Keep user modes sorted + _userModes[ircuser] = network()->sortPrefixModes(modes); QString nick = ircuser->nick(); SYNC_OTHER(setUserModes, ARG(nick), ARG(modes)) emit ircUserModesSet(ircuser, modes); @@ -290,9 +293,8 @@ void IrcChannel::addUserMode(IrcUser *ircuser, const QString &mode) return; if (!_userModes[ircuser].contains(mode)) { - _userModes[ircuser] += mode; - // Also update the IRC user's record of modes; this allows easier tracking - ircuser->addUserModes(mode); + // Keep user modes sorted + _userModes[ircuser] = network()->sortPrefixModes(_userModes[ircuser] + mode); QString nick = ircuser->nick(); SYNC_OTHER(addUserMode, ARG(nick), ARG(mode)) emit ircUserModeAdded(ircuser, mode); @@ -313,9 +315,8 @@ void IrcChannel::removeUserMode(IrcUser *ircuser, const QString &mode) return; if (_userModes[ircuser].contains(mode)) { + // Removing modes shouldn't mess up ordering _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); @@ -352,6 +353,7 @@ void IrcChannel::initSetUserModes(const QVariantMap &usermodes) modes << iter.value().toString(); ++iter; } + // joinIrcUsers handles sorting modes joinIrcUsers(users, modes); } @@ -562,9 +564,8 @@ bool IrcChannel::hasMode(const QChar &mode) const return _C_channelModes.contains(mode); case Network::D_CHANMODE: return _D_channelModes.contains(mode); - default: - return false; } + return false; } @@ -597,9 +598,11 @@ QStringList IrcChannel::modeValueList(const QChar &mode) const case Network::A_CHANMODE: if (_A_channelModes.contains(mode)) return _A_channelModes[mode]; + break; default: - return QStringList(); + ; } + return {}; }