Skip to content

Commit

Permalink
Update __init__.py - use of None in mapper parameter
Browse files Browse the repository at this point in the history
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.
  • Loading branch information
pickworthi authored Oct 1, 2024
1 parent fb88ea7 commit b50cacd
Showing 1 changed file with 2 additions and 0 deletions.
2 changes: 2 additions & 0 deletions vdf/__init__.py
Original file line number Diff line number Diff line change
Expand Up @@ -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'):
Expand Down Expand Up @@ -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))

Expand Down

0 comments on commit b50cacd

Please sign in to comment.