OLD | NEW |
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/ui/search/search.h" | 5 #include "chrome/browser/ui/search/search.h" |
6 | 6 |
7 #include "base/command_line.h" | 7 #include "base/command_line.h" |
8 #include "base/metrics/field_trial.h" | 8 #include "base/metrics/field_trial.h" |
9 #include "base/string_number_conversions.h" | 9 #include "base/string_number_conversions.h" |
10 #include "base/string_split.h" | 10 #include "base/string_split.h" |
11 #include "base/string_util.h" | 11 #include "base/string_util.h" |
12 #include "chrome/browser/profiles/profile.h" | 12 #include "chrome/browser/profiles/profile.h" |
13 #include "chrome/common/chrome_switches.h" | 13 #include "chrome/common/chrome_switches.h" |
14 #include "chrome/common/chrome_version_info.h" | 14 #include "chrome/common/chrome_version_info.h" |
| 15 #include "content/public/browser/navigation_entry.h" |
15 | 16 |
16 #if !defined(OS_ANDROID) | 17 #if !defined(OS_ANDROID) |
17 #include "chrome/browser/themes/theme_service.h" | 18 #include "chrome/browser/themes/theme_service.h" |
18 #include "chrome/browser/themes/theme_service_factory.h" | 19 #include "chrome/browser/themes/theme_service_factory.h" |
19 #endif | 20 #endif |
20 | 21 |
21 namespace { | 22 namespace { |
22 | 23 |
23 // Configuration options for Embedded Search. | 24 // Configuration options for Embedded Search. |
24 // InstantExtended field trials are named in such a way that we can parse out | 25 // InstantExtended field trials are named in such a way that we can parse out |
(...skipping 14 matching lines...) Expand all Loading... |
39 | 40 |
40 // If the field trial's group name ends with this string its configuration will | 41 // If the field trial's group name ends with this string its configuration will |
41 // be ignored and Instant Extended will not be enabled by default. | 42 // be ignored and Instant Extended will not be enabled by default. |
42 const char kDisablingSuffix[] = "DISABLED"; | 43 const char kDisablingSuffix[] = "DISABLED"; |
43 | 44 |
44 } // namespace | 45 } // namespace |
45 | 46 |
46 namespace chrome { | 47 namespace chrome { |
47 namespace search { | 48 namespace search { |
48 | 49 |
| 50 // static |
| 51 const char kInstantExtendedSearchTermsKey[] = "search_terms"; |
| 52 |
49 // Check whether or not the Extended API should be used on the given profile. | 53 // Check whether or not the Extended API should be used on the given profile. |
50 bool IsInstantExtendedAPIEnabled(Profile* profile) { | 54 bool IsInstantExtendedAPIEnabled(Profile* profile) { |
51 return EmbeddedSearchPageVersion(profile) != 0; | 55 return EmbeddedSearchPageVersion(profile) != 0; |
52 } | 56 } |
53 | 57 |
54 // Determine what embedded search page version to request from the user's | 58 // Determine what embedded search page version to request from the user's |
55 // default search provider. If 0, the embedded search UI should not be enabled. | 59 // default search provider. If 0, the embedded search UI should not be enabled. |
56 // Note that the profile object here isn't const because we need to determine | 60 // Note that the profile object here isn't const because we need to determine |
57 // whether or not the user has a theme installed as part of this check, and | 61 // whether or not the user has a theme installed as part of this check, and |
58 // that logic requires a non-const profile for whatever reason. | 62 // that logic requires a non-const profile for whatever reason. |
(...skipping 73 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
132 CommandLine::ForCurrentProcess()->AppendSwitch( | 136 CommandLine::ForCurrentProcess()->AppendSwitch( |
133 switches::kEnableQueryExtraction); | 137 switches::kEnableQueryExtraction); |
134 #else | 138 #else |
135 // On desktop, query extraction is controlled by the instant-extended-api | 139 // On desktop, query extraction is controlled by the instant-extended-api |
136 // flag. | 140 // flag. |
137 CommandLine::ForCurrentProcess()->AppendSwitch( | 141 CommandLine::ForCurrentProcess()->AppendSwitch( |
138 switches::kEnableInstantExtendedAPI); | 142 switches::kEnableInstantExtendedAPI); |
139 #endif | 143 #endif |
140 } | 144 } |
141 | 145 |
| 146 string16 GetSearchTermsFromNavigationEntry( |
| 147 const content::NavigationEntry* entry) { |
| 148 string16 search_terms; |
| 149 entry->GetExtraData(kInstantExtendedSearchTermsKey, &search_terms); |
| 150 return search_terms; |
| 151 } |
| 152 |
142 bool IsForcedInstantURL(const GURL& url) { | 153 bool IsForcedInstantURL(const GURL& url) { |
143 CommandLine* command_line = CommandLine::ForCurrentProcess(); | 154 CommandLine* command_line = CommandLine::ForCurrentProcess(); |
144 if (!command_line->HasSwitch(switches::kInstantURL)) | 155 if (!command_line->HasSwitch(switches::kInstantURL)) |
145 return false; | 156 return false; |
146 | 157 |
147 GURL instant_url(command_line->GetSwitchValueASCII(switches::kInstantURL)); | 158 GURL instant_url(command_line->GetSwitchValueASCII(switches::kInstantURL)); |
148 return url.scheme() == instant_url.scheme() && | 159 return url.scheme() == instant_url.scheme() && |
149 url.host() == instant_url.host() && | 160 url.host() == instant_url.host() && |
150 url.port() == instant_url.port() && | 161 url.port() == instant_url.port() && |
151 url.path() == instant_url.path(); | 162 url.path() == instant_url.path(); |
(...skipping 51 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
203 | 214 |
204 // Given a FieldTrialFlags object, returns the boolean value of the provided | 215 // Given a FieldTrialFlags object, returns the boolean value of the provided |
205 // flag. | 216 // flag. |
206 bool GetBoolValueForFlagWithDefault( | 217 bool GetBoolValueForFlagWithDefault( |
207 const std::string& flag, bool default_value, FieldTrialFlags& flags) { | 218 const std::string& flag, bool default_value, FieldTrialFlags& flags) { |
208 return !!GetUInt64ValueForFlagWithDefault(flag, default_value ? 1 : 0, flags); | 219 return !!GetUInt64ValueForFlagWithDefault(flag, default_value ? 1 : 0, flags); |
209 } | 220 } |
210 | 221 |
211 } // namespace search | 222 } // namespace search |
212 } // namespace chrome | 223 } // namespace chrome |
OLD | NEW |