Skip to content

Commit 3fc7080

Browse files
bpo-41491: plistlib: accept hexadecimal integer values in xml plist files (GH-22764) (GH-22806)
(cherry picked from commit 3185267) Co-authored-by: Ronald Oussoren <[email protected]>
1 parent aa7b03b commit 3fc7080

File tree

3 files changed

+19
-1
lines changed

3 files changed

+19
-1
lines changed

Lib/plistlib.py

Lines changed: 5 additions & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -252,7 +252,11 @@ def end_false(self):
252252
self.add_object(False)
253253

254254
def end_integer(self):
255-
self.add_object(int(self.get_data()))
255+
raw = self.get_data()
256+
if raw.startswith('0x') or raw.startswith('0X'):
257+
self.add_object(int(raw, 16))
258+
else:
259+
self.add_object(int(raw))
256260

257261
def end_real(self):
258262
self.add_object(float(self.get_data()))

Lib/test/test_plistlib.py

Lines changed: 13 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -497,6 +497,19 @@ def test_invalidreal(self):
497497
self.assertRaises(ValueError, plistlib.loads,
498498
b"<plist><integer>not real</integer></plist>")
499499

500+
def test_integer_notations(self):
501+
pl = b"<plist><integer>456</integer></plist>"
502+
value = plistlib.loads(pl)
503+
self.assertEqual(value, 456)
504+
505+
pl = b"<plist><integer>0xa</integer></plist>"
506+
value = plistlib.loads(pl)
507+
self.assertEqual(value, 10)
508+
509+
pl = b"<plist><integer>0123</integer></plist>"
510+
value = plistlib.loads(pl)
511+
self.assertEqual(value, 123)
512+
500513
def test_xml_encodings(self):
501514
base = TESTDATA[plistlib.FMT_XML]
502515

Lines changed: 1 addition & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1 @@
1+
plistlib: fix parsing XML plists with hexadecimal integer values

0 commit comments

Comments
 (0)