[Python-checkins] cpython (3.3): Ensure that plistlib doesn't corrupt deeply nested datastructures
ronald.oussoren
python-checkins at python.org
Tue Apr 23 13:50:55 CEST 2013
http://hg.python.org/cpython/rev/6a8cb4875ac6
changeset: 83506:6a8cb4875ac6
branch: 3.3
parent: 83503:a4d294539f2e
user: Ronald Oussoren <ronaldoussoren at mac.com>
date: Tue Apr 23 13:47:22 2013 +0200
summary:
Ensure that plistlib doesn't corrupt deeply nested datastructures
Without this changeset plistlib would write empty tags for plistlib.Data
objects in deeply nested datastructures.
Fixes #17353
files:
Lib/plistlib.py | 4 ++--
Lib/test/test_plistlib.py | 12 ++++++++++++
Misc/NEWS | 2 ++
3 files changed, 16 insertions(+), 2 deletions(-)
diff --git a/Lib/plistlib.py b/Lib/plistlib.py
--- a/Lib/plistlib.py
+++ b/Lib/plistlib.py
@@ -228,8 +228,8 @@
def writeData(self, data):
self.beginElement("data")
self.indentLevel -= 1
- maxlinelength = 76 - len(self.indent.replace(b"\t", b" " * 8) *
- self.indentLevel)
+ maxlinelength = max(16, 76 - len(self.indent.replace(b"\t", b" " * 8) *
+ self.indentLevel))
for line in data.asBase64(maxlinelength).split(b"\n"):
if line:
self.writeln(line)
diff --git a/Lib/test/test_plistlib.py b/Lib/test/test_plistlib.py
--- a/Lib/test/test_plistlib.py
+++ b/Lib/test/test_plistlib.py
@@ -141,6 +141,18 @@
data2 = plistlib.writePlistToBytes(pl2)
self.assertEqual(data, data2)
+ def test_indentation_array(self):
+ data = [[[[[[[[{'test': plistlib.Data(b'aaaaaa')}]]]]]]]]
+ self.assertEqual(plistlib.readPlistFromBytes(plistlib.writePlistToBytes(data)), data)
+
+ def test_indentation_dict(self):
+ data = {'1': {'2': {'3': {'4': {'5': {'6': {'7': {'8': {'9': plistlib.Data(b'aaaaaa')}}}}}}}}}
+ self.assertEqual(plistlib.readPlistFromBytes(plistlib.writePlistToBytes(data)), data)
+
+ def test_indentation_dict_mix(self):
+ data = {'1': {'2': [{'3': [[[[[{'test': plistlib.Data(b'aaaaaa')}]]]]]}]}}
+ self.assertEqual(plistlib.readPlistFromBytes(plistlib.writePlistToBytes(data)), data)
+
def test_appleformatting(self):
pl = plistlib.readPlistFromBytes(TESTDATA)
data = plistlib.writePlistToBytes(pl)
diff --git a/Misc/NEWS b/Misc/NEWS
--- a/Misc/NEWS
+++ b/Misc/NEWS
@@ -36,6 +36,8 @@
Library
-------
+- Issue #17353: Plistlib emitted empty data tags with deeply nested datastructures
+
- Issue #11714: Use 'with' statements to assure a Semaphore releases a
condition variable. Original patch by Thomas Rachel.
--
Repository URL: http://hg.python.org/cpython
More information about the Python-checkins
mailing list