X-Git-Url: https://git.quassel-irc.org/?p=quassel.git;a=blobdiff_plain;f=src%2Fcommon%2Fignorelistmanager.cpp;h=b4831c072f6625678b583039828bc48a3cddbb30;hp=bd37a20e3917397f956c401e3537c7f96a49a0a6;hb=98bec7bab038a8e656f90617c59fe1e8c0907f71;hpb=75068ed33d1ebfc2d2581d766a69e9bbc84a46f2 diff --git a/src/common/ignorelistmanager.cpp b/src/common/ignorelistmanager.cpp index bd37a20e..b4831c07 100644 --- a/src/common/ignorelistmanager.cpp +++ b/src/common/ignorelistmanager.cpp @@ -24,10 +24,7 @@ #include #include -#include "message.h" - INIT_SYNCABLE_OBJECT(IgnoreListManager) - IgnoreListManager &IgnoreListManager::operator=(const IgnoreListManager &other) { if(this == &other) return *this; @@ -117,21 +114,25 @@ void IgnoreListManager::addIgnoreListItem(int type, const QString &ignoreRule, b SYNC(ARG(type), ARG(ignoreRule), ARG(isRegEx), ARG(strictness), ARG(scope), ARG(scopeRule), ARG(isActive)) } -IgnoreListManager::StrictnessType IgnoreListManager::match(const Message &msg, const QString &network) { - if(!(msg.type() & (Message::Plain | Message::Notice | Message::Action))) +IgnoreListManager::StrictnessType IgnoreListManager::_match(const QString &msgContents, const QString &msgSender, Message::Type msgType, const QString &network, const QString &bufferName) { + // We method don't rely on a proper Message object to make this method more versatile. + // This allows us to use it in the core with unprocessed Messages or in the Client + // with properly preprocessed Messages. + if(!(msgType & (Message::Plain | Message::Notice | Message::Action))) return UnmatchedStrictness; foreach(IgnoreListItem item, _ignoreList) { if(!item.isActive || item.type == CtcpIgnore) continue; - if(item.scope == GlobalScope || (item.scope == NetworkScope && scopeMatch(item.scopeRule, network)) || - (item.scope == ChannelScope && scopeMatch(item.scopeRule, msg.bufferInfo().bufferName()))) { + if(item.scope == GlobalScope + || (item.scope == NetworkScope && scopeMatch(item.scopeRule, network)) + || (item.scope == ChannelScope && scopeMatch(item.scopeRule, bufferName))) { QString str; if(item.type == MessageIgnore) - str = msg.contents(); + str = msgContents; else - str = msg.sender(); + str = msgSender; QRegExp ruleRx = QRegExp(item.ignoreRule); ruleRx.setCaseSensitivity(Qt::CaseInsensitive); @@ -154,6 +155,7 @@ IgnoreListManager::StrictnessType IgnoreListManager::match(const Message &msg, c return UnmatchedStrictness; } + bool IgnoreListManager::scopeMatch(const QString &scopeRule, const QString &string) const { foreach(QString rule, scopeRule.split(";")) { QRegExp ruleRx = QRegExp(rule.trimmed());