Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(14)

Side by Side Diff: chrome/browser/autocomplete/history_quick_provider.cc

Issue 1185723002: Prepare HistoryProvider for componentization (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: Fix Created 5 years, 6 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch
OLDNEW
1 // Copyright (c) 2012 The Chromium Authors. All rights reserved. 1 // Copyright (c) 2012 The Chromium Authors. All rights reserved.
2 // Use of this source code is governed by a BSD-style license that can be 2 // Use of this source code is governed by a BSD-style license that can be
3 // found in the LICENSE file. 3 // found in the LICENSE file.
4 4
5 #include "chrome/browser/autocomplete/history_quick_provider.h" 5 #include "chrome/browser/autocomplete/history_quick_provider.h"
6 6
7 #include <vector> 7 #include <vector>
8 8
9 #include "base/basictypes.h" 9 #include "base/basictypes.h"
10 #include "base/debug/crash_logging.h" 10 #include "base/debug/crash_logging.h"
(...skipping 29 matching lines...) Expand all
40 #include "content/public/browser/notification_types.h" 40 #include "content/public/browser/notification_types.h"
41 #include "net/base/escape.h" 41 #include "net/base/escape.h"
42 #include "net/base/net_util.h" 42 #include "net/base/net_util.h"
43 #include "net/base/registry_controlled_domains/registry_controlled_domain.h" 43 #include "net/base/registry_controlled_domains/registry_controlled_domain.h"
44 #include "url/third_party/mozilla/url_parse.h" 44 #include "url/third_party/mozilla/url_parse.h"
45 #include "url/url_util.h" 45 #include "url/url_util.h"
46 46
47 bool HistoryQuickProvider::disabled_ = false; 47 bool HistoryQuickProvider::disabled_ = false;
48 48
49 HistoryQuickProvider::HistoryQuickProvider( 49 HistoryQuickProvider::HistoryQuickProvider(
50 scoped_ptr<AutocompleteProviderClient> client,
50 Profile* profile, 51 Profile* profile,
51 InMemoryURLIndex* in_memory_url_index) 52 InMemoryURLIndex* in_memory_url_index)
52 : HistoryProvider(profile, AutocompleteProvider::TYPE_HISTORY_QUICK), 53 : HistoryProvider(client.Pass(), AutocompleteProvider::TYPE_HISTORY_QUICK),
54 profile_(profile),
53 languages_(profile_->GetPrefs()->GetString(prefs::kAcceptLanguages)), 55 languages_(profile_->GetPrefs()->GetString(prefs::kAcceptLanguages)),
54 in_memory_url_index_(in_memory_url_index) { 56 in_memory_url_index_(in_memory_url_index) {
55 } 57 }
56 58
57 void HistoryQuickProvider::Start(const AutocompleteInput& input, 59 void HistoryQuickProvider::Start(const AutocompleteInput& input,
58 bool minimal_changes, 60 bool minimal_changes,
59 bool called_due_to_focus) { 61 bool called_due_to_focus) {
60 matches_.clear(); 62 matches_.clear();
61 if (disabled_ || called_due_to_focus) 63 if (disabled_ || called_due_to_focus)
62 return; 64 return;
(...skipping 37 matching lines...) Expand 10 before | Expand all | Expand 10 after
100 // provider won't promote the URL-what-you-typed match to first 102 // provider won't promote the URL-what-you-typed match to first
101 // for these inputs. 103 // for these inputs.
102 const bool can_have_url_what_you_typed_match_first = 104 const bool can_have_url_what_you_typed_match_first =
103 (autocomplete_input_.type() != metrics::OmniboxInputType::QUERY) && 105 (autocomplete_input_.type() != metrics::OmniboxInputType::QUERY) &&
104 (!autocomplete_input_.parts().username.is_nonempty() || 106 (!autocomplete_input_.parts().username.is_nonempty() ||
105 autocomplete_input_.parts().password.is_nonempty() || 107 autocomplete_input_.parts().password.is_nonempty() ||
106 autocomplete_input_.parts().path.is_nonempty()); 108 autocomplete_input_.parts().path.is_nonempty());
107 if (can_have_url_what_you_typed_match_first) { 109 if (can_have_url_what_you_typed_match_first) {
108 history::HistoryService* const history_service = 110 history::HistoryService* const history_service =
109 HistoryServiceFactory::GetForProfile( 111 HistoryServiceFactory::GetForProfile(
110 profile_, ServiceAccessType::EXPLICIT_ACCESS); 112 profile_, ServiceAccessType::EXPLICIT_ACCESS);
Peter Kasting 2015/06/12 16:20:23 Seems like this ought to be using the client's His
blundell 2015/06/15 08:51:33 Done.
111 // We expect HistoryService to be available. In case it's not, 113 // We expect HistoryService to be available. In case it's not,
112 // (e.g., due to Profile corruption) we let HistoryQuick provider 114 // (e.g., due to Profile corruption) we let HistoryQuick provider
113 // completions (which may be available because it's a different 115 // completions (which may be available because it's a different
114 // data structure) compete with the URL-what-you-typed match as 116 // data structure) compete with the URL-what-you-typed match as
115 // normal. 117 // normal.
116 if (history_service) { 118 if (history_service) {
117 history::URLDatabase* url_db = history_service->InMemoryDatabase(); 119 history::URLDatabase* url_db = history_service->InMemoryDatabase();
118 // url_db can be NULL if it hasn't finished initializing (or 120 // url_db can be NULL if it hasn't finished initializing (or
119 // failed to to initialize). In this case, we let HistoryQuick 121 // failed to to initialize). In this case, we let HistoryQuick
120 // provider completions compete with the URL-what-you-typed 122 // provider completions compete with the URL-what-you-typed
(...skipping 155 matching lines...) Expand 10 before | Expand all | Expand 10 after
276 match.description = info.title(); 278 match.description = info.title();
277 match.description_class = SpansFromTermMatch( 279 match.description_class = SpansFromTermMatch(
278 history_match.title_matches, match.description.length(), false); 280 history_match.title_matches, match.description.length(), false);
279 281
280 match.RecordAdditionalInfo("typed count", info.typed_count()); 282 match.RecordAdditionalInfo("typed count", info.typed_count());
281 match.RecordAdditionalInfo("visit count", info.visit_count()); 283 match.RecordAdditionalInfo("visit count", info.visit_count());
282 match.RecordAdditionalInfo("last visit", info.last_visit()); 284 match.RecordAdditionalInfo("last visit", info.last_visit());
283 285
284 return match; 286 return match;
285 } 287 }
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698