summaryrefslogtreecommitdiffstats
path: root/netwerk/base/nsURLHelper.h
diff options
context:
space:
mode:
Diffstat (limited to '')
-rw-r--r--netwerk/base/nsURLHelper.h15
1 files changed, 8 insertions, 7 deletions
diff --git a/netwerk/base/nsURLHelper.h b/netwerk/base/nsURLHelper.h
index f5ccc8bac6..36844e6e4b 100644
--- a/netwerk/base/nsURLHelper.h
+++ b/netwerk/base/nsURLHelper.h
@@ -257,19 +257,20 @@ class URLParams final {
* true otherwise
*/
template <typename ParamHandler>
- static bool Parse(const nsACString& aInput, ParamHandler aParamHandler) {
+ static bool Parse(const nsACString& aInput, bool aShouldDecode,
+ ParamHandler aParamHandler) {
const char* start = aInput.BeginReading();
const char* const end = aInput.EndReading();
while (start != end) {
- nsAutoString decodedName;
- nsAutoString decodedValue;
+ nsAutoString name;
+ nsAutoString value;
- if (!ParseNextInternal(start, end, &decodedName, &decodedValue)) {
+ if (!ParseNextInternal(start, end, aShouldDecode, &name, &value)) {
continue;
}
- if (!aParamHandler(std::move(decodedName), std::move(decodedValue))) {
+ if (!aParamHandler(std::move(name), std::move(value))) {
return false;
}
}
@@ -357,8 +358,8 @@ class URLParams final {
static void DecodeString(const nsACString& aInput, nsAString& aOutput);
static void ConvertString(const nsACString& aInput, nsAString& aOutput);
static bool ParseNextInternal(const char*& aStart, const char* aEnd,
- nsAString* aOutDecodedName,
- nsAString* aOutDecodedValue);
+ bool aShouldDecode, nsAString* aOutputName,
+ nsAString* aOutputValue);
struct Param {
nsString mKey;