Chromium Code Reviews| OLD | NEW |
|---|---|
| 1 // Copyright 2013 The Chromium Authors. All rights reserved. | 1 // Copyright 2013 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 #ifndef CHROME_BROWSER_SEARCH_INSTANT_SERVICE_H_ | 5 #ifndef CHROME_BROWSER_SEARCH_INSTANT_SERVICE_H_ |
| 6 #define CHROME_BROWSER_SEARCH_INSTANT_SERVICE_H_ | 6 #define CHROME_BROWSER_SEARCH_INSTANT_SERVICE_H_ |
| 7 | 7 |
| 8 #include <map> | 8 #include <map> |
| 9 #include <set> | 9 #include <set> |
| 10 #include <string> | 10 #include <string> |
| 11 #include <vector> | 11 #include <vector> |
| 12 | 12 |
| 13 #include "base/basictypes.h" | 13 #include "base/basictypes.h" |
| 14 #include "base/memory/ref_counted.h" | 14 #include "base/memory/ref_counted.h" |
| 15 #include "base/memory/scoped_ptr.h" | 15 #include "base/memory/scoped_ptr.h" |
| 16 #include "base/memory/weak_ptr.h" | 16 #include "base/memory/weak_ptr.h" |
| 17 #include "base/observer_list.h" | 17 #include "base/observer_list.h" |
| 18 #include "base/prefs/pref_change_registrar.h" | 18 #include "base/prefs/pref_change_registrar.h" |
| 19 #include "chrome/browser/google/google_url_tracker.h" | 19 #include "chrome/browser/google/google_url_tracker.h" |
| 20 #include "chrome/browser/history/history_types.h" | 20 #include "chrome/browser/history/history_types.h" |
| 21 #include "chrome/browser/search_engines/template_url_service_observer.h" | |
| 21 #include "chrome/browser/ui/search/instant_search_prerenderer.h" | 22 #include "chrome/browser/ui/search/instant_search_prerenderer.h" |
| 22 #include "chrome/common/instant_types.h" | 23 #include "chrome/common/instant_types.h" |
| 23 #include "components/keyed_service/core/keyed_service.h" | 24 #include "components/keyed_service/core/keyed_service.h" |
| 24 #include "content/public/browser/notification_observer.h" | 25 #include "content/public/browser/notification_observer.h" |
| 25 #include "content/public/browser/notification_registrar.h" | 26 #include "content/public/browser/notification_registrar.h" |
| 26 | 27 |
| 27 class GURL; | 28 class GURL; |
| 28 class InstantIOContext; | 29 class InstantIOContext; |
| 29 class InstantServiceObserver; | 30 class InstantServiceObserver; |
| 30 class InstantTestBase; | 31 class InstantTestBase; |
| (...skipping 62 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 93 // changed. | 94 // changed. |
| 94 void OnOmniboxStartMarginChanged(int start_margin); | 95 void OnOmniboxStartMarginChanged(int start_margin); |
| 95 | 96 |
| 96 InstantSearchPrerenderer* instant_search_prerenderer() { | 97 InstantSearchPrerenderer* instant_search_prerenderer() { |
| 97 return instant_prerenderer_.get(); | 98 return instant_prerenderer_.get(); |
| 98 } | 99 } |
| 99 | 100 |
| 100 int omnibox_start_margin() const { return omnibox_start_margin_; } | 101 int omnibox_start_margin() const { return omnibox_start_margin_; } |
| 101 | 102 |
| 102 private: | 103 private: |
| 104 class DefaultSearchEngineWatcher : public TemplateURLServiceObserver { | |
|
Peter Kasting
2014/05/03 00:28:18
What do we gain by having this class instead of ma
erikwright (departed)
2014/05/03 00:54:08
It maintains encapsulation. OnTemplateURLServiceCh
Peter Kasting
2014/05/03 01:18:17
That's fine, you should be declaring that method p
erikwright (departed)
2014/05/03 01:24:59
It's not as though converting from an InstantServi
Peter Kasting
2014/05/03 01:31:01
It requires an explicit upcast or assignment. Tha
erikwright (departed)
2014/05/05 01:49:38
Done.
| |
| 105 public: | |
| 106 explicit DefaultSearchEngineWatcher(InstantService* outer); | |
|
Peter Kasting
2014/05/03 00:28:18
Nit: I suggest explicitly declaring a virtual dest
erikwright (departed)
2014/05/05 01:49:38
Done.
| |
| 107 virtual void OnTemplateURLServiceChanged() OVERRIDE; | |
| 108 | |
| 109 private: | |
| 110 InstantService* outer_; | |
| 111 DISALLOW_COPY_AND_ASSIGN(DefaultSearchEngineWatcher); | |
|
Peter Kasting
2014/05/03 00:28:18
Tiny nit: I'd put a blank line above this. Also p
erikwright (departed)
2014/05/05 01:49:38
Done.
| |
| 112 }; | |
| 113 | |
| 103 friend class InstantExtendedTest; | 114 friend class InstantExtendedTest; |
| 104 friend class InstantServiceTest; | 115 friend class InstantServiceTest; |
| 105 friend class InstantTestBase; | 116 friend class InstantTestBase; |
| 106 friend class InstantUnitTestBase; | 117 friend class InstantUnitTestBase; |
| 107 | 118 |
| 108 FRIEND_TEST_ALL_PREFIXES(InstantExtendedManualTest, | 119 FRIEND_TEST_ALL_PREFIXES(InstantExtendedManualTest, |
| 109 MANUAL_SearchesFromFakebox); | 120 MANUAL_SearchesFromFakebox); |
| 110 FRIEND_TEST_ALL_PREFIXES(InstantExtendedTest, ProcessIsolation); | 121 FRIEND_TEST_ALL_PREFIXES(InstantExtendedTest, ProcessIsolation); |
| 111 FRIEND_TEST_ALL_PREFIXES(InstantServiceTest, SendsSearchURLsToRenderer); | 122 FRIEND_TEST_ALL_PREFIXES(InstantServiceTest, SendsSearchURLsToRenderer); |
| 112 | 123 |
| (...skipping 15 matching lines...) Expand all Loading... | |
| 128 | 139 |
| 129 // Notifies the observer about the last known most visited items. | 140 // Notifies the observer about the last known most visited items. |
| 130 void NotifyAboutMostVisitedItems(); | 141 void NotifyAboutMostVisitedItems(); |
| 131 | 142 |
| 132 // Theme changed notification handler. | 143 // Theme changed notification handler. |
| 133 void OnThemeChanged(ThemeService* theme_service); | 144 void OnThemeChanged(ThemeService* theme_service); |
| 134 | 145 |
| 135 void OnGoogleURLUpdated(Profile* profile, | 146 void OnGoogleURLUpdated(Profile* profile, |
| 136 GoogleURLTracker::UpdatedDetails* details); | 147 GoogleURLTracker::UpdatedDetails* details); |
| 137 | 148 |
| 138 void OnDefaultSearchProviderChanged(const std::string& pref_name); | 149 void OnTemplateURLServiceChanged(); |
| 139 | 150 |
| 140 void ResetInstantSearchPrerenderer(); | 151 void ResetInstantSearchPrerenderer(); |
| 141 | 152 |
| 142 Profile* const profile_; | 153 Profile* const profile_; |
| 143 | 154 |
| 144 // The process ids associated with Instant processes. | 155 // The process ids associated with Instant processes. |
| 145 std::set<int> process_ids_; | 156 std::set<int> process_ids_; |
| 146 | 157 |
| 147 // InstantMostVisitedItems sent to the Instant Pages. | 158 // InstantMostVisitedItems sent to the Instant Pages. |
| 148 std::vector<InstantMostVisitedItem> most_visited_items_; | 159 std::vector<InstantMostVisitedItem> most_visited_items_; |
| (...skipping 12 matching lines...) Expand all Loading... | |
| 161 PrefChangeRegistrar profile_pref_registrar_; | 172 PrefChangeRegistrar profile_pref_registrar_; |
| 162 | 173 |
| 163 scoped_refptr<InstantIOContext> instant_io_context_; | 174 scoped_refptr<InstantIOContext> instant_io_context_; |
| 164 | 175 |
| 165 // Set to NULL if the default search provider does not support Instant. | 176 // Set to NULL if the default search provider does not support Instant. |
| 166 scoped_ptr<InstantSearchPrerenderer> instant_prerenderer_; | 177 scoped_ptr<InstantSearchPrerenderer> instant_prerenderer_; |
| 167 | 178 |
| 168 // Used for Top Sites async retrieval. | 179 // Used for Top Sites async retrieval. |
| 169 base::WeakPtrFactory<InstantService> weak_ptr_factory_; | 180 base::WeakPtrFactory<InstantService> weak_ptr_factory_; |
| 170 | 181 |
| 182 // Used to avoid resetting the instant_prerenderer_ if an unrelated change to | |
| 183 // the TemplateURLService occurs. | |
| 184 GURL current_search_result_prefetch_base_url_; | |
| 185 | |
| 186 DefaultSearchEngineWatcher default_search_engine_watcher_; | |
| 187 | |
| 171 DISALLOW_COPY_AND_ASSIGN(InstantService); | 188 DISALLOW_COPY_AND_ASSIGN(InstantService); |
| 172 }; | 189 }; |
| 173 | 190 |
| 174 #endif // CHROME_BROWSER_SEARCH_INSTANT_SERVICE_H_ | 191 #endif // CHROME_BROWSER_SEARCH_INSTANT_SERVICE_H_ |
| OLD | NEW |