mirror of
https://github.com/Tautulli/Tautulli.git
synced 2025-01-06 11:09:57 -08:00
1798594569
* Bump simplejson from 3.18.3 to 3.19.1 Bumps [simplejson](https://github.com/simplejson/simplejson) from 3.18.3 to 3.19.1. - [Release notes](https://github.com/simplejson/simplejson/releases) - [Changelog](https://github.com/simplejson/simplejson/blob/master/CHANGES.txt) - [Commits](https://github.com/simplejson/simplejson/compare/v3.18.3...v3.19.1) --- updated-dependencies: - dependency-name: simplejson dependency-type: direct:production update-type: version-update:semver-minor ... Signed-off-by: dependabot[bot] <support@github.com> * Update simplejson==3.19.1 --------- Signed-off-by: dependabot[bot] <support@github.com> Co-authored-by: dependabot[bot] <49699333+dependabot[bot]@users.noreply.github.com> Co-authored-by: JonnyWong16 <9099342+JonnyWong16@users.noreply.github.com> [skip ci]
86 lines
3.0 KiB
Python
86 lines
3.0 KiB
Python
"""JSON token scanner
|
|
"""
|
|
import re
|
|
from .errors import JSONDecodeError
|
|
def _import_c_make_scanner():
|
|
try:
|
|
from ._speedups import make_scanner
|
|
return make_scanner
|
|
except ImportError:
|
|
return None
|
|
c_make_scanner = _import_c_make_scanner()
|
|
|
|
__all__ = ['make_scanner', 'JSONDecodeError']
|
|
|
|
NUMBER_RE = re.compile(
|
|
r'(-?(?:0|[1-9]\d*))(\.\d+)?([eE][-+]?\d+)?',
|
|
(re.VERBOSE | re.MULTILINE | re.DOTALL))
|
|
|
|
|
|
def py_make_scanner(context):
|
|
parse_object = context.parse_object
|
|
parse_array = context.parse_array
|
|
parse_string = context.parse_string
|
|
match_number = NUMBER_RE.match
|
|
encoding = context.encoding
|
|
strict = context.strict
|
|
parse_float = context.parse_float
|
|
parse_int = context.parse_int
|
|
parse_constant = context.parse_constant
|
|
object_hook = context.object_hook
|
|
object_pairs_hook = context.object_pairs_hook
|
|
memo = context.memo
|
|
|
|
def _scan_once(string, idx):
|
|
errmsg = 'Expecting value'
|
|
try:
|
|
nextchar = string[idx]
|
|
except IndexError:
|
|
raise JSONDecodeError(errmsg, string, idx)
|
|
|
|
if nextchar == '"':
|
|
return parse_string(string, idx + 1, encoding, strict)
|
|
elif nextchar == '{':
|
|
return parse_object((string, idx + 1), encoding, strict,
|
|
_scan_once, object_hook, object_pairs_hook, memo)
|
|
elif nextchar == '[':
|
|
return parse_array((string, idx + 1), _scan_once)
|
|
elif nextchar == 'n' and string[idx:idx + 4] == 'null':
|
|
return None, idx + 4
|
|
elif nextchar == 't' and string[idx:idx + 4] == 'true':
|
|
return True, idx + 4
|
|
elif nextchar == 'f' and string[idx:idx + 5] == 'false':
|
|
return False, idx + 5
|
|
|
|
m = match_number(string, idx)
|
|
if m is not None:
|
|
integer, frac, exp = m.groups()
|
|
if frac or exp:
|
|
res = parse_float(integer + (frac or '') + (exp or ''))
|
|
else:
|
|
res = parse_int(integer)
|
|
return res, m.end()
|
|
elif parse_constant and nextchar == 'N' and string[idx:idx + 3] == 'NaN':
|
|
return parse_constant('NaN'), idx + 3
|
|
elif parse_constant and nextchar == 'I' and string[idx:idx + 8] == 'Infinity':
|
|
return parse_constant('Infinity'), idx + 8
|
|
elif parse_constant and nextchar == '-' and string[idx:idx + 9] == '-Infinity':
|
|
return parse_constant('-Infinity'), idx + 9
|
|
else:
|
|
raise JSONDecodeError(errmsg, string, idx)
|
|
|
|
def scan_once(string, idx):
|
|
if idx < 0:
|
|
# Ensure the same behavior as the C speedup, otherwise
|
|
# this would work for *some* negative string indices due
|
|
# to the behavior of __getitem__ for strings. #98
|
|
raise JSONDecodeError('Expecting value', string, idx)
|
|
try:
|
|
return _scan_once(string, idx)
|
|
finally:
|
|
memo.clear()
|
|
|
|
return scan_once
|
|
|
|
make_scanner = c_make_scanner or py_make_scanner
|