X-Git-Url: https://git.quassel-irc.org/?p=quassel.git;a=blobdiff_plain;f=src%2Fcommon%2Fignorelistmanager.cpp;h=b4831c072f6625678b583039828bc48a3cddbb30;hp=dfd9ae2db03b1b747db4a53cb67ca5036b801ddd;hb=46984aca05b2d5f8dddd0c8739e60a1753078123;hpb=f19fea582ace1d8f3dfe29c1096c48758079e56e diff --git a/src/common/ignorelistmanager.cpp b/src/common/ignorelistmanager.cpp index dfd9ae2d..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) + 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()); @@ -178,3 +180,28 @@ void IgnoreListManager::toggleIgnoreRule(const QString &ignoreRule) { _ignoreList[idx].isActive = !_ignoreList[idx].isActive; SYNC(ARG(ignoreRule)) } + +bool IgnoreListManager::ctcpMatch(const QString sender, const QString &network, const QString &type) { + foreach(IgnoreListItem item, _ignoreList) { + if(!item.isActive) + continue; + if(item.scope == GlobalScope || (item.scope == NetworkScope && scopeMatch(item.scopeRule, network))) { + QString sender_; + QStringList types = item.ignoreRule.split(QRegExp("\\s+"), QString::SkipEmptyParts); + + sender_ = types.takeAt(0); + + QRegExp ruleRx = QRegExp(sender_); + ruleRx.setCaseSensitivity(Qt::CaseInsensitive); + if(!item.isRegEx) + ruleRx.setPatternSyntax(QRegExp::Wildcard); + if((!item.isRegEx && ruleRx.exactMatch(sender)) || + (item.isRegEx && ruleRx.indexIn(sender) != -1)) { + + if(types.isEmpty() || types.contains(type, Qt::CaseInsensitive)) + return true; + } + } + } + return false; +}