Merging NetworkConnection into CoreNetwork.
[quassel.git] / src / core / basichandler.cpp
index 8b9fd03..4df9ea2 100644 (file)
 #include "util.h"
 #include "logger.h"
 
-BasicHandler::BasicHandler(NetworkConnection *parent)
+BasicHandler::BasicHandler(CoreNetwork *parent)
   : QObject(parent),
     defaultHandler(-1),
-    _networkConnection(parent),
+    _network(parent),
     initDone(false)
 {
   connect(this, SIGNAL(displayMsg(Message::Type, BufferInfo::Type, QString, QString, QString, Message::Flags)),
-         networkConnection(), SIGNAL(displayMsg(Message::Type, BufferInfo::Type, QString, QString, QString, Message::Flags)));
+         network(), SIGNAL(displayMsg(Message::Type, BufferInfo::Type, QString, QString, QString, Message::Flags)));
 
   connect(this, SIGNAL(putCmd(QString, const QList<QByteArray> &, const QByteArray &)),
-         networkConnection(), SLOT(putCmd(QString, const QList<QByteArray> &, const QByteArray &)));
+         network(), SLOT(putCmd(QString, const QList<QByteArray> &, const QByteArray &)));
 
   connect(this, SIGNAL(putRawLine(const QByteArray &)),
-          networkConnection(), SLOT(putRawLine(const QByteArray &)));
+          network(), SLOT(putRawLine(const QByteArray &)));
 }
 
 QStringList BasicHandler::providesHandlers() {
@@ -78,7 +78,7 @@ void BasicHandler::handle(const QString &member, QGenericArgument val0,
 
   if(!handlerHash().contains(handler)) {
     if(defaultHandler == -1) {
-      quWarning() << QString("No such Handler: %1::handle%2").arg(metaObject()->className(), handler);
+      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(),
@@ -94,64 +94,64 @@ void BasicHandler::handle(const QString &member, QGenericArgument val0,
 }
 
 QString BasicHandler::serverDecode(const QByteArray &string) {
-  return networkConnection()->serverDecode(string);
+  return network()->serverDecode(string);
 }
 
 QStringList BasicHandler::serverDecode(const QList<QByteArray> &stringlist) {
   QStringList list;
-  foreach(QByteArray s, stringlist) list << networkConnection()->serverDecode(s);
+  foreach(QByteArray s, stringlist) list << network()->serverDecode(s);
   return list;
 }
 
 QString BasicHandler::channelDecode(const QString &bufferName, const QByteArray &string) {
-  return networkConnection()->channelDecode(bufferName, string);
+  return network()->channelDecode(bufferName, string);
 }
 
 QStringList BasicHandler::channelDecode(const QString &bufferName, const QList<QByteArray> &stringlist) {
   QStringList list;
-  foreach(QByteArray s, stringlist) list << networkConnection()->channelDecode(bufferName, s);
+  foreach(QByteArray s, stringlist) list << network()->channelDecode(bufferName, s);
   return list;
 }
 
 QString BasicHandler::userDecode(const QString &userNick, const QByteArray &string) {
-  return networkConnection()->userDecode(userNick, string);
+  return network()->userDecode(userNick, string);
 }
 
 QStringList BasicHandler::userDecode(const QString &userNick, const QList<QByteArray> &stringlist) {
   QStringList list;
-  foreach(QByteArray s, stringlist) list << networkConnection()->userDecode(userNick, s);
+  foreach(QByteArray s, stringlist) list << network()->userDecode(userNick, s);
   return list;
 }
 
 /*** ***/
 
 QByteArray BasicHandler::serverEncode(const QString &string) {
-  return networkConnection()->serverEncode(string);
+  return network()->serverEncode(string);
 }
 
 QList<QByteArray> BasicHandler::serverEncode(const QStringList &stringlist) {
   QList<QByteArray> list;
-  foreach(QString s, stringlist) list << networkConnection()->serverEncode(s);
+  foreach(QString s, stringlist) list << network()->serverEncode(s);
   return list;
 }
 
 QByteArray BasicHandler::channelEncode(const QString &bufferName, const QString &string) {
-  return networkConnection()->channelEncode(bufferName, string);
+  return network()->channelEncode(bufferName, string);
 }
 
 QList<QByteArray> BasicHandler::channelEncode(const QString &bufferName, const QStringList &stringlist) {
   QList<QByteArray> list;
-  foreach(QString s, stringlist) list << networkConnection()->channelEncode(bufferName, s);
+  foreach(QString s, stringlist) list << network()->channelEncode(bufferName, s);
   return list;
 }
 
 QByteArray BasicHandler::userEncode(const QString &userNick, const QString &string) {
-  return networkConnection()->userEncode(userNick, string);
+  return network()->userEncode(userNick, string);
 }
 
 QList<QByteArray> BasicHandler::userEncode(const QString &userNick, const QStringList &stringlist) {
   QList<QByteArray> list;
-  foreach(QString s, stringlist) list << networkConnection()->userEncode(userNick, s);
+  foreach(QString s, stringlist) list << network()->userEncode(userNick, s);
   return list;
 }
 
@@ -175,6 +175,9 @@ void BasicHandler::putCmd(const QString &cmd, const QByteArray &param, const QBy
 }
 
 void BasicHandler::displayMsg(Message::Type msgType, QString target, QString text, QString sender, Message::Flags flags) {
+  if(!target.isEmpty() && network()->prefixes().contains(target[0]))
+    target = target.mid(1);
+
   IrcChannel *channel = network()->ircChannel(target);
   if(!channel && (target.startsWith('$') || target.startsWith('#')))
     target = nickFromMask(sender);