diff options
author | Andrea Diamantini <adjam7@gmail.com> | 2011-01-09 11:40:43 +0100 |
---|---|---|
committer | Andrea Diamantini <adjam7@gmail.com> | 2011-01-09 11:42:23 +0100 |
commit | 527756748468ddd3d5e7fa1bafcb2e32bf02144b (patch) | |
tree | f1f9a34722932e30d8341ec8299cda07b18cfc15 /src/urlbar/urlresolver.cpp | |
parent | Should fix rekonq compilation against KDE SC 4.5... (diff) | |
download | rekonq-527756748468ddd3d5e7fa1bafcb2e32bf02144b.tar.xz |
Update the completion list when the user switches search engine on the fly.
Lionel Chauvin's work.
Reviewed by me :)
Diffstat (limited to 'src/urlbar/urlresolver.cpp')
-rw-r--r-- | src/urlbar/urlresolver.cpp | 31 |
1 files changed, 21 insertions, 10 deletions
diff --git a/src/urlbar/urlresolver.cpp b/src/urlbar/urlresolver.cpp index 864eca04..3797f51f 100644 --- a/src/urlbar/urlresolver.cpp +++ b/src/urlbar/urlresolver.cpp @@ -69,6 +69,7 @@ QRegExp UrlResolver::_searchEnginesRegexp; UrlResolver::UrlResolver(const QString &typedUrl) : QObject() , _typedString(typedUrl.trimmed()) + , _typedQuery() { if (!_searchEngine ) setSearchEngine(SearchEngine::defaultEngine()); @@ -339,12 +340,12 @@ void UrlResolver::computeWebSearches() if (engine) { query = query.remove(0, _typedString.indexOf(SearchEngine::delimiter()) + 1); - _searchEngine = engine; + setSearchEngine(engine); } if(_searchEngine) { - UrlSearchItem item = UrlSearchItem(UrlSearchItem::Search, SearchEngine::buildQuery(_searchEngine, query), _searchEngine->name()); + UrlSearchItem item = UrlSearchItem(UrlSearchItem::Search, SearchEngine::buildQuery(_searchEngine, query), query); UrlSearchList list; list << item; _webSearches = list; @@ -394,30 +395,40 @@ void UrlResolver::computeSuggestions() return; } + QString query = _typedString; + KService::Ptr engine = SearchEngine::fromString(_typedString); + if (engine) + { + query = query.remove(0, _typedString.indexOf(SearchEngine::delimiter()) + 1); + setSearchEngine(engine); + } + connect(Application::opensearchManager(), - SIGNAL(suggestionReceived(const QString &, const ResponseList &)), + SIGNAL(suggestionsReceived(const QString &, const ResponseList &)), this, SLOT(suggestionsReceived(const QString &, const ResponseList &))); - Application::opensearchManager()->requestSuggestion(_typedString); + _typedQuery = query; + Application::opensearchManager()->requestSuggestion(query); } void UrlResolver::suggestionsReceived(const QString &text, const ResponseList &suggestions) { - if(text != _typedString) + if(text != _typedQuery) return; UrlSearchList sugList; - + QString urlString; Q_FOREACH(const Response &i, suggestions) { - QString url = i.url; - if (url.isEmpty()) + urlString = i.url; + if (urlString.isEmpty()) { - url = SearchEngine::buildQuery(searchEngine(), i.title); + urlString = SearchEngine::buildQuery(UrlResolver::searchEngine(),i.title); } - UrlSearchItem gItem(UrlSearchItem::Suggestion, url, i.title, i.description, i.image, i.image_width, i.image_height); + + UrlSearchItem gItem(UrlSearchItem::Suggestion, urlString, i.title, i.description, i.image, i.image_width, i.image_height); sugList << gItem; } emit suggestionsReady(sugList, _typedString); |