2013-11-02 17:43:18 +01:00
|
|
|
/* ============================================================
|
|
|
|
* QupZilla - WebKit based browser
|
2014-01-11 16:11:42 +01:00
|
|
|
* Copyright (C) 2013-2014 David Rosca <nowrep@gmail.com>
|
2013-11-02 17:43:18 +01:00
|
|
|
*
|
|
|
|
* This program is free software: you can redistribute it and/or modify
|
|
|
|
* it under the terms of the GNU General Public License as published by
|
|
|
|
* the Free Software Foundation, either version 3 of the License, or
|
|
|
|
* (at your option) any later version.
|
|
|
|
*
|
|
|
|
* This program is distributed in the hope that it will be useful,
|
|
|
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
|
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
|
|
* GNU General Public License for more details.
|
|
|
|
*
|
|
|
|
* You should have received a copy of the GNU General Public License
|
|
|
|
* along with this program. If not, see <http://www.gnu.org/licenses/>.
|
|
|
|
* ============================================================ */
|
|
|
|
#ifndef ADBLOCKSEARCHTREE_H
|
|
|
|
#define ADBLOCKSEARCHTREE_H
|
|
|
|
|
|
|
|
#include <QChar>
|
|
|
|
#include <QHash>
|
|
|
|
|
|
|
|
#include "qz_namespace.h"
|
|
|
|
|
|
|
|
class QNetworkRequest;
|
|
|
|
|
|
|
|
class AdBlockRule;
|
|
|
|
|
|
|
|
class QT_QUPZILLA_EXPORT AdBlockSearchTree
|
|
|
|
{
|
|
|
|
public:
|
|
|
|
explicit AdBlockSearchTree();
|
|
|
|
~AdBlockSearchTree();
|
|
|
|
|
2013-11-03 14:29:23 +01:00
|
|
|
void clear();
|
|
|
|
|
2013-11-02 17:43:18 +01:00
|
|
|
bool add(const AdBlockRule* rule);
|
2013-11-03 14:49:58 +01:00
|
|
|
const AdBlockRule* find(const QNetworkRequest &request, const QString &domain, const QString &urlString) const;
|
2013-11-02 17:43:18 +01:00
|
|
|
|
|
|
|
private:
|
|
|
|
struct Node {
|
|
|
|
QChar c;
|
|
|
|
const AdBlockRule* rule;
|
2013-11-03 14:22:27 +01:00
|
|
|
QHash<QChar, Node*> children;
|
2013-11-02 17:43:18 +01:00
|
|
|
|
|
|
|
Node() : c(0) , rule(0) { }
|
|
|
|
};
|
|
|
|
|
|
|
|
const AdBlockRule* prefixSearch(const QNetworkRequest &request, const QString &domain,
|
2013-11-03 14:49:58 +01:00
|
|
|
const QString &urlString, const QChar* string, int len) const;
|
2013-11-02 17:43:18 +01:00
|
|
|
|
|
|
|
void deleteNode(Node* node);
|
|
|
|
|
|
|
|
Node* m_root;
|
|
|
|
};
|
|
|
|
|
|
|
|
#endif // ADBLOCKSEARCHTREE_H
|