changeset: 100871:778ccbe3cf74 parent: 100869:633bb190fb76 parent: 100870:ba35b0404163 user: Serhiy Storchaka date: Fri Apr 08 15:00:33 2016 +0300 files: Misc/NEWS description: Issue #26709: Fixed Y2038 problem in loading binary PLists. diff -r 633bb190fb76 -r 778ccbe3cf74 Lib/plistlib.py --- a/Lib/plistlib.py Fri Apr 08 08:48:20 2016 +0300 +++ b/Lib/plistlib.py Fri Apr 08 15:00:33 2016 +0300 @@ -685,7 +685,7 @@ f = struct.unpack('>d', self._fp.read(8))[0] # timestamp 0 of binary plists corresponds to 1/1/2001 # (year of Mac OS X 10.0), instead of 1/1/1970. - return datetime.datetime.utcfromtimestamp(f + (31 * 365 + 8) * 86400) + return datetime.datetime(2001, 1, 1) + datetime.timedelta(seconds=f) elif tokenH == 0x40: # data s = self._get_size(tokenL) diff -r 633bb190fb76 -r 778ccbe3cf74 Lib/test/test_plistlib.py --- a/Lib/test/test_plistlib.py Fri Apr 08 08:48:20 2016 +0300 +++ b/Lib/test/test_plistlib.py Fri Apr 08 15:00:33 2016 +0300 @@ -428,6 +428,15 @@ b'\x00\x00\x00\x00\x00\x00\x00\x13') self.assertEqual(plistlib.loads(data), {'a': 'b'}) + def test_large_timestamp(self): + # Issue #26709: 32-bit timestamp out of range + for ts in -2**31-1, 2**31: + with self.subTest(ts=ts): + d = (datetime.datetime.utcfromtimestamp(0) + + datetime.timedelta(seconds=ts)) + data = plistlib.dumps(d, fmt=plistlib.FMT_BINARY) + self.assertEqual(plistlib.loads(data), d) + class TestPlistlibDeprecated(unittest.TestCase): def test_io_deprecated(self): diff -r 633bb190fb76 -r 778ccbe3cf74 Misc/NEWS --- a/Misc/NEWS Fri Apr 08 08:48:20 2016 +0300 +++ b/Misc/NEWS Fri Apr 08 15:00:33 2016 +0300 @@ -237,6 +237,8 @@ Library ------- +- Issue #26709: Fixed Y2038 problem in loading binary PLists. + - Issue #23735: Handle terminal resizing with Readline 6.3+ by installing our own SIGWINCH handler. Patch by Eric Price.