/***************************************************************************
- * Copyright (C) 2005-2018 by the Quassel Project *
+ * Copyright (C) 2005-2019 by the Quassel Project *
* devel@quassel-irc.org *
* *
* This program is free software; you can redistribute it and/or modify *
#include "ignorelistmanager.h"
-#include <QtCore>
#include <QDebug>
#include <QStringList>
+#include <QtCore>
-IgnoreListManager &IgnoreListManager::operator=(const IgnoreListManager &other)
+IgnoreListManager& IgnoreListManager::operator=(const IgnoreListManager& other)
{
if (this == &other)
return *this;
return *this;
}
-
-int IgnoreListManager::indexOf(const QString &ignore) const
+int IgnoreListManager::indexOf(const QString& ignore) const
{
for (int i = 0; i < _ignoreList.count(); i++) {
if (_ignoreList[i].contents() == ignore)
return -1;
}
-
QVariantMap IgnoreListManager::initIgnoreList() const
{
QVariantMap ignoreListMap;
return ignoreListMap;
}
-
-void IgnoreListManager::initSetIgnoreList(const QVariantMap &ignoreList)
+void IgnoreListManager::initSetIgnoreList(const QVariantMap& ignoreList)
{
QVariantList ignoreType = ignoreList["ignoreType"].toList();
QStringList ignoreRule = ignoreList["ignoreRule"].toStringList();
QVariantList isActive = ignoreList["isActive"].toList();
int count = ignoreRule.count();
- if (count != scopeRule.count() || count != isRegEx.count() ||
- count != scope.count() || count != strictness.count() || count != ignoreType.count() || count != isActive.count()) {
+ if (count != scopeRule.count() || count != isRegEx.count() || count != scope.count() || count != strictness.count()
+ || count != ignoreType.count() || count != isActive.count()) {
qWarning() << "Corrupted IgnoreList settings! (Count mismatch)";
return;
}
_ignoreList.clear();
for (int i = 0; i < ignoreRule.count(); i++) {
- _ignoreList << IgnoreListItem(static_cast<IgnoreType>(ignoreType[i].toInt()), ignoreRule[i], isRegEx[i].toBool(),
- static_cast<StrictnessType>(strictness[i].toInt()), static_cast<ScopeType>(scope[i].toInt()),
- scopeRule[i], isActive[i].toBool());
+ _ignoreList << IgnoreListItem(static_cast<IgnoreType>(ignoreType[i].toInt()),
+ ignoreRule[i],
+ isRegEx[i].toBool(),
+ static_cast<StrictnessType>(strictness[i].toInt()),
+ static_cast<ScopeType>(scope[i].toInt()),
+ scopeRule[i],
+ isActive[i].toBool());
}
}
-
/* since overloaded methods aren't syncable (yet?) we can't use that anymore
void IgnoreListManager::addIgnoreListItem(const IgnoreListItem &item) {
addIgnoreListItem(item.type(), item.contents(), item.isRegEx(), item.strictness(), item.scope(), item.scopeRule(), item.isEnabled());
}
*/
-void IgnoreListManager::addIgnoreListItem(int type, const QString &ignoreRule, bool isRegEx, int strictness,
- int scope, const QString &scopeRule, bool isActive)
+void IgnoreListManager::addIgnoreListItem(
+ int type, const QString& ignoreRule, bool isRegEx, int strictness, int scope, const QString& scopeRule, bool isActive)
{
if (contains(ignoreRule)) {
return;
}
- IgnoreListItem newItem = IgnoreListItem(static_cast<IgnoreType>(type), ignoreRule, isRegEx, static_cast<StrictnessType>(strictness),
- static_cast<ScopeType>(scope), scopeRule, isActive);
+ IgnoreListItem newItem = IgnoreListItem(static_cast<IgnoreType>(type),
+ ignoreRule,
+ isRegEx,
+ static_cast<StrictnessType>(strictness),
+ static_cast<ScopeType>(scope),
+ scopeRule,
+ isActive);
_ignoreList << newItem;
SYNC(ARG(type), ARG(ignoreRule), ARG(isRegEx), ARG(strictness), ARG(scope), ARG(scopeRule), ARG(isActive))
}
-
-IgnoreListManager::StrictnessType IgnoreListManager::_match(const QString &msgContents, const QString &msgSender, Message::Type msgType, const QString &network, const QString &bufferName)
+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
if (!(msgType & (Message::Plain | Message::Notice | Message::Action)))
return UnmatchedStrictness;
- foreach(IgnoreListItem item, _ignoreList) {
+ foreach (IgnoreListItem item, _ignoreList) {
if (!item.isEnabled() || item.type() == CtcpIgnore)
continue;
- if (item.scope() == GlobalScope
- || (item.scope() == NetworkScope && item.scopeRuleMatcher().match(network))
+ if (item.scope() == GlobalScope || (item.scope() == NetworkScope && item.scopeRuleMatcher().match(network))
|| (item.scope() == ChannelScope && item.scopeRuleMatcher().match(bufferName))) {
QString str;
if (item.type() == MessageIgnore)
else
str = msgSender;
-// qDebug() << "IgnoreListManager::match: ";
-// qDebug() << "string: " << str;
-// qDebug() << "pattern: " << ruleRx.pattern();
-// qDebug() << "scopeRule: " << item.scopeRule;
-// qDebug() << "now testing";
+ // qDebug() << "IgnoreListManager::match: ";
+ // qDebug() << "string: " << str;
+ // qDebug() << "pattern: " << ruleRx.pattern();
+ // qDebug() << "scopeRule: " << item.scopeRule;
+ // qDebug() << "now testing";
if (item.contentsMatcher().match(str)) {
return item.strictness();
}
return UnmatchedStrictness;
}
-
-void IgnoreListManager::removeIgnoreListItem(const QString &ignoreRule)
+void IgnoreListManager::removeIgnoreListItem(const QString& ignoreRule)
{
removeAt(indexOf(ignoreRule));
SYNC(ARG(ignoreRule))
}
-
-void IgnoreListManager::toggleIgnoreRule(const QString &ignoreRule)
+void IgnoreListManager::toggleIgnoreRule(const QString& ignoreRule)
{
int idx = indexOf(ignoreRule);
if (idx == -1)
SYNC(ARG(ignoreRule))
}
-
-bool IgnoreListManager::ctcpMatch(const QString sender, const QString &network, const QString &type)
+bool IgnoreListManager::ctcpMatch(const QString sender, const QString& network, const QString& type)
{
- foreach(IgnoreListItem item, _ignoreList) {
+ foreach (IgnoreListItem item, _ignoreList) {
if (!item.isEnabled())
continue;
- if (item.scope() == GlobalScope
- || (item.scope() == NetworkScope && item.scopeRuleMatcher().match(network))) {
-
+ if (item.scope() == GlobalScope || (item.scope() == NetworkScope && item.scopeRuleMatcher().match(network))) {
// For CTCP ignore rules, use ctcpSender
if (item.senderCTCPMatcher().match(sender)) {
// Sender matches, check types
- if (item.ctcpTypes().isEmpty()
- || item.ctcpTypes().contains(type, Qt::CaseInsensitive)) {
+ if (item.ctcpTypes().isEmpty() || item.ctcpTypes().contains(type, Qt::CaseInsensitive)) {
// Either all types are blocked, or type matches
return true;
}
return false;
}
-
/**************************************************************************
* IgnoreListItem
*************************************************************************/
-bool IgnoreListManager::IgnoreListItem::operator!=(const IgnoreListItem &other) const
+bool IgnoreListManager::IgnoreListItem::operator!=(const IgnoreListItem& other) const
{
- return (_type != other._type ||
- _contents != other._contents ||
- _isRegEx != other._isRegEx ||
- _strictness != other._strictness ||
- _scope != other._scope ||
- _scopeRule != other._scopeRule ||
- _isEnabled != other._isEnabled);
+ return (_type != other._type || _contents != other._contents || _isRegEx != other._isRegEx || _strictness != other._strictness
+ || _scope != other._scope || _scopeRule != other._scopeRule || _isEnabled != other._isEnabled);
// Don't compare ExpressionMatch objects as they are created as needed from the above
}
-
void IgnoreListManager::IgnoreListItem::determineExpressions() const
{
// Don't update if not needed
// Set up matching rules
// Message is either wildcard or regex
- ExpressionMatch::MatchMode contentsMode =
- _isRegEx ? ExpressionMatch::MatchMode::MatchRegEx :
- ExpressionMatch::MatchMode::MatchWildcard;
+ ExpressionMatch::MatchMode contentsMode = _isRegEx ? ExpressionMatch::MatchMode::MatchRegEx : ExpressionMatch::MatchMode::MatchWildcard;
// Ignore rules are always case-insensitive
// Scope matching is always wildcard
}
// Scope rules are always multiple wildcard entries
// (Adding a regex option would be awesome, but requires a backwards-compatible protocol change)
- _scopeRuleMatch = ExpressionMatch(_scopeRule,
- ExpressionMatch::MatchMode::MatchMultiWildcard, false);
+ _scopeRuleMatch = ExpressionMatch(_scopeRule, ExpressionMatch::MatchMode::MatchMultiWildcard, false);
_cacheInvalid = false;
}