From be1f7220238022f8b29fe747f0b643f280bfdb6e Mon Sep 17 00:00:00 2001 From: pickworthi <82284576+pickworthi@users.noreply.github.com> Date: Thu, 3 Oct 2024 20:08:10 +0100 Subject: [PATCH] Update __init__.py - use of None in mapper parameter (#4) When a caller passes a value of None for the mapper parameter, a TypeException is raised. Usage of None by a caller to signify no value given is quite common, so this makes the calls a bit more robust. --- vdf/__init__.py | 2 ++ 1 file changed, 2 insertions(+) diff --git a/vdf/__init__.py b/vdf/__init__.py index f80fd13..e569df1 100644 --- a/vdf/__init__.py +++ b/vdf/__init__.py @@ -60,6 +60,7 @@ def parse(fp, mapper=dict, merge_duplicate_keys=True, escaped=True): same key into one instead of overwriting. You can se this to ``False`` if you are using ``VDFDict`` and need to preserve the duplicates. """ + mapper = dict if mapper is None else mapper if not issubclass(mapper, Mapping): raise TypeError("Expected mapper to be subclass of dict, got %s" % type(mapper)) if not hasattr(fp, 'readline'): @@ -298,6 +299,7 @@ def binary_loads(b, mapper=dict, merge_duplicate_keys=True, alt_format=False, ke table. Newer `appinfo.vdf` format stores this table the end of the file, and it is needed to deserialize the binary VDF objects in that file. """ + mapper = dict if mapper is None else mapper if not isinstance(b, bytes): raise TypeError("Expected s to be bytes, got %s" % type(b))