Refactoring of BasicHandler
authorSebastian Goth <seezer@roath.org>
Sun, 31 Jan 2010 18:05:16 +0000 (19:05 +0100)
committerSebastian Goth <seezer@roath.org>
Sun, 31 Jan 2010 18:21:00 +0000 (19:21 +0100)
- BasicHandler moved from core/ to common/
We can use that in the client too (ClientInuptHandler etc.)

- core/BasicHandler is now CoreBasicHandler

12 files changed:
src/common/CMakeLists.txt
src/common/basichandler.cpp [new file with mode: 0644]
src/common/basichandler.h [new file with mode: 0644]
src/core/CMakeLists.txt
src/core/corebasichandler.cpp [moved from src/core/basichandler.cpp with 51% similarity]
src/core/corebasichandler.h [moved from src/core/basichandler.h with 77% similarity]
src/core/coreuserinputhandler.cpp
src/core/coreuserinputhandler.h
src/core/ctcphandler.cpp
src/core/ctcphandler.h
src/core/ircserverhandler.cpp
src/core/ircserverhandler.h

index f8337cb..30eed02 100644 (file)
@@ -7,6 +7,7 @@ include(${QT_USE_FILE})
 set(SOURCES
     aliasmanager.cpp
     backlogmanager.cpp
+    basichandler.cpp
     bufferinfo.cpp
     buffersyncer.cpp
     bufferviewconfig.cpp
@@ -37,6 +38,7 @@ endif(CMAKE_HOST_UNIX)
 set(MOC_HDRS
     aliasmanager.h
     backlogmanager.h
+    basichandler.h
     buffersyncer.h
     bufferviewconfig.h
     bufferviewmanager.h
diff --git a/src/common/basichandler.cpp b/src/common/basichandler.cpp
new file mode 100644 (file)
index 0000000..59fba8a
--- /dev/null
@@ -0,0 +1,84 @@
+/***************************************************************************
+ *   Copyright (C) 2005-10 by the Quassel Project                          *
+ *   devel@quassel-irc.org                                                 *
+ *                                                                         *
+ *   This program is free software; you can redistribute it and/or modify  *
+ *   it under the terms of the GNU General Public License as published by  *
+ *   the Free Software Foundation; either version 2 of the License, or     *
+ *   (at your option) version 3.                                           *
+ *                                                                         *
+ *   This program is distributed in the hope that it will be useful,       *
+ *   but WITHOUT ANY WARRANTY; without even the implied warranty of        *
+ *   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the         *
+ *   GNU General Public License for more details.                          *
+ *                                                                         *
+ *   You should have received a copy of the GNU General Public License     *
+ *   along with this program; if not, write to the                         *
+ *   Free Software Foundation, Inc.,                                       *
+ *   59 Temple Place - Suite 330, Boston, MA  02111-1307, USA.             *
+ ***************************************************************************/
+#include "basichandler.h"
+
+#include <QMetaMethod>
+
+#include "logger.h"
+
+BasicHandler::BasicHandler(QObject *parent)
+  : QObject(parent),
+    defaultHandler(-1),
+    initDone(false)
+{
+}
+
+QStringList BasicHandler::providesHandlers() {
+  return handlerHash().keys();
+}
+
+const QHash<QString, int> &BasicHandler::handlerHash() {
+  if(!initDone) {
+    for(int i = metaObject()->methodOffset(); i < metaObject()->methodCount(); i++) {
+      QString methodSignature(metaObject()->method(i).signature());
+      if(methodSignature.startsWith("defaultHandler")) {
+       defaultHandler = i;
+       continue;
+      }
+      
+      if(!methodSignature.startsWith("handle"))
+       continue;
+      
+      methodSignature = methodSignature.section('(',0,0);  // chop the attribute list
+      methodSignature = methodSignature.mid(6); // strip "handle"
+      _handlerHash[methodSignature] = i;
+    }
+    initDone = true;
+  }
+  return _handlerHash;
+}
+
+void BasicHandler::handle(const QString &member, QGenericArgument val0,
+                         QGenericArgument val1, QGenericArgument val2,
+                         QGenericArgument val3, QGenericArgument val4,
+                         QGenericArgument val5, QGenericArgument val6,
+                         QGenericArgument val7, QGenericArgument val8) {
+  // Now we try to find a handler for this message. BTW, I do love the Trolltech guys ;-)
+  // and now we even have a fast lookup! Thanks thiago!
+
+  QString handler = member.toLower();
+  handler[0] = handler[0].toUpper();
+
+  if(!handlerHash().contains(handler)) {
+    if(defaultHandler == -1) {
+      qWarning() << QString("No such Handler: %1::handle%2").arg(metaObject()->className(), handler);
+      return;
+    } else {
+      void *param[] = {0, Q_ARG(QString, member).data(), val0.data(), val1.data(), val2.data(), val3.data(), val4.data(),
+                      val5.data(), val6.data(), val7.data(), val8.data(), val8.data()};
+      qt_metacall(QMetaObject::InvokeMetaMethod, defaultHandler, param);
+      return;
+    }
+  }
+
+  void *param[] = {0, val0.data(), val1.data(), val2.data(), val3.data(), val4.data(),
+                  val5.data(), val6.data(), val7.data(), val8.data(), val8.data(), 0};
+  qt_metacall(QMetaObject::InvokeMetaMethod, handlerHash()[handler], param);
+}
diff --git a/src/common/basichandler.h b/src/common/basichandler.h
new file mode 100644 (file)
index 0000000..5bfafe9
--- /dev/null
@@ -0,0 +1,51 @@
+/***************************************************************************
+ *   Copyright (C) 2005-10 by the Quassel Project                          *
+ *   devel@quassel-irc.org                                                 *
+ *                                                                         *
+ *   This program is free software; you can redistribute it and/or modify  *
+ *   it under the terms of the GNU General Public License as published by  *
+ *   the Free Software Foundation; either version 2 of the License, or     *
+ *   (at your option) version 3.                                           *
+ *                                                                         *
+ *   This program is distributed in the hope that it will be useful,       *
+ *   but WITHOUT ANY WARRANTY; without even the implied warranty of        *
+ *   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the         *
+ *   GNU General Public License for more details.                          *
+ *                                                                         *
+ *   You should have received a copy of the GNU General Public License     *
+ *   along with this program; if not, write to the                         *
+ *   Free Software Foundation, Inc.,                                       *
+ *   59 Temple Place - Suite 330, Boston, MA  02111-1307, USA.             *
+ ***************************************************************************/
+
+#ifndef BASICHANDLER_H
+#define BASICHANDLER_H
+
+#include <QObject>
+#include <QString>
+#include <QStringList>
+#include <QHash>
+#include <QGenericArgument>
+
+class BasicHandler : public QObject {
+  Q_OBJECT
+
+public:
+  BasicHandler(QObject *parent = 0);
+
+  QStringList providesHandlers();
+
+protected:
+  virtual void handle(const QString &member, QGenericArgument val0 = QGenericArgument(0),
+                      QGenericArgument val1 = QGenericArgument(), QGenericArgument val2 = QGenericArgument(),
+                      QGenericArgument val3 = QGenericArgument(), QGenericArgument val4 = QGenericArgument(),
+                      QGenericArgument val5 = QGenericArgument(), QGenericArgument val6 = QGenericArgument(),
+                      QGenericArgument val7 = QGenericArgument(), QGenericArgument val8 = QGenericArgument());
+
+private:
+  const QHash<QString, int> &handlerHash();
+  QHash<QString, int> _handlerHash;
+  int defaultHandler;
+  bool initDone;
+};
+#endif
index ccf5aec..3b7e24e 100644 (file)
@@ -8,11 +8,11 @@ include(${QT_USE_FILE})
 
 set(SOURCES
     abstractsqlstorage.cpp
-    basichandler.cpp
     core.cpp
     corealiasmanager.cpp
     coreapplication.cpp
     corebacklogmanager.cpp
+    corebasichandler.cpp
     corebuffersyncer.cpp
     corebufferviewconfig.cpp
     corebufferviewmanager.cpp
@@ -37,11 +37,11 @@ set(SOURCES
 
 set(MOC_HDRS
     abstractsqlstorage.h
-    basichandler.h
     core.h
     corealiasmanager.h
     coreapplication.h
     corebacklogmanager.h
+    corebasichandler.h
     corebuffersyncer.h
     corebufferviewconfig.h
     corebufferviewmanager.h
similarity index 51%
rename from src/core/basichandler.cpp
rename to src/core/corebasichandler.cpp
index a053b52..d15a594 100644 (file)
  *   Free Software Foundation, Inc.,                                       *
  *   59 Temple Place - Suite 330, Boston, MA  02111-1307, USA.             *
  ***************************************************************************/
-#include "basichandler.h"
-
-#include <QMetaMethod>
+#include "corebasichandler.h"
 
 #include "util.h"
 #include "logger.h"
 
-BasicHandler::BasicHandler(CoreNetwork *parent)
-  : QObject(parent),
-    defaultHandler(-1),
-    _network(parent),
-    initDone(false)
+CoreBasicHandler::CoreBasicHandler(CoreNetwork *parent)
+  : BasicHandler(parent),
+    _network(parent)
 {
   connect(this, SIGNAL(displayMsg(Message::Type, BufferInfo::Type, const QString &, const QString &, const QString &, Message::Flags)),
          network(), SLOT(displayMsg(Message::Type, BufferInfo::Type, const QString &, const QString &, const QString &, Message::Flags)));
 
   connect(this, SIGNAL(putCmd(QString, const QList<QByteArray> &, const QByteArray &)),
-         network(), SLOT(putCmd(QString, const QList<QByteArray> &, const QByteArray &)));
+    network(), SLOT(putCmd(QString, const QList<QByteArray> &, const QByteArray &)));
 
   connect(this, SIGNAL(putRawLine(const QByteArray &)),
           network(), SLOT(putRawLine(const QByteArray &)));
 }
 
-QStringList BasicHandler::providesHandlers() {
-  return handlerHash().keys();
-}
-
-const QHash<QString, int> &BasicHandler::handlerHash() {
-  if(!initDone) {
-    for(int i = metaObject()->methodOffset(); i < metaObject()->methodCount(); i++) {
-      QString methodSignature(metaObject()->method(i).signature());
-      if(methodSignature.startsWith("defaultHandler")) {
-       defaultHandler = i;
-       continue;
-      }
-      
-      if(!methodSignature.startsWith("handle"))
-       continue;
-      
-      methodSignature = methodSignature.section('(',0,0);  // chop the attribute list
-      methodSignature = methodSignature.mid(6); // strip "handle"
-      _handlerHash[methodSignature] = i;
-    }
-    initDone = true;
-  }
-  return _handlerHash;
-}
-
-void BasicHandler::handle(const QString &member, QGenericArgument val0,
-                         QGenericArgument val1, QGenericArgument val2,
-                         QGenericArgument val3, QGenericArgument val4,
-                         QGenericArgument val5, QGenericArgument val6,
-                         QGenericArgument val7, QGenericArgument val8) {
-  // Now we try to find a handler for this message. BTW, I do love the Trolltech guys ;-)
-  // and now we even have a fast lookup! Thanks thiago!
-
-  QString handler = member.toLower();
-  handler[0] = handler[0].toUpper();
-
-  if(!handlerHash().contains(handler)) {
-    if(defaultHandler == -1) {
-      qWarning() << QString("No such Handler: %1::handle%2").arg(metaObject()->className(), handler);
-      return;
-    } else {
-      void *param[] = {0, Q_ARG(QString, member).data(), val0.data(), val1.data(), val2.data(), val3.data(), val4.data(),
-                      val5.data(), val6.data(), val7.data(), val8.data(), val8.data()};
-      qt_metacall(QMetaObject::InvokeMetaMethod, defaultHandler, param);
-      return;
-    }
-  }
-
-  void *param[] = {0, val0.data(), val1.data(), val2.data(), val3.data(), val4.data(),
-                  val5.data(), val6.data(), val7.data(), val8.data(), val8.data(), 0};
-  qt_metacall(QMetaObject::InvokeMetaMethod, handlerHash()[handler], param);
-}
-
-QString BasicHandler::serverDecode(const QByteArray &string) {
+QString CoreBasicHandler::serverDecode(const QByteArray &string) {
   return network()->serverDecode(string);
 }
 
-QStringList BasicHandler::serverDecode(const QList<QByteArray> &stringlist) {
+QStringList CoreBasicHandler::serverDecode(const QList<QByteArray> &stringlist) {
   QStringList list;
   foreach(QByteArray s, stringlist) list << network()->serverDecode(s);
   return list;
 }
 
-QString BasicHandler::channelDecode(const QString &bufferName, const QByteArray &string) {
+QString CoreBasicHandler::channelDecode(const QString &bufferName, const QByteArray &string) {
   return network()->channelDecode(bufferName, string);
 }
 
-QStringList BasicHandler::channelDecode(const QString &bufferName, const QList<QByteArray> &stringlist) {
+QStringList CoreBasicHandler::channelDecode(const QString &bufferName, const QList<QByteArray> &stringlist) {
   QStringList list;
   foreach(QByteArray s, stringlist) list << network()->channelDecode(bufferName, s);
   return list;
 }
 
-QString BasicHandler::userDecode(const QString &userNick, const QByteArray &string) {
+QString CoreBasicHandler::userDecode(const QString &userNick, const QByteArray &string) {
   return network()->userDecode(userNick, string);
 }
 
-QStringList BasicHandler::userDecode(const QString &userNick, const QList<QByteArray> &stringlist) {
+QStringList CoreBasicHandler::userDecode(const QString &userNick, const QList<QByteArray> &stringlist) {
   QStringList list;
   foreach(QByteArray s, stringlist) list << network()->userDecode(userNick, s);
   return list;
@@ -125,31 +68,31 @@ QStringList BasicHandler::userDecode(const QString &userNick, const QList<QByteA
 
 /*** ***/
 
-QByteArray BasicHandler::serverEncode(const QString &string) {
+QByteArray CoreBasicHandler::serverEncode(const QString &string) {
   return network()->serverEncode(string);
 }
 
-QList<QByteArray> BasicHandler::serverEncode(const QStringList &stringlist) {
+QList<QByteArray> CoreBasicHandler::serverEncode(const QStringList &stringlist) {
   QList<QByteArray> list;
   foreach(QString s, stringlist) list << network()->serverEncode(s);
   return list;
 }
 
-QByteArray BasicHandler::channelEncode(const QString &bufferName, const QString &string) {
+QByteArray CoreBasicHandler::channelEncode(const QString &bufferName, const QString &string) {
   return network()->channelEncode(bufferName, string);
 }
 
-QList<QByteArray> BasicHandler::channelEncode(const QString &bufferName, const QStringList &stringlist) {
+QList<QByteArray> CoreBasicHandler::channelEncode(const QString &bufferName, const QStringList &stringlist) {
   QList<QByteArray> list;
   foreach(QString s, stringlist) list << network()->channelEncode(bufferName, s);
   return list;
 }
 
-QByteArray BasicHandler::userEncode(const QString &userNick, const QString &string) {
+QByteArray CoreBasicHandler::userEncode(const QString &userNick, const QString &string) {
   return network()->userEncode(userNick, string);
 }
 
-QList<QByteArray> BasicHandler::userEncode(const QString &userNick, const QStringList &stringlist) {
+QList<QByteArray> CoreBasicHandler::userEncode(const QString &userNick, const QStringList &stringlist) {
   QList<QByteArray> list;
   foreach(QString s, stringlist) list << network()->userEncode(userNick, s);
   return list;
@@ -158,7 +101,7 @@ QList<QByteArray> BasicHandler::userEncode(const QString &userNick, const QStrin
 // ====================
 //  protected:
 // ====================
-BufferInfo::Type BasicHandler::typeByTarget(const QString &target) const {
+BufferInfo::Type CoreBasicHandler::typeByTarget(const QString &target) const {
   if(target.isEmpty())
     return BufferInfo::StatusBuffer;
 
@@ -168,13 +111,13 @@ BufferInfo::Type BasicHandler::typeByTarget(const QString &target) const {
   return BufferInfo::QueryBuffer;
 }
 
-void BasicHandler::putCmd(const QString &cmd, const QByteArray &param, const QByteArray &prefix) {
+void CoreBasicHandler::putCmd(const QString &cmd, const QByteArray &param, const QByteArray &prefix) {
   QList<QByteArray> list;
   list << param;
   emit putCmd(cmd, list, prefix);
 }
 
-void BasicHandler::displayMsg(Message::Type msgType, QString target, const QString &text, const QString &sender, Message::Flags flags) {
+void CoreBasicHandler::displayMsg(Message::Type msgType, QString target, const QString &text, const QString &sender, Message::Flags flags) {
   if(!target.isEmpty() && network()->prefixes().contains(target[0]))
     target = target.mid(1);
 
similarity index 77%
rename from src/core/basichandler.h
rename to src/core/corebasichandler.h
index ad954b5..d04beed 100644 (file)
@@ -1,5 +1,5 @@
 /***************************************************************************
- *   Copyright (C) 2005-09 by the Quassel Project                          *
+ *   Copyright (C) 2005-10 by the Quassel Project                          *
  *   devel@quassel-irc.org                                                 *
  *                                                                         *
  *   This program is free software; you can redistribute it and/or modify  *
  *   59 Temple Place - Suite 330, Boston, MA  02111-1307, USA.             *
  ***************************************************************************/
 
-#ifndef BASICHANDLER_H_
-#define BASICHANDLER_H_
+#ifndef COREBASICHANDLER_H
+#define COREBASICHANDLER_H
 
-#include <QObject>
 #include <QString>
 #include <QStringList>
-#include <QHash>
-#include <QGenericArgument>
 
+#include "basichandler.h"
 #include "message.h"
 
 #include "corenetwork.h"
 
 class CoreSession;
 
-class BasicHandler : public QObject {
+class CoreBasicHandler : public BasicHandler {
   Q_OBJECT
 
 public:
-  BasicHandler(CoreNetwork *parent = 0);
-
-  QStringList providesHandlers();
+  CoreBasicHandler(CoreNetwork *parent = 0);
 
   QString serverDecode(const QByteArray &string);
   QStringList serverDecode(const QList<QByteArray> &stringlist);
@@ -64,23 +60,12 @@ protected:
   void displayMsg(Message::Type, QString target, const QString &text, const QString &sender = "", Message::Flags flags = Message::None);
   void putCmd(const QString &cmd, const QByteArray &param, const QByteArray &prefix = QByteArray());
 
-  virtual void handle(const QString &member, QGenericArgument val0 = QGenericArgument(0),
-                      QGenericArgument val1 = QGenericArgument(), QGenericArgument val2 = QGenericArgument(),
-                      QGenericArgument val3 = QGenericArgument(), QGenericArgument val4 = QGenericArgument(),
-                      QGenericArgument val5 = QGenericArgument(), QGenericArgument val6 = QGenericArgument(),
-                      QGenericArgument val7 = QGenericArgument(), QGenericArgument val8 = QGenericArgument());
-
-
   inline CoreNetwork *network() const { return _network; }
   inline CoreSession *coreSession() const { return _network->coreSession(); }
 
   BufferInfo::Type typeByTarget(const QString &target) const;
 
 private:
-  const QHash<QString, int> &handlerHash();
-  QHash<QString, int> _handlerHash;
-  int defaultHandler;
   CoreNetwork *_network;
-  bool initDone;
 };
 #endif
index b7f1cc0..5764605 100644 (file)
@@ -1,5 +1,5 @@
 /***************************************************************************
- *   Copyright (C) 2005-09 by the Quassel Project                          *
+ *   Copyright (C) 2005-10 by the Quassel Project                          *
  *   devel@quassel-irc.org                                                 *
  *                                                                         *
  *   This program is free software; you can redistribute it and/or modify  *
@@ -29,7 +29,7 @@
 #include <QRegExp>
 
 CoreUserInputHandler::CoreUserInputHandler(CoreNetwork *parent)
-  : BasicHandler(parent)
+  : CoreBasicHandler(parent)
 {
 }
 
index 0634fa1..40490be 100644 (file)
@@ -1,5 +1,5 @@
 /***************************************************************************
- *   Copyright (C) 2005-09 by the Quassel Project                          *
+ *   Copyright (C) 2005-10 by the Quassel Project                          *
  *   devel@quassel-irc.org                                                 *
  *                                                                         *
  *   This program is free software; you can redistribute it and/or modify  *
 #ifndef COREUSERINPUTHANDLER_H
 #define COREUSERINPUTHANDLER_H
 
-#include "basichandler.h"
+#include "corebasichandler.h"
 
 class Server;
 
-class CoreUserInputHandler : public BasicHandler {
+class CoreUserInputHandler : public CoreBasicHandler {
   Q_OBJECT
 
 public:
index 8b17de1..aab7cd1 100644 (file)
@@ -1,5 +1,5 @@
 /***************************************************************************
- *   Copyright (C) 2005-09 by the Quassel Project                          *
+ *   Copyright (C) 2005-10 by the Quassel Project                          *
  *   devel@quassel-irc.org                                                 *
  *                                                                         *
  *   This program is free software; you can redistribute it and/or modify  *
@@ -26,7 +26,7 @@
 #include "coreignorelistmanager.h"
 
 CtcpHandler::CtcpHandler(CoreNetwork *parent)
-  : BasicHandler(parent),
+  : CoreBasicHandler(parent),
     XDELIM("\001"),
     _ignoreListManager(parent->ignoreListManager())
 {
index 35847c1..e44321b 100644 (file)
@@ -1,5 +1,5 @@
 /***************************************************************************
- *   Copyright (C) 2005-09 by the Quassel Project                          *
+ *   Copyright (C) 2005-10 by the Quassel Project                          *
  *   devel@quassel-irc.org                                                 *
  *                                                                         *
  *   This program is free software; you can redistribute it and/or modify  *
 #include <QHash>
 #include <QStringList>
 
-#include "basichandler.h"
+#include "corebasichandler.h"
 
 class CoreListIgnoreListManager;
 
-class CtcpHandler : public BasicHandler {
+class CtcpHandler : public CoreBasicHandler {
   Q_OBJECT
 
 public:
index 33445c2..30f5e2a 100644 (file)
@@ -1,5 +1,5 @@
 /***************************************************************************
- *   Copyright (C) 2005-09 by the Quassel Project                          *
+ *   Copyright (C) 2005-10 by the Quassel Project                          *
  *   devel@quassel-irc.org                                                 *
  *                                                                         *
  *   This program is free software; you can redistribute it and/or modify  *
@@ -33,7 +33,7 @@
 #include <QDebug>
 
 IrcServerHandler::IrcServerHandler(CoreNetwork *parent)
-  : BasicHandler(parent),
+  : CoreBasicHandler(parent),
     _whois(false)
 {
   connect(parent, SIGNAL(disconnected(NetworkId)), this, SLOT(destroyNetsplits()));
index 4ad28de..86eaff2 100644 (file)
@@ -1,5 +1,5 @@
 /***************************************************************************
- *   Copyright (C) 2005-09 by the Quassel Project                          *
+ *   Copyright (C) 2005-10 by the Quassel Project                          *
  *   devel@quassel-irc.org                                                 *
  *                                                                         *
  *   This program is free software; you can redistribute it and/or modify  *
 #ifndef IRCSERVERHANDLER_H
 #define IRCSERVERHANDLER_H
 
-#include "basichandler.h"
+#include "corebasichandler.h"
 #include "netsplit.h"
 
-class IrcServerHandler : public BasicHandler {
+class IrcServerHandler : public CoreBasicHandler {
   Q_OBJECT
 
 public: