mirror of https://github.com/python/cpython
#17368: Fix an off-by-one error in the Python JSON decoder that caused a failure while decoding empty object literals when object_pairs_hook was specified.
This commit is contained in:
parent
981c3bde8d
commit
fda7a8ce78
|
@ -163,7 +163,7 @@ def JSONObject(s_and_end, encoding, strict, scan_once, object_hook,
|
|||
if nextchar == '}':
|
||||
if object_pairs_hook is not None:
|
||||
result = object_pairs_hook(pairs)
|
||||
return result, end
|
||||
return result, end + 1
|
||||
pairs = {}
|
||||
if object_hook is not None:
|
||||
pairs = object_hook(pairs)
|
||||
|
|
|
@ -40,10 +40,15 @@ class TestDecode(object):
|
|||
self.assertEqual(od, OrderedDict(p))
|
||||
self.assertEqual(type(od), OrderedDict)
|
||||
# the object_pairs_hook takes priority over the object_hook
|
||||
self.assertEqual(self.loads(s,
|
||||
object_pairs_hook=OrderedDict,
|
||||
self.assertEqual(self.loads(s, object_pairs_hook=OrderedDict,
|
||||
object_hook=lambda x: None),
|
||||
OrderedDict(p))
|
||||
# check that empty objects literals work (see #17368)
|
||||
self.assertEqual(self.loads('{}', object_pairs_hook=OrderedDict),
|
||||
OrderedDict())
|
||||
self.assertEqual(self.loads('{"empty": {}}',
|
||||
object_pairs_hook=OrderedDict),
|
||||
OrderedDict([('empty', OrderedDict())]))
|
||||
|
||||
def test_extra_data(self):
|
||||
s = '[1, 2, 3]5'
|
||||
|
|
|
@ -214,6 +214,10 @@ Core and Builtins
|
|||
Library
|
||||
-------
|
||||
|
||||
- Issue #17368: Fix an off-by-one error in the Python JSON decoder that caused
|
||||
a failure while decoding empty object literals when object_pairs_hook was
|
||||
specified.
|
||||
|
||||
- Issue #17278: Fix a crash in heapq.heappush() and heapq.heappop() when
|
||||
the list is being resized concurrently.
|
||||
|
||||
|
|
Loading…
Reference in New Issue