X-Git-Url: https://git.quassel-irc.org/?p=quassel.git;a=blobdiff_plain;f=src%2Fcore%2Fcoresession.cpp;h=0173a9572e2fee6208e8f2fb9f5c1334904cd088;hp=3fd539ea6e905702497dbaf3f1a0823fa9dc9876;hb=5cab348de53cb3b994273c06fe69e1f799d247b4;hpb=77a021d6d237abc3b54277584c1bedfecf0ceda2 diff --git a/src/core/coresession.cpp b/src/core/coresession.cpp index 3fd539ea..0173a957 100644 --- a/src/core/coresession.cpp +++ b/src/core/coresession.cpp @@ -68,7 +68,6 @@ CoreSession::CoreSession(UserId uid, bool restoreState, QObject *parent) _ctcpParser(new CtcpParser(this)), _ircParser(new IrcParser(this)), scriptEngine(new QScriptEngine(this)), - _processMessages(false), _ignoreListManager(this) { SignalProxy *p = signalProxy(); @@ -97,6 +96,7 @@ CoreSession::CoreSession(UserId uid, bool restoreState, QObject *parent) loadSettings(); initScriptEngine(); + 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); @@ -223,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; } @@ -247,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) { @@ -271,15 +270,10 @@ 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); @@ -335,7 +329,6 @@ void CoreSession::processMessages() { emit displayMsg(messages[i]); } } - _processMessages = false; _messageQueue.clear(); }