Chromium Code Reviews| Index: net/cookies/cookie_util.cc |
| diff --git a/net/cookies/cookie_util.cc b/net/cookies/cookie_util.cc |
| index 3c80566e7a3e15c02e8815b2af196fc5f2e9444a..4ebe7996d735a45e03a72d8713c8446bbde08dee 100644 |
| --- a/net/cookies/cookie_util.cc |
| +++ b/net/cookies/cookie_util.cc |
| @@ -210,6 +210,57 @@ GURL CookieOriginToURL(const std::string& domain, bool is_https) { |
| return GURL(scheme + "://" + host); |
| } |
| +void ParseRequestCookieLine(const std::string& header_value, |
| + ParsedRequestCookies* parsed_cookies) { |
| + std::string::const_iterator i = header_value.begin(); |
| + while (i != header_value.end()) { |
| + // Here we are at the beginning of a cookie. |
| + |
| + // Eat whitespace. |
| + while (i != header_value.end() && *i == ' ') ++i; |
| + if (i == header_value.end()) return; |
| + |
| + // Find cookie name. |
| + std::string::const_iterator cookie_name_beginning = i; |
| + while (i != header_value.end() && *i != '=') ++i; |
| + base::StringPiece cookie_name(cookie_name_beginning, i); |
| + |
| + // Find cookie value. |
| + base::StringPiece cookie_value; |
| + if (i != header_value.end()) { // Cookies may have no value. |
| + ++i; // Skip '='. |
| + std::string::const_iterator cookie_value_beginning = i; |
| + if (*i == '"') { |
| + ++i; // Skip '"'. |
| + while (i != header_value.end() && *i != '"') ++i; |
| + if (i == header_value.end()) return; |
| + ++i; // Skip '"'. |
| + cookie_value = base::StringPiece(cookie_value_beginning, i); |
| + // i points to character after '"', potentially a ';' |
| + } else { |
| + while (i != header_value.end() && *i != ';') ++i; |
| + cookie_value = base::StringPiece(cookie_value_beginning, i); |
| + // i points to ';' or end of string. |
| + } |
| + } |
| + parsed_cookies->push_back(std::make_pair(cookie_name, cookie_value)); |
| + // Eat ';' |
|
erikwright (departed)
2014/07/10 14:26:24
add '.'.
Marc Treib
2014/07/10 15:40:39
Done.
|
| + if (i != header_value.end()) ++i; |
| + } |
| +} |
| + |
| +std::string SerializeRequestCookieLine( |
| + const ParsedRequestCookies& parsed_cookies) { |
| + std::string buffer; |
| + for (ParsedRequestCookies::const_iterator i = parsed_cookies.begin(); |
| + i != parsed_cookies.end(); ++i) { |
| + if (!buffer.empty()) |
| + buffer += "; "; |
| + buffer += i->first.as_string() + "=" + i->second.as_string(); |
|
erikwright (departed)
2014/07/10 14:26:24
How about:
buffer.append(i->first.begin(), i->fir
Marc Treib
2014/07/10 15:40:39
Done.
|
| + } |
| + return buffer; |
| +} |
| + |
| } // namespace cookie_utils |
| } // namespace net |