refactor out mode-applying into a separate method
authorMartin T. H. Sandsmark <martin.sandsmark@kde.org>
Wed, 26 Dec 2012 20:46:59 +0000 (21:46 +0100)
committerMartin T. H. Sandsmark <martin.sandsmark@kde.org>
Wed, 26 Dec 2012 20:46:59 +0000 (21:46 +0100)
src/core/coreuserinputhandler.cpp
src/core/coreuserinputhandler.h

index 45c71f0..b873b40 100644 (file)
@@ -226,34 +226,64 @@ void CoreUserInputHandler::handleDelkey(const BufferInfo &bufferInfo, const QStr
 #endif
 }
 
 #endif
 }
 
+void CoreUserInputHandler::doMode(const BufferInfo &bufferInfo, const QChar& addOrRemove, const QChar& mode, QStringList nicks)
+{
+    QString m;
+    bool isNumber;
+    int maxModes = network()->support("MODES").toInt(&isNumber);
+    if (!isNumber || maxModes == 0) maxModes = 1;
+    
+    if (nicks.count() == 0) return;
+    
+    while (!nicks.isEmpty()) {
+        int amount = qMin(nicks.count(), maxModes);
+        QString m = addOrRemove; for(int i = 0; i < amount; i++) m += mode;
+        QStringList params;
+        params << bufferInfo.bufferName() << m;
+        for(int i = 0; i < amount; i++) params << nicks.takeFirst();
+        emit putCmd("MODE", serverEncode(params));
+    }
+}
+
 
 void CoreUserInputHandler::handleDeop(const BufferInfo &bufferInfo, const QString &msg)
 {
     QStringList nicks = msg.split(' ', QString::SkipEmptyParts);
 
 void CoreUserInputHandler::handleDeop(const BufferInfo &bufferInfo, const QString &msg)
 {
     QStringList nicks = msg.split(' ', QString::SkipEmptyParts);
-    QString m = "-"; for (int i = 0; i < nicks.count(); i++) m += 'o';
-    QStringList params;
-    params << bufferInfo.bufferName() << m << nicks;
-    emit putCmd("MODE", serverEncode(params));
+    doMode(bufferInfo, '-', 'o', nicks);
 }
 
 
 void CoreUserInputHandler::handleDehalfop(const BufferInfo &bufferInfo, const QString &msg)
 {
     QStringList nicks = msg.split(' ', QString::SkipEmptyParts);
 }
 
 
 void CoreUserInputHandler::handleDehalfop(const BufferInfo &bufferInfo, const QString &msg)
 {
     QStringList nicks = msg.split(' ', QString::SkipEmptyParts);
-    QString m = "-"; for (int i = 0; i < nicks.count(); i++) m += 'h';
-    QStringList params;
-    params << bufferInfo.bufferName() << m << nicks;
-    emit putCmd("MODE", serverEncode(params));
+    doMode(bufferInfo, '-', 'h', nicks);
 }
 
 
 void CoreUserInputHandler::handleDevoice(const BufferInfo &bufferInfo, const QString &msg)
 {
     QStringList nicks = msg.split(' ', QString::SkipEmptyParts);
 }
 
 
 void CoreUserInputHandler::handleDevoice(const BufferInfo &bufferInfo, const QString &msg)
 {
     QStringList nicks = msg.split(' ', QString::SkipEmptyParts);
-    QString m = "-"; for (int i = 0; i < nicks.count(); i++) m += 'v';
-    QStringList params;
-    params << bufferInfo.bufferName() << m << nicks;
-    emit putCmd("MODE", serverEncode(params));
+    doMode(bufferInfo, '-', 'v', nicks);
+}
+
+void CoreUserInputHandler::handleHalfop(const BufferInfo &bufferInfo, const QString &msg)
+{
+    QStringList nicks = msg.split(' ', QString::SkipEmptyParts);
+    doMode(bufferInfo, '+', 'h', nicks);
+}
+
+void CoreUserInputHandler::handleOp(const BufferInfo &bufferInfo, const QString &msg) {
+  QStringList nicks;
+  if (msg == "*") {
+    const QList<IrcUser*> users = network()->ircChannel(bufferInfo.bufferName())->ircUsers();
+    foreach(IrcUser *user, users) {
+      if (!network()->ircChannel(bufferInfo.bufferName())->userModes(user).contains("o"))
+    nicks.append(user->nick());
+    }
+  } else { 
+    nicks = msg.split(' ', QString::SkipEmptyParts);
+  }
+  doMode(bufferInfo, '+', 'o', nicks);
 }
 
 
 }
 
 
@@ -427,42 +457,6 @@ void CoreUserInputHandler::handleNotice(const BufferInfo &bufferInfo, const QStr
 }
 
 
 }
 
 
-void CoreUserInputHandler::handleHalfop(const BufferInfo &bufferInfo, const QString &msg)
-{
-    QStringList nicks = msg.split(' ', QString::SkipEmptyParts);
-    QString m = "+"; for (int i = 0; i < nicks.count(); i++) m += 'h';
-    QStringList params;
-    params << bufferInfo.bufferName() << m << nicks;
-    emit putCmd("MODE", serverEncode(params));
-}
-
-void CoreUserInputHandler::handleOp(const BufferInfo &bufferInfo, const QString &msg) {
-  QStringList nicks;
-  if (msg == "*") {
-    const QList<IrcUser*> users = network()->ircChannel(bufferInfo.bufferName())->ircUsers();
-    foreach(IrcUser *user, users) {
-      if (!network()->ircChannel(bufferInfo.bufferName())->userModes(user).contains("o"))
-       nicks.append(user->nick());
-    }
-  } else { 
-    nicks = msg.split(' ', QString::SkipEmptyParts);
-  }
-  if (nicks.count() == 0) return;
-  
-  bool isNumber;
-  int maxModes = network()->support("MODES").toInt(&isNumber);
-  if (!isNumber || maxModes == 0) maxModes = 1;
-  
-  while (!nicks.isEmpty()) {
-    int amount = qMin(nicks.count(), maxModes);
-    QString m = "+"; for(int i = 0; i < amount; i++) m += 'o';
-    QStringList params;
-    params << bufferInfo.bufferName() << m;
-    for(int i = 0; i < amount; i++) params << nicks.takeFirst();
-    emit putCmd("MODE", serverEncode(params));
-  }
-}
-
 
 void CoreUserInputHandler::handleOper(const BufferInfo &bufferInfo, const QString &msg)
 {
 
 void CoreUserInputHandler::handleOper(const BufferInfo &bufferInfo, const QString &msg)
 {
index 6f559c5..1375bd7 100644 (file)
@@ -83,6 +83,7 @@ protected:
     void timerEvent(QTimerEvent *event);
 
 private:
     void timerEvent(QTimerEvent *event);
 
 private:
+    void doMode(const BufferInfo& bufferInfo, const QChar& addOrRemove, const QChar& mode, QStringList nicks);
     void banOrUnban(const BufferInfo &bufferInfo, const QString &text, bool ban);
     void putPrivmsg(const QByteArray &target, const QByteArray &message, Cipher *cipher = 0);
     int lastParamOverrun(const QString &cmd, const QList<QByteArray> &params);
     void banOrUnban(const BufferInfo &bufferInfo, const QString &text, bool ban);
     void putPrivmsg(const QByteArray &target, const QByteArray &message, Cipher *cipher = 0);
     int lastParamOverrun(const QString &cmd, const QList<QByteArray> &params);