From 0db541f524e1774865efebcbe5653e9ad76ea2e8 Mon Sep 17 00:00:00 2001 From: Unit 193 Date: Mon, 14 Oct 2024 03:02:05 -0400 Subject: New upstream version 1.27.6. --- gallery_dl/text.py | 45 +++++++++++++++++++++++++++++++++++++++++---- 1 file changed, 41 insertions(+), 4 deletions(-) (limited to 'gallery_dl/text.py') diff --git a/gallery_dl/text.py b/gallery_dl/text.py index 8517cdf..5fd5a40 100644 --- a/gallery_dl/text.py +++ b/gallery_dl/text.py @@ -238,12 +238,49 @@ def parse_float(value, default=0.0): def parse_query(qs): - """Parse a query string into key-value pairs""" + """Parse a query string into name-value pairs + + Ignore values whose name has been seen before + """ + if not qs: + return {} + + result = {} + try: + for name_value in qs.split("&"): + name, eq, value = name_value.partition("=") + if eq: + name = unquote(name.replace("+", " ")) + if name not in result: + result[name] = unquote(value.replace("+", " ")) + except Exception: + pass + return result + + +def parse_query_list(qs): + """Parse a query string into name-value pairs + + Combine values of duplicate names into lists + """ + if not qs: + return {} + result = {} try: - for key, value in urllib.parse.parse_qsl(qs): - if key not in result: - result[key] = value + for name_value in qs.split("&"): + name, eq, value = name_value.partition("=") + if eq: + name = unquote(name.replace("+", " ")) + value = unquote(value.replace("+", " ")) + if name in result: + rvalue = result[name] + if isinstance(rvalue, list): + rvalue.append(value) + else: + result[name] = [rvalue, value] + else: + result[name] = value except Exception: pass return result -- cgit v1.2.3