_ctcpParser(new CtcpParser(this)),
_ircParser(new IrcParser(this)),
scriptEngine(new QScriptEngine(this)),
- _processMessages(false),
_ignoreListManager(this)
{
SignalProxy *p = signalProxy();
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);
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;
}
return;
_messageQueue << rawMsg;
- if(!_processMessages) {
- _processMessages = true;
- QCoreApplication::postEvent(this, new ProcessMessagesEvent());
- }
}
void CoreSession::recvStatusMsgFromServer(QString msg) {
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);
emit displayMsg(messages[i]);
}
}
- _processMessages = false;
_messageQueue.clear();
}