X-Git-Url: https://git.quassel-irc.org/?p=quassel.git;a=blobdiff_plain;f=src%2Fcore%2Fcoresession.cpp;h=0173a9572e2fee6208e8f2fb9f5c1334904cd088;hp=52cab60b78f0b16c7da9e2e2c81dc5c94258cdec;hb=85c5d43cd1a1f6b4e9fe41fe533c743517017d37;hpb=0afd913a5fa29fa44f6119df86aa7574b3274e51 diff --git a/src/core/coresession.cpp b/src/core/coresession.cpp index 52cab60b..0173a957 100644 --- a/src/core/coresession.cpp +++ b/src/core/coresession.cpp @@ -34,7 +34,9 @@ #include "corenetworkconfig.h" #include "coresessioneventprocessor.h" #include "coreusersettings.h" +#include "ctcpparser.h" #include "eventmanager.h" +#include "eventstringifier.h" #include "ircchannel.h" #include "ircparser.h" #include "ircuser.h" @@ -61,10 +63,11 @@ CoreSession::CoreSession(UserId uid, bool restoreState, QObject *parent) _networkConfig(new CoreNetworkConfig("GlobalNetworkConfig", this)), _coreInfo(this), _eventManager(new EventManager(this)), - _eventProcessor(new CoreSessionEventProcessor(this)), + _eventStringifier(new EventStringifier(this)), + _sessionEventProcessor(new CoreSessionEventProcessor(this)), + _ctcpParser(new CtcpParser(this)), _ircParser(new IrcParser(this)), scriptEngine(new QScriptEngine(this)), - _processMessages(false), _ignoreListManager(this) { SignalProxy *p = signalProxy(); @@ -93,9 +96,15 @@ CoreSession::CoreSession(UserId uid, bool restoreState, QObject *parent) loadSettings(); initScriptEngine(); - eventManager()->registerObject(ircParser(), EventManager::NormalPriority, "process"); - eventManager()->registerObject(eventProcessor(), EventManager::HighPriority, "process"); - eventManager()->registerObject(this, EventManager::LowPriority, "process"); // for sending MessageEvents to the client + connect(eventManager(), SIGNAL(eventQueueEmptied()), SLOT(processMessages())); + eventManager()->registerObject(ircParser(), EventManager::NormalPriority); + eventManager()->registerObject(sessionEventProcessor(), EventManager::HighPriority); // needs to process events *before* the stringifier! + eventManager()->registerObject(ctcpParser(), EventManager::NormalPriority); + eventManager()->registerObject(eventStringifier(), EventManager::NormalPriority); + eventManager()->registerObject(this, EventManager::LowPriority); // for sending MessageEvents to the client + // some events need to be handled after msg generation + eventManager()->registerObject(sessionEventProcessor(), EventManager::LowPriority, "lateProcess"); + eventManager()->registerObject(ctcpParser(), EventManager::LowPriority, "send"); // periodically save our session state connect(&(Core::instance()->syncTimer()), SIGNAL(timeout()), this, SLOT(saveSessionState())); @@ -214,6 +223,9 @@ void CoreSession::msgFromClient(BufferInfo bufinfo, QString msg) { CoreNetwork *net = network(bufinfo.networkId()); if(net) { net->userInput(bufinfo, msg); + // FIXME as soon as user input is event-based + // until then, user input doesn't trigger a message queue flush! + processMessages(); } else { qWarning() << "Trying to send to unconnected network:" << msg; } @@ -238,10 +250,6 @@ void CoreSession::recvMessageFromServer(NetworkId networkId, Message::Type type, return; _messageQueue << rawMsg; - if(!_processMessages) { - _processMessages = true; - QCoreApplication::postEvent(this, new ProcessMessagesEvent()); - } } void CoreSession::recvStatusMsgFromServer(QString msg) { @@ -251,23 +259,21 @@ void CoreSession::recvStatusMsgFromServer(QString msg) { } void CoreSession::processMessageEvent(MessageEvent *event) { - recvMessageFromServer(event->networkId(), event->msgType(), event->bufferType(), event->target(), - event->text(), event->sender(), event->msgFlags()); + 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()); } -void CoreSession::customEvent(QEvent *event) { - if(event->type() != QEvent::User) +void CoreSession::processMessages() { + if(_messageQueue.isEmpty()) return; - processMessages(); - event->accept(); -} - -void CoreSession::processMessages() { if(_messageQueue.count() == 1) { const RawMessage &rawMsg = _messageQueue.first(); bool createBuffer = !(rawMsg.flags & Message::Redirected); @@ -323,7 +329,6 @@ void CoreSession::processMessages() { emit displayMsg(messages[i]); } } - _processMessages = false; _messageQueue.clear(); } @@ -449,6 +454,7 @@ void CoreSession::createNetwork(const NetworkInfo &info_, const QStringList &per connect(net, SIGNAL(displayMsg(NetworkId, Message::Type, BufferInfo::Type, const QString &, const QString &, const QString &, Message::Flags)), SLOT(recvMessageFromServer(NetworkId, Message::Type, BufferInfo::Type, const QString &, const QString &, const QString &, Message::Flags))); connect(net, SIGNAL(displayStatusMsg(QString)), SLOT(recvStatusMsgFromServer(QString))); + connect(net, SIGNAL(disconnected(NetworkId)), SIGNAL(networkDisconnected(NetworkId))); net->setNetworkInfo(info); net->setProxy(signalProxy()); @@ -468,7 +474,7 @@ void CoreSession::removeNetwork(NetworkId id) { return; if(net->connectionState() != Network::Disconnected) { - connect(net, SIGNAL(disconnected(NetworkId)), this, SLOT(destroyNetwork(NetworkId))); + connect(net, SIGNAL(disconnected(NetworkId)), SLOT(destroyNetwork(NetworkId))); net->disconnectFromIrc(); } else { destroyNetwork(id);