X-Git-Url: https://git.quassel-irc.org/?p=quassel.git;a=blobdiff_plain;f=src%2Fcore%2Fcoresession.cpp;h=2ed950c0fd1bbb8895fa74ae639e525c8ba7d874;hp=2e138bbee550df2a505b73439f4b58669cd3fd65;hb=d60c5028b49a95d3c27c35b2ea1d74cdd7bb0e46;hpb=86837eac3346857733f3488acccca9dc2c45605e diff --git a/src/core/coresession.cpp b/src/core/coresession.cpp index 2e138bbe..2ed950c0 100644 --- a/src/core/coresession.cpp +++ b/src/core/coresession.cpp @@ -35,10 +35,12 @@ #include "coresessioneventprocessor.h" #include "coreusersettings.h" #include "eventmanager.h" +#include "eventstringifier.h" #include "ircchannel.h" #include "ircparser.h" #include "ircuser.h" #include "logger.h" +#include "messageevent.h" #include "signalproxy.h" #include "storage.h" #include "util.h" @@ -60,6 +62,7 @@ CoreSession::CoreSession(UserId uid, bool restoreState, QObject *parent) _networkConfig(new CoreNetworkConfig("GlobalNetworkConfig", this)), _coreInfo(this), _eventManager(new EventManager(this)), + _eventStringifier(new EventStringifier(this)), _eventProcessor(new CoreSessionEventProcessor(this)), _ircParser(new IrcParser(this)), scriptEngine(new QScriptEngine(this)), @@ -92,8 +95,11 @@ CoreSession::CoreSession(UserId uid, bool restoreState, QObject *parent) loadSettings(); initScriptEngine(); - eventManager()->registerObject(ircParser(), EventManager::NormalPriority, "process"); - eventManager()->registerObject(eventProcessor(), EventManager::HighPriority, "process"); + eventManager()->registerObject(ircParser(), EventManager::NormalPriority); + eventManager()->registerObject(eventStringifier(), EventManager::HighPriority, "earlyProcess"); // some need to be sent before statechange + eventManager()->registerObject(eventProcessor(), EventManager::HighPriority); // needs to process events *before* the stringifier! + eventManager()->registerObject(eventStringifier(), EventManager::NormalPriority); + eventManager()->registerObject(this, EventManager::LowPriority); // for sending MessageEvents to the client // periodically save our session state connect(&(Core::instance()->syncTimer()), SIGNAL(timeout()), this, SLOT(saveSessionState())); @@ -248,6 +254,14 @@ void CoreSession::recvStatusMsgFromServer(QString msg) { emit displayStatusMsg(net->networkName(), msg); } +void CoreSession::processMessageEvent(MessageEvent *event) { + recvMessageFromServer(event->networkId(), event->msgType(), event->bufferType(), + event->target().isNull()? "" : event->target(), + event->text().isNull()? "" : event->text(), + event->sender().isNull()? "" : event->sender(), + event->msgFlags()); +} + QList CoreSession::buffers() const { return Core::requestBuffers(user()); }