X-Git-Url: https://git.quassel-irc.org/?p=quassel.git;a=blobdiff_plain;f=src%2Fcore%2Fcoresession.cpp;h=3c8e20c67a573f5ef6fee25103983cb502620cf4;hp=33f5b09dde7c8527aad6e3dff091c3b65462aa2b;hb=b2de861297e7bb461b37ff041827c89360ecfec6;hpb=39eb2fda3eaef2de78a8134556015ff86e9b85d4 diff --git a/src/core/coresession.cpp b/src/core/coresession.cpp index 33f5b09d..3c8e20c6 100644 --- a/src/core/coresession.cpp +++ b/src/core/coresession.cpp @@ -22,7 +22,7 @@ #include "core.h" #include "coresession.h" -#include "userinputhandler.h" +#include "coreuserinputhandler.h" #include "signalproxy.h" #include "corebuffersyncer.h" #include "corebacklogmanager.h" @@ -39,6 +39,7 @@ #include "util.h" #include "coreusersettings.h" #include "logger.h" +#include "coreignorelistmanager.h" class ProcessMessagesEvent : public QEvent { public: @@ -57,7 +58,8 @@ CoreSession::CoreSession(UserId uid, bool restoreState, QObject *parent) _networkConfig(new CoreNetworkConfig("GlobalNetworkConfig", this)), _coreInfo(this), scriptEngine(new QScriptEngine(this)), - _processMessages(false) + _processMessages(false), + _ignoreListManager(this) { SignalProxy *p = signalProxy(); connect(p, SIGNAL(peerRemoved(QIODevice *)), this, SLOT(removeClient(QIODevice *))); @@ -82,8 +84,8 @@ CoreSession::CoreSession(UserId uid, bool restoreState, QObject *parent) loadSettings(); initScriptEngine(); - connect(&(Core::instance()->syncTimer()), SIGNAL(timeout()), _bufferSyncer, SLOT(storeDirtyIds())); - connect(&(Core::instance()->syncTimer()), SIGNAL(timeout()), _bufferViewManager, SLOT(saveBufferViews())); + // periodically save our session state + connect(&(Core::instance()->syncTimer()), SIGNAL(timeout()), this, SLOT(saveSessionState())); p->synchronize(_bufferSyncer); p->synchronize(&aliasManager()); @@ -91,7 +93,7 @@ CoreSession::CoreSession(UserId uid, bool restoreState, QObject *parent) p->synchronize(ircListHelper()); p->synchronize(networkConfig()); p->synchronize(&_coreInfo); - + p->synchronize(&_ignoreListManager); // Restore session state if(restoreState) restoreSessionState(); @@ -241,12 +243,19 @@ void CoreSession::customEvent(QEvent *event) { } void CoreSession::processMessages() { + QString networkName; if(_messageQueue.count() == 1) { const RawMessage &rawMsg = _messageQueue.first(); BufferInfo bufferInfo = Core::bufferInfo(user(), rawMsg.networkId, rawMsg.bufferType, rawMsg.target); Message msg(bufferInfo, rawMsg.type, rawMsg.text, rawMsg.sender, rawMsg.flags); - Core::storeMessage(msg); - emit displayMsg(msg); + + CoreNetwork *currentNetwork = network(bufferInfo.networkId()); + networkName = currentNetwork ? currentNetwork->networkName() : QString(""); + // if message is ignored with "HardStrictness" we discard it here + if(_ignoreListManager.match(msg, networkName) != IgnoreListManager::HardStrictness) { + Core::storeMessage(msg); + emit displayMsg(msg); + } } else { QHash > bufferInfoCache; MessageList messages; @@ -259,7 +268,14 @@ void CoreSession::processMessages() { bufferInfo = Core::bufferInfo(user(), rawMsg.networkId, rawMsg.bufferType, rawMsg.target); bufferInfoCache[rawMsg.networkId][rawMsg.target] = bufferInfo; } - messages << Message(bufferInfo, rawMsg.type, rawMsg.text, rawMsg.sender, rawMsg.flags); + + Message msg(bufferInfo, rawMsg.type, rawMsg.text, rawMsg.sender, rawMsg.flags); + CoreNetwork *currentNetwork = network(bufferInfo.networkId()); + networkName = currentNetwork ? currentNetwork->networkName() : QString(""); + // if message is ignored with "HardStrictness" we discard it here + if(_ignoreListManager.match(msg, networkName) == IgnoreListManager::HardStrictness) + continue; + messages << msg; } Core::storeMessages(messages); // FIXME: extend protocol to a displayMessages(MessageList)