Chromium Code Reviews| 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/basictypes.h" | 10 #include "base/basictypes.h" |
| (...skipping 85 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 96 const char kGoogleSuggestAPIKeyParameter[] = "google:suggestAPIKeyParameter"; | 96 const char kGoogleSuggestAPIKeyParameter[] = "google:suggestAPIKeyParameter"; |
| 97 const char kGoogleSuggestClient[] = "google:suggestClient"; | 97 const char kGoogleSuggestClient[] = "google:suggestClient"; |
| 98 const char kGoogleSuggestRequestId[] = "google:suggestRid"; | 98 const char kGoogleSuggestRequestId[] = "google:suggestRid"; |
| 99 | 99 |
| 100 // Same as kSearchTermsParameter, with no escaping. | 100 // Same as kSearchTermsParameter, with no escaping. |
| 101 const char kGoogleUnescapedSearchTermsParameter[] = | 101 const char kGoogleUnescapedSearchTermsParameter[] = |
| 102 "google:unescapedSearchTerms"; | 102 "google:unescapedSearchTerms"; |
| 103 const char kGoogleUnescapedSearchTermsParameterFull[] = | 103 const char kGoogleUnescapedSearchTermsParameterFull[] = |
| 104 "{google:unescapedSearchTerms}"; | 104 "{google:unescapedSearchTerms}"; |
| 105 | 105 |
| 106 // Yandex reported that mobile should use a different path for the search | |
| 107 // to avoid one additional redirect, this is used to encode the path in | |
| 108 // the URL template. | |
| 109 const char kYandexSearchPathParameter[] = "yandex:searchPath"; | |
|
Peter Kasting
2015/05/13 22:56:55
I'm not a fan of the ton of constants we have up h
sdefresne
2015/05/18 12:35:45
Done. Followup CL https://codereview.chromium.org/
| |
| 110 | |
| 106 // Display value for kSearchTermsParameter. | 111 // Display value for kSearchTermsParameter. |
| 107 const char kDisplaySearchTerms[] = "%s"; | 112 const char kDisplaySearchTerms[] = "%s"; |
| 108 | 113 |
| 109 // Display value for kGoogleUnescapedSearchTermsParameter. | 114 // Display value for kGoogleUnescapedSearchTermsParameter. |
| 110 const char kDisplayUnescapedSearchTerms[] = "%S"; | 115 const char kDisplayUnescapedSearchTerms[] = "%S"; |
| 111 | 116 |
| 112 // Used if the count parameter is not optional. Indicates we want 10 search | 117 // Used if the count parameter is not optional. Indicates we want 10 search |
| 113 // results. | 118 // results. |
| 114 const char kDefaultCount[] = "10"; | 119 const char kDefaultCount[] = "10"; |
| 115 | 120 |
| (...skipping 563 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 679 #endif | 684 #endif |
| 680 } else if (parameter == kGoogleSuggestAPIKeyParameter) { | 685 } else if (parameter == kGoogleSuggestAPIKeyParameter) { |
| 681 url->insert(start, | 686 url->insert(start, |
| 682 net::EscapeQueryParamValue(google_apis::GetAPIKey(), false)); | 687 net::EscapeQueryParamValue(google_apis::GetAPIKey(), false)); |
| 683 } else if (parameter == kGoogleSuggestClient) { | 688 } else if (parameter == kGoogleSuggestClient) { |
| 684 replacements->push_back(Replacement(GOOGLE_SUGGEST_CLIENT, start)); | 689 replacements->push_back(Replacement(GOOGLE_SUGGEST_CLIENT, start)); |
| 685 } else if (parameter == kGoogleSuggestRequestId) { | 690 } else if (parameter == kGoogleSuggestRequestId) { |
| 686 replacements->push_back(Replacement(GOOGLE_SUGGEST_REQUEST_ID, start)); | 691 replacements->push_back(Replacement(GOOGLE_SUGGEST_REQUEST_ID, start)); |
| 687 } else if (parameter == kGoogleUnescapedSearchTermsParameter) { | 692 } else if (parameter == kGoogleUnescapedSearchTermsParameter) { |
| 688 replacements->push_back(Replacement(GOOGLE_UNESCAPED_SEARCH_TERMS, start)); | 693 replacements->push_back(Replacement(GOOGLE_UNESCAPED_SEARCH_TERMS, start)); |
| 694 } else if (parameter == kYandexSearchPathParameter) { | |
| 695 #if defined(OS_ANDROID) || defined(OS_IOS) | |
|
Peter Kasting
2015/05/13 22:56:55
Is OS_ANDROID correct here for tablets running And
sdefresne
2015/05/18 12:35:45
I've tested and tablet are redirected to "padsearc
| |
| 696 url->insert(start, "touchsearch"); | |
| 697 #else | |
| 698 url->insert(start, "yandsearch"); | |
| 699 #endif | |
| 689 } else if (parameter == kInputEncodingParameter) { | 700 } else if (parameter == kInputEncodingParameter) { |
| 690 replacements->push_back(Replacement(ENCODING, start)); | 701 replacements->push_back(Replacement(ENCODING, start)); |
| 691 } else if (parameter == kLanguageParameter) { | 702 } else if (parameter == kLanguageParameter) { |
| 692 replacements->push_back(Replacement(LANGUAGE, start)); | 703 replacements->push_back(Replacement(LANGUAGE, start)); |
| 693 } else if (parameter == kOutputEncodingParameter) { | 704 } else if (parameter == kOutputEncodingParameter) { |
| 694 if (!optional) | 705 if (!optional) |
| 695 url->insert(start, kOutputEncodingType); | 706 url->insert(start, kOutputEncodingType); |
| 696 } else if ((parameter == kStartIndexParameter) || | 707 } else if ((parameter == kStartIndexParameter) || |
| 697 (parameter == kStartPageParameter)) { | 708 (parameter == kStartPageParameter)) { |
| 698 // We don't support these. | 709 // We don't support these. |
| (...skipping 844 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 1543 // patterns. This means that given patterns | 1554 // patterns. This means that given patterns |
| 1544 // [ "http://foo/#q={searchTerms}", "http://foo/?q={searchTerms}" ], | 1555 // [ "http://foo/#q={searchTerms}", "http://foo/?q={searchTerms}" ], |
| 1545 // calling ExtractSearchTermsFromURL() on "http://foo/?q=bar#q=' would | 1556 // calling ExtractSearchTermsFromURL() on "http://foo/?q=bar#q=' would |
| 1546 // return false. This is important for at least Google, where such URLs | 1557 // return false. This is important for at least Google, where such URLs |
| 1547 // are invalid. | 1558 // are invalid. |
| 1548 return !search_terms->empty(); | 1559 return !search_terms->empty(); |
| 1549 } | 1560 } |
| 1550 } | 1561 } |
| 1551 return false; | 1562 return false; |
| 1552 } | 1563 } |
| OLD | NEW |