diff options
author | Serhiy Storchaka <storchaka@gmail.com> | 2014-05-23 13:13:33 (GMT) |
---|---|---|
committer | Serhiy Storchaka <storchaka@gmail.com> | 2014-05-23 13:13:33 (GMT) |
commit | 065266450ea5519a43bcc199e48d304f1e7038e8 (patch) | |
tree | b88904805e57b2a8ff92093e67c3684cebbf7ab2 /Lib/plistlib.py | |
parent | f01fffedd1e0ee29c4535e9b10e39c3654f159d7 (diff) | |
download | cpython-065266450ea5519a43bcc199e48d304f1e7038e8.zip cpython-065266450ea5519a43bcc199e48d304f1e7038e8.tar.gz cpython-065266450ea5519a43bcc199e48d304f1e7038e8.tar.bz2 |
Issue #21538: The plistlib module now supports loading of binary plist files
when reference or offset size is not a power of two.
Diffstat (limited to 'Lib/plistlib.py')
-rw-r--r-- | Lib/plistlib.py | 16 |
1 files changed, 10 insertions, 6 deletions
diff --git a/Lib/plistlib.py b/Lib/plistlib.py index dcb0f9c..8c148a8 100644 --- a/Lib/plistlib.py +++ b/Lib/plistlib.py @@ -619,10 +619,7 @@ class _BinaryPlistParser: offset_table_offset ) = struct.unpack('>6xBBQQQ', trailer) self._fp.seek(offset_table_offset) - offset_format = '>' + _BINARY_FORMAT[offset_size] * num_objects - self._ref_format = _BINARY_FORMAT[self._ref_size] - self._object_offsets = struct.unpack( - offset_format, self._fp.read(offset_size * num_objects)) + self._object_offsets = self._read_ints(num_objects, offset_size) return self._read_object(self._object_offsets[top_object]) except (OSError, IndexError, struct.error): @@ -638,9 +635,16 @@ class _BinaryPlistParser: return tokenL + def _read_ints(self, n, size): + data = self._fp.read(size * n) + if size in _BINARY_FORMAT: + return struct.unpack('>' + _BINARY_FORMAT[size] * n, data) + else: + return tuple(int.from_bytes(data[i: i + size], 'big') + for i in range(0, size * n, size)) + def _read_refs(self, n): - return struct.unpack( - '>' + self._ref_format * n, self._fp.read(n * self._ref_size)) + return self._read_ints(n, self._ref_size) def _read_object(self, offset): """ |