Chromium Code Reviews| Index: chrome/common/instant_types.cc |
| diff --git a/chrome/common/instant_types.cc b/chrome/common/instant_types.cc |
| index 5d199ae46de6f95e173c6aa4142a162161cd528a..938116f2523093f50aeef6f1052967144b159801 100644 |
| --- a/chrome/common/instant_types.cc |
| +++ b/chrome/common/instant_types.cc |
| @@ -4,6 +4,19 @@ |
| #include "chrome/common/instant_types.h" |
| +#include "base/strings/utf_string_conversions.h" |
| +#include "net/base/escape.h" |
| + |
| +namespace { |
| + |
| +std::string GetComponent(const std::string& url, |
| + const url::Component component) { |
| + return (component.len > 0) ? url.substr(component.begin, component.len) : |
| + std::string(); |
| +} |
| + |
| +} // namespace |
| + |
| InstantSuggestion::InstantSuggestion() { |
| } |
| @@ -68,3 +81,50 @@ bool ThemeBackgroundInfo::operator==(const ThemeBackgroundInfo& rhs) const { |
| has_attribution == rhs.has_attribution && |
| logo_alternate == rhs.logo_alternate; |
| } |
| + |
| +const char kSearchQueryKey[] = "q"; |
| +const char kOriginalQueryKey[] = "oq"; |
| +const char kRLZParameterKey[] = "rlz"; |
| +const char kInputEncodingKey[] = "ie"; |
| +const char kAssistedQueryStatsKey[] = "aqs"; |
| + |
| +EmbeddedSearchRequestParams::EmbeddedSearchRequestParams() { |
| +} |
| + |
| +EmbeddedSearchRequestParams::EmbeddedSearchRequestParams(const GURL& url) { |
|
Mark P
2014/11/17 19:15:59
Can you add a simple test for this that show it ex
kmadhusu
2014/11/17 22:52:05
Done.
|
| + const std::string& url_params(url.query()); |
| + url::Component query, key, value; |
| + query.len = static_cast<int>(url_params.size()); |
| + |
| + net::UnescapeRule::Type unescape_rules = |
|
Mark P
2014/11/17 19:15:59
nit: might as well be const
kmadhusu
2014/11/17 22:52:05
Done.
|
| + net::UnescapeRule::CONTROL_CHARS | net::UnescapeRule::SPACES | |
| + net::UnescapeRule::URL_SPECIAL_CHARS | net::UnescapeRule::NORMAL | |
| + net::UnescapeRule::REPLACE_PLUS_WITH_SPACE; |
| + |
| + while (url::ExtractQueryKeyValue(url_params.c_str(), &query, &key, &value)) { |
| + if (!key.is_nonempty()) |
| + continue; |
| + |
| + std::string key_param(GetComponent(url_params, key)); |
| + std::string value_param(GetComponent(url_params, value)); |
| + if (key_param == kSearchQueryKey) { |
| + search_query = base::UTF8ToUTF16(net::UnescapeURLComponent( |
| + value_param, unescape_rules)); |
| + } else if (key_param == kOriginalQueryKey) { |
| + original_query = base::UTF8ToUTF16(net::UnescapeURLComponent( |
| + value_param, unescape_rules)); |
| + } else if (key_param == kRLZParameterKey) { |
| + rlz_parameter_value =net::UnescapeAndDecodeUTF8URLComponent( |
|
Mark P
2014/11/17 19:15:59
nit: "=n" -> "= n"
kmadhusu
2014/11/17 22:52:05
Done.
|
| + value_param, net::UnescapeRule::NORMAL); |
| + } else if (key_param == kInputEncodingKey) { |
| + input_encoding = net::UnescapeAndDecodeUTF8URLComponent( |
| + value_param, net::UnescapeRule::NORMAL); |
| + } else if (key_param == kAssistedQueryStatsKey) { |
| + assisted_query_stats = net::UnescapeAndDecodeUTF8URLComponent( |
| + value_param, net::UnescapeRule::NORMAL); |
| + } |
| + } |
| +} |
| + |
| +EmbeddedSearchRequestParams::~EmbeddedSearchRequestParams() { |
| +} |