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 27 matching lines...) Expand all Loading... | |
38 // brace is a ?, it indicates the term is optional and can be replaced with | 38 // brace is a ?, it indicates the term is optional and can be replaced with |
39 // an empty string. | 39 // an empty string. |
40 const char kStartParameter = '{'; | 40 const char kStartParameter = '{'; |
41 const char kEndParameter = '}'; | 41 const char kEndParameter = '}'; |
42 const char kOptional = '?'; | 42 const char kOptional = '?'; |
43 | 43 |
44 // Known parameters found in the URL. | 44 // Known parameters found in the URL. |
45 const char kSearchTermsParameter[] = "searchTerms"; | 45 const char kSearchTermsParameter[] = "searchTerms"; |
46 const char kSearchTermsParameterFull[] = "{searchTerms}"; | 46 const char kSearchTermsParameterFull[] = "{searchTerms}"; |
47 const char kSearchTermsParameterFullEscaped[] = "%7BsearchTerms%7D"; | 47 const char kSearchTermsParameterFullEscaped[] = "%7BsearchTerms%7D"; |
48 const char kCountParameter[] = "count"; | |
49 const char kStartIndexParameter[] = "startIndex"; | |
50 const char kStartPageParameter[] = "startPage"; | |
51 const char kLanguageParameter[] = "language"; | |
52 const char kInputEncodingParameter[] = "inputEncoding"; | |
53 const char kOutputEncodingParameter[] = "outputEncoding"; | |
54 | |
55 const char kGoogleAssistedQueryStatsParameter[] = "google:assistedQueryStats"; | |
56 | |
57 // Host/Domain Google searches are relative to. | |
58 const char kGoogleBaseURLParameter[] = "google:baseURL"; | |
59 const char kGoogleBaseURLParameterFull[] = "{google:baseURL}"; | |
60 | |
61 // Like google:baseURL, but for the Search Suggest capability. | |
62 const char kGoogleBaseSuggestURLParameter[] = "google:baseSuggestURL"; | |
63 const char kGoogleBaseSuggestURLParameterFull[] = "{google:baseSuggestURL}"; | |
64 const char kGoogleBookmarkBarPinnedParameter[] = "google:bookmarkBarPinned"; | |
65 const char kGoogleContextualSearchContextData[] = | |
66 "google:contextualSearchContextData"; | |
67 const char kGoogleContextualSearchVersion[] = "google:contextualSearchVersion"; | |
68 const char kGoogleCurrentPageUrlParameter[] = "google:currentPageUrl"; | |
69 const char kGoogleCursorPositionParameter[] = "google:cursorPosition"; | |
70 const char kGoogleForceInstantResultsParameter[] = "google:forceInstantResults"; | |
71 const char kGoogleImageSearchSource[] = "google:imageSearchSource"; | |
72 const char kGoogleImageThumbnailParameter[] = "google:imageThumbnail"; | |
73 const char kGoogleImageOriginalWidth[] = "google:imageOriginalWidth"; | |
74 const char kGoogleImageOriginalHeight[] = "google:imageOriginalHeight"; | |
75 const char kGoogleImageURLParameter[] = "google:imageURL"; | |
76 const char kGoogleInputTypeParameter[] = "google:inputType"; | |
77 const char kGoogleInstantExtendedEnabledParameter[] = | |
78 "google:instantExtendedEnabledParameter"; | |
79 const char kGoogleInstantExtendedEnabledKey[] = | |
80 "google:instantExtendedEnabledKey"; | |
81 const char kGoogleInstantExtendedEnabledKeyFull[] = | |
82 "{google:instantExtendedEnabledKey}"; | |
83 const char kGoogleNTPIsThemedParameter[] = "google:ntpIsThemedParameter"; | |
84 const char kGoogleOmniboxStartMarginParameter[] = | |
85 "google:omniboxStartMarginParameter"; | |
86 const char kGoogleOriginalQueryForSuggestionParameter[] = | |
87 "google:originalQueryForSuggestion"; | |
88 const char kGooglePageClassificationParameter[] = "google:pageClassification"; | |
89 const char kGooglePrefetchQuery[] = "google:prefetchQuery"; | |
90 const char kGoogleRLZParameter[] = "google:RLZ"; | |
91 const char kGoogleSearchClient[] = "google:searchClient"; | |
92 const char kGoogleSearchFieldtrialParameter[] = | |
93 "google:searchFieldtrialParameter"; | |
94 const char kGoogleSearchVersion[] = "google:searchVersion"; | |
95 const char kGoogleSessionToken[] = "google:sessionToken"; | |
96 const char kGoogleSourceIdParameter[] = "google:sourceId"; | |
97 const char kGoogleSuggestAPIKeyParameter[] = "google:suggestAPIKeyParameter"; | |
98 const char kGoogleSuggestClient[] = "google:suggestClient"; | |
99 const char kGoogleSuggestRequestId[] = "google:suggestRid"; | |
100 | 48 |
101 // Same as kSearchTermsParameter, with no escaping. | 49 // Same as kSearchTermsParameter, with no escaping. |
102 const char kGoogleUnescapedSearchTermsParameter[] = | 50 const char kGoogleUnescapedSearchTermsParameter[] = |
103 "google:unescapedSearchTerms"; | 51 "google:unescapedSearchTerms"; |
104 const char kGoogleUnescapedSearchTermsParameterFull[] = | 52 const char kGoogleUnescapedSearchTermsParameterFull[] = |
105 "{google:unescapedSearchTerms}"; | 53 "{google:unescapedSearchTerms}"; |
106 | 54 |
107 // Display value for kSearchTermsParameter. | 55 // Display value for kSearchTermsParameter. |
108 const char kDisplaySearchTerms[] = "%s"; | 56 const char kDisplaySearchTerms[] = "%s"; |
109 | 57 |
110 // Display value for kGoogleUnescapedSearchTermsParameter. | 58 // Display value for kGoogleUnescapedSearchTermsParameter. |
111 const char kDisplayUnescapedSearchTerms[] = "%S"; | 59 const char kDisplayUnescapedSearchTerms[] = "%S"; |
112 | 60 |
113 // Used if the count parameter is not optional. Indicates we want 10 search | 61 // Used if the count parameter is not optional. Indicates we want 10 search |
114 // results. | 62 // results. |
115 const char kDefaultCount[] = "10"; | 63 const char kDefaultCount[] = "10"; |
116 | 64 |
117 // Used if the parameter kOutputEncodingParameter is required. | 65 // Used if the output encodeing parameter is required. |
Peter Kasting
2015/05/18 18:27:30
Nit: encoding
sdefresne
2015/05/19 09:12:29
Done.
| |
118 const char kOutputEncodingType[] = "UTF-8"; | 66 const char kOutputEncodingType[] = "UTF-8"; |
119 | 67 |
120 // Attempts to encode |terms| and |original_query| in |encoding| and escape | 68 // Attempts to encode |terms| and |original_query| in |encoding| and escape |
121 // them. |terms| may be escaped as path or query depending on |is_in_query|; | 69 // them. |terms| may be escaped as path or query depending on |is_in_query|; |
122 // |original_query| is always escaped as query. Returns whether the encoding | 70 // |original_query| is always escaped as query. Returns whether the encoding |
123 // process succeeded. | 71 // process succeeded. |
124 bool TryEncoding(const base::string16& terms, | 72 bool TryEncoding(const base::string16& terms, |
125 const base::string16& original_query, | 73 const base::string16& original_query, |
126 const char* encoding, | 74 const char* encoding, |
127 bool is_in_query, | 75 bool is_in_query, |
(...skipping 470 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
598 length--; | 546 length--; |
599 } | 547 } |
600 std::string parameter(url->substr(start + 1, length)); | 548 std::string parameter(url->substr(start + 1, length)); |
601 std::string full_parameter(url->substr(start, end - start + 1)); | 549 std::string full_parameter(url->substr(start, end - start + 1)); |
602 // Remove the parameter from the string. For parameters who replacement is | 550 // Remove the parameter from the string. For parameters who replacement is |
603 // constant and already known, just replace them directly. For other cases, | 551 // constant and already known, just replace them directly. For other cases, |
604 // like parameters whose values may change over time, use |replacements|. | 552 // like parameters whose values may change over time, use |replacements|. |
605 url->erase(start, end - start + 1); | 553 url->erase(start, end - start + 1); |
606 if (parameter == kSearchTermsParameter) { | 554 if (parameter == kSearchTermsParameter) { |
607 replacements->push_back(Replacement(SEARCH_TERMS, start)); | 555 replacements->push_back(Replacement(SEARCH_TERMS, start)); |
608 } else if (parameter == kCountParameter) { | 556 } else if (parameter == "count") { |
609 if (!optional) | 557 if (!optional) |
610 url->insert(start, kDefaultCount); | 558 url->insert(start, kDefaultCount); |
611 } else if (parameter == kGoogleAssistedQueryStatsParameter) { | 559 } else if (parameter == "google:assistedQueryStats") { |
612 replacements->push_back(Replacement(GOOGLE_ASSISTED_QUERY_STATS, start)); | 560 replacements->push_back(Replacement(GOOGLE_ASSISTED_QUERY_STATS, start)); |
613 } else if (parameter == kGoogleBaseURLParameter) { | 561 } else if (parameter == "google:baseURL") { |
614 replacements->push_back(Replacement(GOOGLE_BASE_URL, start)); | 562 replacements->push_back(Replacement(GOOGLE_BASE_URL, start)); |
615 } else if (parameter == kGoogleBaseSuggestURLParameter) { | 563 } else if (parameter == "google:baseSuggestURL") { |
616 replacements->push_back(Replacement(GOOGLE_BASE_SUGGEST_URL, start)); | 564 replacements->push_back(Replacement(GOOGLE_BASE_SUGGEST_URL, start)); |
617 } else if (parameter == kGoogleBookmarkBarPinnedParameter) { | 565 } else if (parameter == "google:bookmarkBarPinned") { |
618 replacements->push_back(Replacement(GOOGLE_BOOKMARK_BAR_PINNED, start)); | 566 replacements->push_back(Replacement(GOOGLE_BOOKMARK_BAR_PINNED, start)); |
619 } else if (parameter == kGoogleCurrentPageUrlParameter) { | 567 } else if (parameter == "google:currentPageUrl") { |
620 replacements->push_back(Replacement(GOOGLE_CURRENT_PAGE_URL, start)); | 568 replacements->push_back(Replacement(GOOGLE_CURRENT_PAGE_URL, start)); |
621 } else if (parameter == kGoogleCursorPositionParameter) { | 569 } else if (parameter == "google:cursorPosition") { |
622 replacements->push_back(Replacement(GOOGLE_CURSOR_POSITION, start)); | 570 replacements->push_back(Replacement(GOOGLE_CURSOR_POSITION, start)); |
623 } else if (parameter == kGoogleForceInstantResultsParameter) { | 571 } else if (parameter == "google:forceInstantResults") { |
624 replacements->push_back(Replacement(GOOGLE_FORCE_INSTANT_RESULTS, start)); | 572 replacements->push_back(Replacement(GOOGLE_FORCE_INSTANT_RESULTS, start)); |
625 } else if (parameter == kGoogleImageOriginalHeight) { | 573 } else if (parameter == "google:imageOriginalHeight") { |
626 replacements->push_back( | 574 replacements->push_back( |
627 Replacement(TemplateURLRef::GOOGLE_IMAGE_ORIGINAL_HEIGHT, start)); | 575 Replacement(TemplateURLRef::GOOGLE_IMAGE_ORIGINAL_HEIGHT, start)); |
628 } else if (parameter == kGoogleImageOriginalWidth) { | 576 } else if (parameter == "google:imageOriginalWidth") { |
629 replacements->push_back( | 577 replacements->push_back( |
630 Replacement(TemplateURLRef::GOOGLE_IMAGE_ORIGINAL_WIDTH, start)); | 578 Replacement(TemplateURLRef::GOOGLE_IMAGE_ORIGINAL_WIDTH, start)); |
631 } else if (parameter == kGoogleImageSearchSource) { | 579 } else if (parameter == "google:imageSearchSource") { |
632 replacements->push_back( | 580 replacements->push_back( |
633 Replacement(TemplateURLRef::GOOGLE_IMAGE_SEARCH_SOURCE, start)); | 581 Replacement(TemplateURLRef::GOOGLE_IMAGE_SEARCH_SOURCE, start)); |
634 } else if (parameter == kGoogleImageThumbnailParameter) { | 582 } else if (parameter == "google:imageThumbnail") { |
635 replacements->push_back( | 583 replacements->push_back( |
636 Replacement(TemplateURLRef::GOOGLE_IMAGE_THUMBNAIL, start)); | 584 Replacement(TemplateURLRef::GOOGLE_IMAGE_THUMBNAIL, start)); |
637 } else if (parameter == kGoogleImageURLParameter) { | 585 } else if (parameter == "google:imageURL") { |
638 replacements->push_back(Replacement(TemplateURLRef::GOOGLE_IMAGE_URL, | 586 replacements->push_back(Replacement(TemplateURLRef::GOOGLE_IMAGE_URL, |
639 start)); | 587 start)); |
640 } else if (parameter == kGoogleInputTypeParameter) { | 588 } else if (parameter == "google:inputType") { |
641 replacements->push_back(Replacement(TemplateURLRef::GOOGLE_INPUT_TYPE, | 589 replacements->push_back(Replacement(TemplateURLRef::GOOGLE_INPUT_TYPE, |
642 start)); | 590 start)); |
643 } else if (parameter == kGoogleInstantExtendedEnabledParameter) { | 591 } else if (parameter == "google:instantExtendedEnabledParameter") { |
644 replacements->push_back(Replacement(GOOGLE_INSTANT_EXTENDED_ENABLED, | 592 replacements->push_back(Replacement(GOOGLE_INSTANT_EXTENDED_ENABLED, |
645 start)); | 593 start)); |
646 } else if (parameter == kGoogleInstantExtendedEnabledKey) { | 594 } else if (parameter == "google:instantExtendedEnabledKey") { |
647 url->insert(start, google_util::kInstantExtendedAPIParam); | 595 url->insert(start, google_util::kInstantExtendedAPIParam); |
648 } else if (parameter == kGoogleNTPIsThemedParameter) { | 596 } else if (parameter == "google:ntpIsThemedParameter") { |
649 replacements->push_back(Replacement(GOOGLE_NTP_IS_THEMED, start)); | 597 replacements->push_back(Replacement(GOOGLE_NTP_IS_THEMED, start)); |
650 } else if (parameter == kGoogleOmniboxStartMarginParameter) { | 598 } else if (parameter == "google:omniboxStartMarginParameter") { |
651 replacements->push_back(Replacement(GOOGLE_OMNIBOX_START_MARGIN, start)); | 599 replacements->push_back(Replacement(GOOGLE_OMNIBOX_START_MARGIN, start)); |
652 } else if (parameter == kGoogleContextualSearchVersion) { | 600 } else if (parameter == "google:contextualSearchVersion") { |
653 replacements->push_back( | 601 replacements->push_back( |
654 Replacement(GOOGLE_CONTEXTUAL_SEARCH_VERSION, start)); | 602 Replacement(GOOGLE_CONTEXTUAL_SEARCH_VERSION, start)); |
655 } else if (parameter == kGoogleContextualSearchContextData) { | 603 } else if (parameter == "google:contextualSearchContextData") { |
656 replacements->push_back( | 604 replacements->push_back( |
657 Replacement(GOOGLE_CONTEXTUAL_SEARCH_CONTEXT_DATA, start)); | 605 Replacement(GOOGLE_CONTEXTUAL_SEARCH_CONTEXT_DATA, start)); |
658 } else if (parameter == kGoogleOriginalQueryForSuggestionParameter) { | 606 } else if (parameter == "google:originalQueryForSuggestion") { |
659 replacements->push_back(Replacement(GOOGLE_ORIGINAL_QUERY_FOR_SUGGESTION, | 607 replacements->push_back(Replacement(GOOGLE_ORIGINAL_QUERY_FOR_SUGGESTION, |
660 start)); | 608 start)); |
661 } else if (parameter == kGooglePageClassificationParameter) { | 609 } else if (parameter == "google:pageClassification") { |
662 replacements->push_back(Replacement(GOOGLE_PAGE_CLASSIFICATION, start)); | 610 replacements->push_back(Replacement(GOOGLE_PAGE_CLASSIFICATION, start)); |
663 } else if (parameter == kGooglePrefetchQuery) { | 611 } else if (parameter == "google:prefetchQuery") { |
664 replacements->push_back(Replacement(GOOGLE_PREFETCH_QUERY, start)); | 612 replacements->push_back(Replacement(GOOGLE_PREFETCH_QUERY, start)); |
665 } else if (parameter == kGoogleRLZParameter) { | 613 } else if (parameter == "google:RLZ") { |
666 replacements->push_back(Replacement(GOOGLE_RLZ, start)); | 614 replacements->push_back(Replacement(GOOGLE_RLZ, start)); |
667 } else if (parameter == kGoogleSearchClient) { | 615 } else if (parameter == "google:searchClient") { |
668 replacements->push_back(Replacement(GOOGLE_SEARCH_CLIENT, start)); | 616 replacements->push_back(Replacement(GOOGLE_SEARCH_CLIENT, start)); |
669 } else if (parameter == kGoogleSearchFieldtrialParameter) { | 617 } else if (parameter == "google:searchFieldtrialParameter") { |
670 replacements->push_back(Replacement(GOOGLE_SEARCH_FIELDTRIAL_GROUP, start)); | 618 replacements->push_back(Replacement(GOOGLE_SEARCH_FIELDTRIAL_GROUP, start)); |
671 } else if (parameter == kGoogleSearchVersion) { | 619 } else if (parameter == "google:searchVersion") { |
672 replacements->push_back(Replacement(GOOGLE_SEARCH_VERSION, start)); | 620 replacements->push_back(Replacement(GOOGLE_SEARCH_VERSION, start)); |
673 } else if (parameter == kGoogleSessionToken) { | 621 } else if (parameter == "google:sessionToken") { |
674 replacements->push_back(Replacement(GOOGLE_SESSION_TOKEN, start)); | 622 replacements->push_back(Replacement(GOOGLE_SESSION_TOKEN, start)); |
675 } else if (parameter == kGoogleSourceIdParameter) { | 623 } else if (parameter == "google:sourceId") { |
676 #if defined(OS_ANDROID) || defined(OS_IOS) | 624 #if defined(OS_ANDROID) || defined(OS_IOS) |
677 url->insert(start, "sourceid=chrome-mobile&"); | 625 url->insert(start, "sourceid=chrome-mobile&"); |
678 #else | 626 #else |
679 url->insert(start, "sourceid=chrome&"); | 627 url->insert(start, "sourceid=chrome&"); |
680 #endif | 628 #endif |
681 } else if (parameter == kGoogleSuggestAPIKeyParameter) { | 629 } else if (parameter == "google:suggestAPIKeyParameter") { |
682 url->insert(start, | 630 url->insert(start, |
683 net::EscapeQueryParamValue(google_apis::GetAPIKey(), false)); | 631 net::EscapeQueryParamValue(google_apis::GetAPIKey(), false)); |
684 } else if (parameter == kGoogleSuggestClient) { | 632 } else if (parameter == "google:suggestClient") { |
685 replacements->push_back(Replacement(GOOGLE_SUGGEST_CLIENT, start)); | 633 replacements->push_back(Replacement(GOOGLE_SUGGEST_CLIENT, start)); |
686 } else if (parameter == kGoogleSuggestRequestId) { | 634 } else if (parameter == "google:suggestRid") { |
687 replacements->push_back(Replacement(GOOGLE_SUGGEST_REQUEST_ID, start)); | 635 replacements->push_back(Replacement(GOOGLE_SUGGEST_REQUEST_ID, start)); |
688 } else if (parameter == kGoogleUnescapedSearchTermsParameter) { | 636 } else if (parameter == kGoogleUnescapedSearchTermsParameter) { |
689 replacements->push_back(Replacement(GOOGLE_UNESCAPED_SEARCH_TERMS, start)); | 637 replacements->push_back(Replacement(GOOGLE_UNESCAPED_SEARCH_TERMS, start)); |
690 } else if (parameter == "yandex:searchPath") { | 638 } else if (parameter == "yandex:searchPath") { |
691 #if defined(OS_ANDROID) || defined(OS_IOS) | 639 #if defined(OS_ANDROID) || defined(OS_IOS) |
692 if (ui::GetDeviceFormFactor() == ui::DEVICE_FORM_FACTOR_TABLET) | 640 if (ui::GetDeviceFormFactor() == ui::DEVICE_FORM_FACTOR_TABLET) |
693 url->insert(start, "padsearch"); | 641 url->insert(start, "padsearch"); |
694 else | 642 else |
695 url->insert(start, "touchsearch"); | 643 url->insert(start, "touchsearch"); |
696 #else | 644 #else |
697 url->insert(start, "yandsearch"); | 645 url->insert(start, "yandsearch"); |
698 #endif | 646 #endif |
699 } else if (parameter == kInputEncodingParameter) { | 647 } else if (parameter == "inputEncoding") { |
700 replacements->push_back(Replacement(ENCODING, start)); | 648 replacements->push_back(Replacement(ENCODING, start)); |
701 } else if (parameter == kLanguageParameter) { | 649 } else if (parameter == "language") { |
702 replacements->push_back(Replacement(LANGUAGE, start)); | 650 replacements->push_back(Replacement(LANGUAGE, start)); |
703 } else if (parameter == kOutputEncodingParameter) { | 651 } else if (parameter == "outputEncoding") { |
704 if (!optional) | 652 if (!optional) |
705 url->insert(start, kOutputEncodingType); | 653 url->insert(start, kOutputEncodingType); |
706 } else if ((parameter == kStartIndexParameter) || | 654 } else if ((parameter == "startIndex") || |
707 (parameter == kStartPageParameter)) { | 655 (parameter == "startPage")) { |
Peter Kasting
2015/05/18 18:27:30
Nit: Collapse onto one line
sdefresne
2015/05/19 09:12:29
Done.
| |
708 // We don't support these. | 656 // We don't support these. |
709 if (!optional) | 657 if (!optional) |
710 url->insert(start, "1"); | 658 url->insert(start, "1"); |
711 } else if (!prepopulated_) { | 659 } else if (!prepopulated_) { |
712 // If it's a prepopulated URL, we know that it's safe to remove unknown | 660 // If it's a prepopulated URL, we know that it's safe to remove unknown |
713 // parameters, so just ignore this and return true below. Otherwise it could | 661 // parameters, so just ignore this and return true below. Otherwise it could |
714 // be some garbage but can also be a javascript block. Put it back. | 662 // be some garbage but can also be a javascript block. Put it back. |
715 url->insert(start, full_parameter); | 663 url->insert(start, full_parameter); |
716 return false; | 664 return false; |
717 } | 665 } |
(...skipping 95 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
813 if (has_only_one_search_term) | 761 if (has_only_one_search_term) |
814 ParseHostAndSearchTermKey(search_terms_data); | 762 ParseHostAndSearchTermKey(search_terms_data); |
815 } | 763 } |
816 } | 764 } |
817 } | 765 } |
818 | 766 |
819 void TemplateURLRef::ParseHostAndSearchTermKey( | 767 void TemplateURLRef::ParseHostAndSearchTermKey( |
820 const SearchTermsData& search_terms_data) const { | 768 const SearchTermsData& search_terms_data) const { |
821 std::string url_string(GetURL()); | 769 std::string url_string(GetURL()); |
822 ReplaceSubstringsAfterOffset(&url_string, 0, | 770 ReplaceSubstringsAfterOffset(&url_string, 0, |
823 kGoogleBaseURLParameterFull, | 771 "{google:baseURL}", |
Peter Kasting
2015/05/18 18:27:30
Nit: Collapse onto previous line
sdefresne
2015/05/19 09:12:29
Done.
| |
824 search_terms_data.GoogleBaseURLValue()); | 772 search_terms_data.GoogleBaseURLValue()); |
825 ReplaceSubstringsAfterOffset(&url_string, 0, | 773 ReplaceSubstringsAfterOffset(&url_string, 0, |
826 kGoogleBaseSuggestURLParameterFull, | 774 "{google:baseSuggestURL}", |
Peter Kasting
2015/05/18 18:27:30
Nit: Collapse onto previous line
sdefresne
2015/05/19 09:12:29
Done.
| |
827 search_terms_data.GoogleBaseSuggestURLValue()); | 775 search_terms_data.GoogleBaseSuggestURLValue()); |
828 | 776 |
829 search_term_key_.clear(); | 777 search_term_key_.clear(); |
830 search_term_position_in_path_ = std::string::npos; | 778 search_term_position_in_path_ = std::string::npos; |
831 host_.clear(); | 779 host_.clear(); |
832 path_.clear(); | 780 path_.clear(); |
833 search_term_key_location_ = url::Parsed::QUERY; | 781 search_term_key_location_ = url::Parsed::QUERY; |
834 | 782 |
835 GURL url(url_string); | 783 GURL url(url_string); |
836 if (!url.is_valid()) | 784 if (!url.is_valid()) |
(...skipping 400 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
1237 suggestions_url_ref_(this, | 1185 suggestions_url_ref_(this, |
1238 TemplateURLRef::SUGGEST), | 1186 TemplateURLRef::SUGGEST), |
1239 instant_url_ref_(this, | 1187 instant_url_ref_(this, |
1240 TemplateURLRef::INSTANT), | 1188 TemplateURLRef::INSTANT), |
1241 image_url_ref_(this, TemplateURLRef::IMAGE), | 1189 image_url_ref_(this, TemplateURLRef::IMAGE), |
1242 new_tab_url_ref_(this, TemplateURLRef::NEW_TAB), | 1190 new_tab_url_ref_(this, TemplateURLRef::NEW_TAB), |
1243 contextual_search_url_ref_(this, TemplateURLRef::CONTEXTUAL_SEARCH) { | 1191 contextual_search_url_ref_(this, TemplateURLRef::CONTEXTUAL_SEARCH) { |
1244 SetPrepopulateId(data_.prepopulate_id); | 1192 SetPrepopulateId(data_.prepopulate_id); |
1245 | 1193 |
1246 if (data_.search_terms_replacement_key == | 1194 if (data_.search_terms_replacement_key == |
1247 kGoogleInstantExtendedEnabledKeyFull) { | 1195 "{google:instantExtendedEnabledKey}") { |
1248 data_.search_terms_replacement_key = google_util::kInstantExtendedAPIParam; | 1196 data_.search_terms_replacement_key = google_util::kInstantExtendedAPIParam; |
1249 } | 1197 } |
1250 } | 1198 } |
1251 | 1199 |
1252 TemplateURL::~TemplateURL() { | 1200 TemplateURL::~TemplateURL() { |
1253 } | 1201 } |
1254 | 1202 |
1255 // static | 1203 // static |
1256 base::string16 TemplateURL::GenerateKeyword(const GURL& url) { | 1204 base::string16 TemplateURL::GenerateKeyword(const GURL& url) { |
1257 DCHECK(url.is_valid()); | 1205 DCHECK(url.is_valid()); |
(...skipping 295 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
1553 // patterns. This means that given patterns | 1501 // patterns. This means that given patterns |
1554 // [ "http://foo/#q={searchTerms}", "http://foo/?q={searchTerms}" ], | 1502 // [ "http://foo/#q={searchTerms}", "http://foo/?q={searchTerms}" ], |
1555 // calling ExtractSearchTermsFromURL() on "http://foo/?q=bar#q=' would | 1503 // calling ExtractSearchTermsFromURL() on "http://foo/?q=bar#q=' would |
1556 // return false. This is important for at least Google, where such URLs | 1504 // return false. This is important for at least Google, where such URLs |
1557 // are invalid. | 1505 // are invalid. |
1558 return !search_terms->empty(); | 1506 return !search_terms->empty(); |
1559 } | 1507 } |
1560 } | 1508 } |
1561 return false; | 1509 return false; |
1562 } | 1510 } |
OLD | NEW |