Index: third_party/WebKit/Source/core/dom/URLSearchParams.cpp |
diff --git a/third_party/WebKit/Source/core/dom/URLSearchParams.cpp b/third_party/WebKit/Source/core/dom/URLSearchParams.cpp |
new file mode 100644 |
index 0000000000000000000000000000000000000000..7ea93d49def417838b31cbd353630f0534372895 |
--- /dev/null |
+++ b/third_party/WebKit/Source/core/dom/URLSearchParams.cpp |
@@ -0,0 +1,148 @@ |
+// Copyright 2015 The Chromium Authors. All rights reserved. |
+// Use of this source code is governed by a BSD-style license that can be |
+// found in the LICENSE file. |
+ |
+#include "config.h" |
+#include "core/dom/URLSearchParams.h" |
+ |
+#include "platform/weborigin/KURL.h" |
+#include "wtf/text/StringBuilder.h" |
+#include "wtf/text/TextEncoding.h" |
+ |
+namespace blink { |
+ |
+URLSearchParams::URLSearchParams(const String& queryString) |
+{ |
+ if (!queryString.isEmpty()) |
+ setInput(queryString); |
+} |
+ |
+URLSearchParams::URLSearchParams(URLSearchParams* searchParams) |
+{ |
+ ASSERT(searchParams); |
+ m_params = searchParams->m_params; |
+} |
+ |
+URLSearchParams::~URLSearchParams() |
+{ |
+} |
+ |
+static String decodeString(String input) |
+{ |
+ return decodeURLEscapeSequences(input.replace('+', ' ')); |
+} |
+ |
+void URLSearchParams::setInput(const String& queryString) |
+{ |
+ m_params.clear(); |
philipj_slow
2015/11/16 12:15:46
Instead ASSERT that m_params is empty, until setIn
Mike West
2015/11/16 14:12:10
Sure. That won't happen until we integrate with UR
|
+ size_t start = 0; |
+ size_t queryStringLength = queryString.length(); |
+ while (start < queryStringLength) { |
+ size_t nameStart = start; |
+ size_t nameValueEnd = queryString.find('&', start); |
+ if (nameValueEnd == kNotFound) |
+ nameValueEnd = queryStringLength; |
+ if (nameValueEnd > start) { |
+ size_t endOfName = queryString.find('=', start); |
+ if (endOfName == kNotFound || endOfName > nameValueEnd) |
+ endOfName = nameValueEnd; |
+ String name = decodeString(queryString.substring(nameStart, endOfName - nameStart)); |
+ String value; |
+ if (endOfName != nameValueEnd) |
+ value = decodeString(queryString.substring(endOfName + 1, nameValueEnd - endOfName - 1)); |
+ if (value.isNull()) |
+ value = ""; |
+ m_params.append(std::make_pair(name, value)); |
+ } |
+ start = nameValueEnd + 1; |
+ } |
+} |
+static String encodeString(const String& input) |
+{ |
+ return encodeWithURLEscapeSequences(input).replace("%20", "+"); |
philipj_slow
2015/11/16 12:15:46
Does this match https://url.spec.whatwg.org/#conce
Mike West
2015/11/16 14:12:11
1. It matches Firefox for all the tests in this CL
philipj_slow
2015/11/16 14:17:33
Right, it's a good thing that we're using shared c
|
+} |
+ |
+String URLSearchParams::toString() const |
+{ |
+ StringBuilder result; |
+ for (size_t i = 0; i < m_params.size(); ++i) { |
+ if (i) |
+ result.append('&'); |
+ result.append(encodeString(m_params[i].first)); |
+ result.append('='); |
+ result.append(encodeString(m_params[i].second)); |
+ } |
+ return result.toString(); |
+} |
+ |
+void URLSearchParams::append(const String& name, const String& value) |
+{ |
+ m_params.append(std::make_pair(name, value)); |
+} |
+ |
+void URLSearchParams::deleteAllWithName(const String& name) |
+{ |
+ for (size_t i = 0; i < m_params.size();) { |
+ if (m_params[i].first == name) |
+ m_params.remove(i); |
+ else |
+ i++; |
+ } |
+} |
+ |
+String URLSearchParams::get(const String& name) const |
+{ |
+ for (const auto& param : m_params) { |
+ if (param.first == name) |
+ return param.second; |
+ } |
+ return String(); |
+} |
+ |
+Vector<String> URLSearchParams::getAll(const String& name) const |
+{ |
+ Vector<String> result; |
+ for (const auto& param : m_params) { |
+ if (param.first == name) |
+ result.append(param.second); |
+ } |
+ return result; |
+} |
+ |
+bool URLSearchParams::has(const String& name) const |
+{ |
+ for (const auto& param : m_params) { |
+ if (param.first == name) |
+ return true; |
+ } |
+ return false; |
+} |
+ |
+void URLSearchParams::set(const String& name, const String& value) |
+{ |
+ bool foundMatch = false; |
+ for (size_t i = 0; i < m_params.size();) { |
+ // If there are any name-value whose name is 'name', set |
+ // the value of the first such name-value pair to 'value' |
+ // and remove the others. |
+ if (m_params[i].first == name) { |
+ if (!foundMatch) { |
+ m_params[i++].second = value; |
+ foundMatch = true; |
+ } else { |
+ m_params.remove(i); |
+ } |
+ } else { |
+ i++; |
+ } |
+ } |
+ // Otherwise, append a new name-value pair to the list. |
+ if (!foundMatch) |
+ append(name, value); |
+} |
+ |
+DEFINE_TRACE(URLSearchParams) |
+{ |
+} |
+ |
+} // namespace blink |