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

Side by Side Diff: chrome/browser/android/omnibox/autocomplete_controller_android.cc

Issue 321943002: Prefetch high-confidence search suggestions in Android Chrome. (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: Rebase Created 6 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 | Annotate | Revision Log
« no previous file with comments | « chrome/browser/about_flags.cc ('k') | chrome/browser/android/omnibox/omnibox_prerender.cc » ('j') | no next file with comments »
Toggle Intra-line Diffs ('i') | Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
OLDNEW
1 // Copyright 2014 The Chromium Authors. All rights reserved. 1 // Copyright 2014 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/android/omnibox/autocomplete_controller_android.h" 5 #include "chrome/browser/android/omnibox/autocomplete_controller_android.h"
6 6
7 #include "base/android/jni_android.h" 7 #include "base/android/jni_android.h"
8 #include "base/android/jni_string.h" 8 #include "base/android/jni_string.h"
9 #include "base/prefs/pref_service.h" 9 #include "base/prefs/pref_service.h"
10 #include "base/strings/string16.h" 10 #include "base/strings/string16.h"
11 #include "base/strings/utf_string_conversions.h" 11 #include "base/strings/utf_string_conversions.h"
12 #include "base/time/time.h" 12 #include "base/time/time.h"
13 #include "base/timer/timer.h" 13 #include "base/timer/timer.h"
14 #include "chrome/browser/autocomplete/autocomplete_classifier.h" 14 #include "chrome/browser/autocomplete/autocomplete_classifier.h"
15 #include "chrome/browser/autocomplete/autocomplete_classifier_factory.h" 15 #include "chrome/browser/autocomplete/autocomplete_classifier_factory.h"
16 #include "chrome/browser/autocomplete/autocomplete_controller.h" 16 #include "chrome/browser/autocomplete/autocomplete_controller.h"
17 #include "chrome/browser/autocomplete/autocomplete_input.h" 17 #include "chrome/browser/autocomplete/autocomplete_input.h"
18 #include "chrome/browser/autocomplete/autocomplete_match.h" 18 #include "chrome/browser/autocomplete/autocomplete_match.h"
19 #include "chrome/browser/autocomplete/search_provider.h"
19 #include "chrome/browser/autocomplete/shortcuts_backend_factory.h" 20 #include "chrome/browser/autocomplete/shortcuts_backend_factory.h"
20 #include "chrome/browser/browser_process.h" 21 #include "chrome/browser/browser_process.h"
21 #include "chrome/browser/chrome_notification_types.h" 22 #include "chrome/browser/chrome_notification_types.h"
22 #include "chrome/browser/omnibox/omnibox_field_trial.h" 23 #include "chrome/browser/omnibox/omnibox_field_trial.h"
23 #include "chrome/browser/omnibox/omnibox_log.h" 24 #include "chrome/browser/omnibox/omnibox_log.h"
24 #include "chrome/browser/profiles/incognito_helpers.h" 25 #include "chrome/browser/profiles/incognito_helpers.h"
25 #include "chrome/browser/profiles/profile_android.h" 26 #include "chrome/browser/profiles/profile_android.h"
26 #include "chrome/browser/profiles/profile_manager.h" 27 #include "chrome/browser/profiles/profile_manager.h"
28 #include "chrome/browser/search/search.h"
27 #include "chrome/browser/search_engines/template_url_service.h" 29 #include "chrome/browser/search_engines/template_url_service.h"
28 #include "chrome/browser/search_engines/template_url_service_factory.h" 30 #include "chrome/browser/search_engines/template_url_service_factory.h"
29 #include "chrome/browser/sessions/session_id.h" 31 #include "chrome/browser/sessions/session_id.h"
32 #include "chrome/browser/ui/search/instant_search_prerenderer.h"
30 #include "chrome/browser/ui/toolbar/toolbar_model.h" 33 #include "chrome/browser/ui/toolbar/toolbar_model.h"
31 #include "chrome/common/autocomplete_match_type.h" 34 #include "chrome/common/autocomplete_match_type.h"
35 #include "chrome/common/instant_types.h"
32 #include "chrome/common/pref_names.h" 36 #include "chrome/common/pref_names.h"
33 #include "chrome/common/url_constants.h" 37 #include "chrome/common/url_constants.h"
34 #include "components/keyed_service/content/browser_context_dependency_manager.h" 38 #include "components/keyed_service/content/browser_context_dependency_manager.h"
35 #include "content/public/browser/notification_details.h" 39 #include "content/public/browser/notification_details.h"
36 #include "content/public/browser/notification_service.h" 40 #include "content/public/browser/notification_service.h"
37 #include "content/public/browser/notification_source.h" 41 #include "content/public/browser/notification_source.h"
38 #include "content/public/browser/web_contents.h" 42 #include "content/public/browser/web_contents.h"
39 #include "content/public/common/url_constants.h" 43 #include "content/public/common/url_constants.h"
40 #include "jni/AutocompleteController_jni.h" 44 #include "jni/AutocompleteController_jni.h"
41 #include "net/base/escape.h" 45 #include "net/base/escape.h"
(...skipping 280 matching lines...) Expand 10 before | Expand all | Expand 10 after
322 AutocompleteControllerAndroid::~AutocompleteControllerAndroid() { 326 AutocompleteControllerAndroid::~AutocompleteControllerAndroid() {
323 } 327 }
324 328
325 void AutocompleteControllerAndroid::InitJNI(JNIEnv* env, jobject obj) { 329 void AutocompleteControllerAndroid::InitJNI(JNIEnv* env, jobject obj) {
326 weak_java_autocomplete_controller_android_ = 330 weak_java_autocomplete_controller_android_ =
327 JavaObjectWeakGlobalRef(env, obj); 331 JavaObjectWeakGlobalRef(env, obj);
328 } 332 }
329 333
330 void AutocompleteControllerAndroid::OnResultChanged( 334 void AutocompleteControllerAndroid::OnResultChanged(
331 bool default_match_changed) { 335 bool default_match_changed) {
332 if (autocomplete_controller_.get() != NULL && !inside_synchronous_start_) 336 if (!autocomplete_controller_)
337 return;
338
339 const AutocompleteResult& result = autocomplete_controller_->result();
340 const AutocompleteResult::const_iterator default_match(
341 result.default_match());
342 if ((default_match != result.end()) && default_match_changed &&
343 chrome::IsInstantExtendedAPIEnabled() &&
344 chrome::ShouldPrefetchSearchResults()) {
345 InstantSuggestion prefetch_suggestion;
346 // If the default match should be prefetched, do that.
347 if (SearchProvider::ShouldPrefetch(*default_match)) {
348 prefetch_suggestion.text = default_match->contents;
349 prefetch_suggestion.metadata =
350 SearchProvider::GetSuggestMetadata(*default_match);
351 }
352 // Send the prefetch suggestion unconditionally to the Instant search base
353 // page. If there is no suggestion to prefetch, we need to send a blank
354 // query to clear the prefetched results.
355 InstantSearchPrerenderer* prerenderer =
356 InstantSearchPrerenderer::GetForProfile(profile_);
357 if (prerenderer)
358 prerenderer->Prerender(prefetch_suggestion);
359 }
360 if (!inside_synchronous_start_)
333 NotifySuggestionsReceived(autocomplete_controller_->result()); 361 NotifySuggestionsReceived(autocomplete_controller_->result());
334 } 362 }
335 363
336 void AutocompleteControllerAndroid::NotifySuggestionsReceived( 364 void AutocompleteControllerAndroid::NotifySuggestionsReceived(
337 const AutocompleteResult& autocomplete_result) { 365 const AutocompleteResult& autocomplete_result) {
338 JNIEnv* env = AttachCurrentThread(); 366 JNIEnv* env = AttachCurrentThread();
339 ScopedJavaLocalRef<jobject> java_bridge = 367 ScopedJavaLocalRef<jobject> java_bridge =
340 weak_java_autocomplete_controller_android_.get(env); 368 weak_java_autocomplete_controller_android_.get(env);
341 if (!java_bridge.obj()) 369 if (!java_bridge.obj())
342 return; 370 return;
(...skipping 184 matching lines...) Expand 10 before | Expand all | Expand 10 after
527 return; 555 return;
528 556
529 // ZeroSuggestPrefetcher deletes itself after it's done prefetching. 557 // ZeroSuggestPrefetcher deletes itself after it's done prefetching.
530 new ZeroSuggestPrefetcher(profile); 558 new ZeroSuggestPrefetcher(profile);
531 } 559 }
532 560
533 // Register native methods 561 // Register native methods
534 bool RegisterAutocompleteControllerAndroid(JNIEnv* env) { 562 bool RegisterAutocompleteControllerAndroid(JNIEnv* env) {
535 return RegisterNativesImpl(env); 563 return RegisterNativesImpl(env);
536 } 564 }
OLDNEW
« no previous file with comments | « chrome/browser/about_flags.cc ('k') | chrome/browser/android/omnibox/omnibox_prerender.cc » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698