mirror of
https://github.com/msgpack/msgpack-python.git
synced 2025-10-22 21:33:17 +00:00
fallback unpacker: precise => strict
This commit is contained in:
parent
cbdf3c339a
commit
1032ef9bf2
1 changed files with 13 additions and 12 deletions
|
@ -69,6 +69,13 @@ TYPE_EXT = 5
|
||||||
DEFAULT_RECURSE_LIMIT = 511
|
DEFAULT_RECURSE_LIMIT = 511
|
||||||
|
|
||||||
|
|
||||||
|
def _check_type_strict(obj, t, type=type, tuple=tuple):
|
||||||
|
if type(t) is tuple:
|
||||||
|
return type(obj) in t
|
||||||
|
else:
|
||||||
|
return type(obj) is t
|
||||||
|
|
||||||
|
|
||||||
def unpack(stream, **kwargs):
|
def unpack(stream, **kwargs):
|
||||||
"""
|
"""
|
||||||
Unpack an object from `stream`.
|
Unpack an object from `stream`.
|
||||||
|
@ -601,7 +608,7 @@ class Packer(object):
|
||||||
Convert unicode to bytes with this encoding. (default: 'utf-8')
|
Convert unicode to bytes with this encoding. (default: 'utf-8')
|
||||||
:param str unicode_errors:
|
:param str unicode_errors:
|
||||||
Error handler for encoding unicode. (default: 'strict')
|
Error handler for encoding unicode. (default: 'strict')
|
||||||
:param bool precise_mode:
|
:param bool strict_types:
|
||||||
If set to true, types will be checked to be exact. Derived classes
|
If set to true, types will be checked to be exact. Derived classes
|
||||||
from serializeable types will not be serialized and will be
|
from serializeable types will not be serialized and will be
|
||||||
treated as unsupported type and forwarded to default.
|
treated as unsupported type and forwarded to default.
|
||||||
|
@ -618,9 +625,9 @@ class Packer(object):
|
||||||
It also enable str8 type for unicode.
|
It also enable str8 type for unicode.
|
||||||
"""
|
"""
|
||||||
def __init__(self, default=None, encoding='utf-8', unicode_errors='strict',
|
def __init__(self, default=None, encoding='utf-8', unicode_errors='strict',
|
||||||
precise_mode=False, use_single_float=False, autoreset=True,
|
strict_types=False, use_single_float=False, autoreset=True,
|
||||||
use_bin_type=False):
|
use_bin_type=False):
|
||||||
self._precise_mode = precise_mode
|
self._strict_types = strict_types
|
||||||
self._use_float = use_single_float
|
self._use_float = use_single_float
|
||||||
self._autoreset = autoreset
|
self._autoreset = autoreset
|
||||||
self._use_bin_type = use_bin_type
|
self._use_bin_type = use_bin_type
|
||||||
|
@ -632,17 +639,11 @@ class Packer(object):
|
||||||
raise TypeError("default must be callable")
|
raise TypeError("default must be callable")
|
||||||
self._default = default
|
self._default = default
|
||||||
|
|
||||||
def _check_precise(obj, t, type=type, tuple=tuple):
|
|
||||||
if type(t) is tuple:
|
|
||||||
return type(obj) in t
|
|
||||||
else:
|
|
||||||
return type(obj) is t
|
|
||||||
|
|
||||||
def _pack(self, obj, nest_limit=DEFAULT_RECURSE_LIMIT,
|
def _pack(self, obj, nest_limit=DEFAULT_RECURSE_LIMIT,
|
||||||
check=isinstance, check_precise=_check_precise):
|
check=isinstance, check_type_strict=_check_type_strict):
|
||||||
default_used = False
|
default_used = False
|
||||||
if self._precise_mode:
|
if self._strict_types:
|
||||||
check = check_precise
|
check = check_type_strict
|
||||||
list_types = list
|
list_types = list
|
||||||
else:
|
else:
|
||||||
list_types = (list, tuple)
|
list_types = (list, tuple)
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue