OLD | NEW |
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 "components/search_engines/template_url.h" | 5 #include "components/search_engines/template_url.h" |
6 | 6 |
7 #include <string> | 7 #include <string> |
8 #include <vector> | 8 #include <vector> |
9 | 9 |
10 #include "base/command_line.h" | 10 #include "base/command_line.h" |
(...skipping 50 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
61 const char kDisplayUnescapedSearchTerms[] = "%S"; | 61 const char kDisplayUnescapedSearchTerms[] = "%S"; |
62 | 62 |
63 // Used if the count parameter is not optional. Indicates we want 10 search | 63 // Used if the count parameter is not optional. Indicates we want 10 search |
64 // results. | 64 // results. |
65 const char kDefaultCount[] = "10"; | 65 const char kDefaultCount[] = "10"; |
66 | 66 |
67 // Used if the output encoding parameter is required. | 67 // Used if the output encoding parameter is required. |
68 const char kOutputEncodingType[] = "UTF-8"; | 68 const char kOutputEncodingType[] = "UTF-8"; |
69 | 69 |
70 constexpr char kGoogleInstantExtendedEnabledKey[] = | 70 constexpr char kGoogleInstantExtendedEnabledKey[] = |
| 71 "google:instantExtendedEnabledKey"; |
| 72 constexpr char kGoogleInstantExtendedEnabledKeyFull[] = |
71 "{google:instantExtendedEnabledKey}"; | 73 "{google:instantExtendedEnabledKey}"; |
72 | 74 |
73 // Attempts to encode |terms| and |original_query| in |encoding| and escape | 75 // Attempts to encode |terms| and |original_query| in |encoding| and escape |
74 // them. |terms| may be escaped as path or query depending on |is_in_query|; | 76 // them. |terms| may be escaped as path or query depending on |is_in_query|; |
75 // |original_query| is always escaped as query. Returns whether the encoding | 77 // |original_query| is always escaped as query. Returns whether the encoding |
76 // process succeeded. | 78 // process succeeded. |
77 bool TryEncoding(const base::string16& terms, | 79 bool TryEncoding(const base::string16& terms, |
78 const base::string16& original_query, | 80 const base::string16& original_query, |
79 const char* encoding, | 81 const char* encoding, |
80 bool is_in_query, | 82 bool is_in_query, |
(...skipping 83 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
164 } | 166 } |
165 | 167 |
166 // Special case for search_terms_replacement_key comparison, because of | 168 // Special case for search_terms_replacement_key comparison, because of |
167 // its special initialization in TemplateUrl constructor. | 169 // its special initialization in TemplateUrl constructor. |
168 bool SearchTermsReplacementKeysMatch( | 170 bool SearchTermsReplacementKeysMatch( |
169 const std::string& search_terms_replacement_key1, | 171 const std::string& search_terms_replacement_key1, |
170 const std::string& search_terms_replacement_key2) { | 172 const std::string& search_terms_replacement_key2) { |
171 if (search_terms_replacement_key1 == search_terms_replacement_key2) | 173 if (search_terms_replacement_key1 == search_terms_replacement_key2) |
172 return true; | 174 return true; |
173 if (search_terms_replacement_key1 == google_util::kInstantExtendedAPIParam && | 175 if (search_terms_replacement_key1 == google_util::kInstantExtendedAPIParam && |
174 search_terms_replacement_key2 == kGoogleInstantExtendedEnabledKey) | 176 search_terms_replacement_key2 == kGoogleInstantExtendedEnabledKeyFull) |
175 return true; | 177 return true; |
176 if (search_terms_replacement_key2 == google_util::kInstantExtendedAPIParam && | 178 if (search_terms_replacement_key2 == google_util::kInstantExtendedAPIParam && |
177 search_terms_replacement_key1 == kGoogleInstantExtendedEnabledKey) | 179 search_terms_replacement_key1 == kGoogleInstantExtendedEnabledKeyFull) |
178 return true; | 180 return true; |
179 return false; | 181 return false; |
180 } | 182 } |
181 | 183 |
182 } // namespace | 184 } // namespace |
183 | 185 |
184 | 186 |
185 // TemplateURLRef::SearchTermsArgs -------------------------------------------- | 187 // TemplateURLRef::SearchTermsArgs -------------------------------------------- |
186 | 188 |
187 TemplateURLRef::SearchTermsArgs::SearchTermsArgs( | 189 TemplateURLRef::SearchTermsArgs::SearchTermsArgs( |
(...skipping 1016 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
1204 suggestions_url_ref_(this, TemplateURLRef::SUGGEST), | 1206 suggestions_url_ref_(this, TemplateURLRef::SUGGEST), |
1205 instant_url_ref_(this, TemplateURLRef::INSTANT), | 1207 instant_url_ref_(this, TemplateURLRef::INSTANT), |
1206 image_url_ref_(this, TemplateURLRef::IMAGE), | 1208 image_url_ref_(this, TemplateURLRef::IMAGE), |
1207 new_tab_url_ref_(this, TemplateURLRef::NEW_TAB), | 1209 new_tab_url_ref_(this, TemplateURLRef::NEW_TAB), |
1208 contextual_search_url_ref_(this, TemplateURLRef::CONTEXTUAL_SEARCH), | 1210 contextual_search_url_ref_(this, TemplateURLRef::CONTEXTUAL_SEARCH), |
1209 type_(type), | 1211 type_(type), |
1210 engine_type_(SEARCH_ENGINE_UNKNOWN) { | 1212 engine_type_(SEARCH_ENGINE_UNKNOWN) { |
1211 ResizeURLRefVector(); | 1213 ResizeURLRefVector(); |
1212 SetPrepopulateId(data_.prepopulate_id); | 1214 SetPrepopulateId(data_.prepopulate_id); |
1213 | 1215 |
1214 if (data_.search_terms_replacement_key == kGoogleInstantExtendedEnabledKey) | 1216 if (data_.search_terms_replacement_key == |
| 1217 kGoogleInstantExtendedEnabledKeyFull) |
1215 data_.search_terms_replacement_key = google_util::kInstantExtendedAPIParam; | 1218 data_.search_terms_replacement_key = google_util::kInstantExtendedAPIParam; |
1216 } | 1219 } |
1217 | 1220 |
1218 TemplateURL::~TemplateURL() { | 1221 TemplateURL::~TemplateURL() { |
1219 } | 1222 } |
1220 | 1223 |
1221 // static | 1224 // static |
1222 base::string16 TemplateURL::GenerateKeyword(const GURL& url) { | 1225 base::string16 TemplateURL::GenerateKeyword(const GURL& url) { |
1223 DCHECK(url.is_valid()); | 1226 DCHECK(url.is_valid()); |
1224 // Strip "www." off the front of the keyword; otherwise the keyword won't work | 1227 // Strip "www." off the front of the keyword; otherwise the keyword won't work |
(...skipping 316 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
1541 // patterns. This means that given patterns | 1544 // patterns. This means that given patterns |
1542 // [ "http://foo/#q={searchTerms}", "http://foo/?q={searchTerms}" ], | 1545 // [ "http://foo/#q={searchTerms}", "http://foo/?q={searchTerms}" ], |
1543 // calling ExtractSearchTermsFromURL() on "http://foo/?q=bar#q=' would | 1546 // calling ExtractSearchTermsFromURL() on "http://foo/?q=bar#q=' would |
1544 // return false. This is important for at least Google, where such URLs | 1547 // return false. This is important for at least Google, where such URLs |
1545 // are invalid. | 1548 // are invalid. |
1546 return !search_terms->empty(); | 1549 return !search_terms->empty(); |
1547 } | 1550 } |
1548 } | 1551 } |
1549 return false; | 1552 return false; |
1550 } | 1553 } |
OLD | NEW |