-
Notifications
You must be signed in to change notification settings - Fork 794
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
registry: Add cancellation and caching to docsets
Add query cancellation at a docset level. This allows the query to be cancelled midway a large docset run. Add caching to docset results. This should limit the number of items to search through for longer queries.
- Loading branch information
Showing
7 changed files
with
250 additions
and
7 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,98 @@ | ||
/**************************************************************************** | ||
** | ||
** Copyright (C) 2015 Oleg Shparber | ||
** Copyright (C) 2013-2014 Jerzy Kozera | ||
** Contact: http://zealdocs.org/contact.html | ||
** | ||
** This file is part of Zeal. | ||
** | ||
** Zeal 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. | ||
** | ||
** Zeal 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 Zeal. If not, see <http://www.gnu.org/licenses/>. | ||
** | ||
****************************************************************************/ | ||
|
||
#include "cachingsearchstrategy.h" | ||
|
||
#include "docset.h" | ||
#include "searchquery.h" | ||
#include "searchresult.h" | ||
|
||
using namespace Zeal; | ||
|
||
const int CacheSize = 10; | ||
|
||
CachingSearchStrategy::CachingSearchStrategy(std::unique_ptr<DocsetSearchStrategy> strategy) | ||
: m_search(std::move(strategy)) | ||
, m_cache(CacheSize) | ||
{ | ||
} | ||
|
||
QList<SearchResult> CachingSearchStrategy::search(const QString &query, const CancellationToken &token) | ||
{ | ||
QString candidate = getCacheEntry(query); | ||
if (!candidate.isEmpty()) { | ||
return searchWithCache(query, candidate); | ||
} else { | ||
return searchWithoutCache(query, token); | ||
} | ||
} | ||
|
||
bool CachingSearchStrategy::validResult( | ||
const QString &query, const SearchResult &previousResult, | ||
SearchResult &result) const | ||
{ | ||
return m_search->validResult(query, previousResult, result); | ||
} | ||
|
||
QString CachingSearchStrategy::getCacheEntry(const QString &query) const | ||
{ | ||
const SearchQuery searchQuery = SearchQuery::fromString(query); | ||
|
||
for (int i = searchQuery.query().size(); i > 0; i--) { | ||
QString candidate = searchQuery.query().mid(0, i); | ||
|
||
/// Use the cache only if the cache entry contains all results. | ||
/// Also handle cases where prefix is a docset query `std:`. | ||
if (m_cache.contains(candidate) | ||
&& m_cache[candidate]->size() < Docset::MaxDocsetResultsCount | ||
&& SearchQuery::fromString(candidate).query().size() == i) | ||
return candidate; | ||
} | ||
return QString(); | ||
} | ||
|
||
QList<SearchResult> CachingSearchStrategy::searchWithCache(const QString &query, const QString &prefix) | ||
{ | ||
QList<SearchResult> *prefixResults = m_cache[prefix]; | ||
QList<SearchResult> results; | ||
QListIterator<SearchResult> prefixResultsIterator(*prefixResults); | ||
while (prefixResultsIterator.hasNext()) { | ||
SearchResult previousResult = prefixResultsIterator.next(); | ||
SearchResult result; | ||
if (validResult(query, previousResult, result)) | ||
results.append(result); | ||
} | ||
|
||
m_cache.insert(query, new QList<SearchResult>(results)); | ||
return results; | ||
} | ||
|
||
QList<SearchResult> CachingSearchStrategy::searchWithoutCache(const QString &query, CancellationToken token) | ||
{ | ||
QList<SearchResult> results = m_search->search(query, token); | ||
|
||
/// Only cache the results if they are not partial. | ||
if (!token.isCanceled()) | ||
m_cache.insert(query, new QList<SearchResult>(results)); | ||
return results; | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,63 @@ | ||
/**************************************************************************** | ||
** | ||
** Copyright (C) 2015 Oleg Shparber | ||
** Copyright (C) 2013-2014 Jerzy Kozera | ||
** Contact: http://zealdocs.org/contact.html | ||
** | ||
** This file is part of Zeal. | ||
** | ||
** Zeal 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. | ||
** | ||
** Zeal 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 Zeal. If not, see <http://www.gnu.org/licenses/>. | ||
** | ||
****************************************************************************/ | ||
|
||
#ifndef CACHINGSEARCHSTRATEGY_H | ||
#define CACHINGSEARCHSTRATEGY_H | ||
|
||
#include "cancellationtoken.h" | ||
#include "docsetsearchstrategy.h" | ||
|
||
#include <QCache> | ||
#include <QList> | ||
#include <QString> | ||
|
||
#include <memory> | ||
|
||
namespace Zeal { | ||
|
||
struct SearchResult; | ||
|
||
/// A search strategy that uses a cache of previous searches. | ||
/// If a search was made for a prefix then then all results | ||
/// must appear in the cache. In this case instead of searching | ||
/// entire docset only cache is searched. | ||
class CachingSearchStrategy : public DocsetSearchStrategy | ||
{ | ||
public: | ||
CachingSearchStrategy(std::unique_ptr<DocsetSearchStrategy> strategy); | ||
QList<SearchResult> search(const QString &query, const CancellationToken &token) override; | ||
bool validResult(const QString &query, const SearchResult &previousResult, | ||
SearchResult &result) const override; | ||
|
||
private: | ||
QString getCacheEntry(const QString &query) const; | ||
QList<SearchResult> searchWithCache(const QString &query, const QString &prefix); | ||
QList<SearchResult> searchWithoutCache(const QString &query, CancellationToken token); | ||
|
||
std::unique_ptr<DocsetSearchStrategy> m_search; | ||
QCache<QString, QList<SearchResult> > m_cache; | ||
}; | ||
|
||
} | ||
|
||
#endif // CACHINGSEARCHSTRATEGY_H |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters