X-Git-Url: https://git.quassel-irc.org/?a=blobdiff_plain;f=src%2Fcore%2Fcoresession.cpp;h=3c8e20c67a573f5ef6fee25103983cb502620cf4;hb=79da84574c2e95ec37894b869668d6b6ffc71c59;hp=0c62171845e6b57dc3697e1cbccea8e01fa650f2;hpb=08adbf35b56f8ce8cf3a8edf614aa0c67061e60f;p=quassel.git diff --git a/src/core/coresession.cpp b/src/core/coresession.cpp index 0c621718..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) @@ -337,7 +353,7 @@ void CoreSession::createIdentity(const CoreIdentity &identity) { _identities[identity.id()] = coreIdentity; // CoreIdentity has it's own synchronize method since it's "private" sslManager needs to be synced aswell coreIdentity->synchronize(signalProxy()); - connect(coreIdentity, SIGNAL(updated(const QVariantMap &)), this, SLOT(updateIdentityBySender())); + connect(coreIdentity, SIGNAL(updated()), this, SLOT(updateIdentityBySender())); emit identityCreated(*coreIdentity); }