summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorBrett Cannon <bcannon@gmail.com>2009-09-22 00:32:59 (GMT)
committerBrett Cannon <bcannon@gmail.com>2009-09-22 00:32:59 (GMT)
commit7d12c559ce48941e2c028682184e351f9a07df5a (patch)
tree9640059ebd637b6676ee7e06d18e7da562da97a4
parentca767bd2db064e8e16ba45d48706dcb4aa6ec42b (diff)
downloadcpython-7d12c559ce48941e2c028682184e351f9a07df5a.zip
cpython-7d12c559ce48941e2c028682184e351f9a07df5a.tar.gz
cpython-7d12c559ce48941e2c028682184e351f9a07df5a.tar.bz2
Merged revisions 75011 via svnmerge from
svn+ssh://pythondev@svn.python.org/python/trunk ........ r75011 | brett.cannon | 2009-09-21 17:29:48 -0700 (Mon, 21 Sep 2009) | 10 lines When range checking was added to time.strftime() a check was placed on tm_isdst to make sure it fell within [-1, 1] just in case someone implementing strftime() in libc was stupid enough to assume this. Turns out, though, some OSs (e.g. zOS) are stupid enough to use values outside of this range for time structs created by the system itself. So instead of throwing a ValueError, tm_isdst is now normalized before being passed to strftime(). Fixes issue #6823. Thanks Robert Shapiro for diagnosing the problem and contributing an initial patch. ........
-rw-r--r--Lib/test/test_time.py5
-rw-r--r--Misc/ACKS1
-rw-r--r--Modules/timemodule.c12
3 files changed, 8 insertions, 10 deletions
diff --git a/Lib/test/test_time.py b/Lib/test/test_time.py
index 49a9d17..4ce90e9 100644
--- a/Lib/test/test_time.py
+++ b/Lib/test/test_time.py
@@ -87,11 +87,6 @@ class TimeTestCase(unittest.TestCase):
(1900, 1, 1, 0, 0, 0, 0, -1, -1))
self.assertRaises(ValueError, time.strftime, '',
(1900, 1, 1, 0, 0, 0, 0, 367, -1))
- # Check daylight savings flag [-1, 1]
- self.assertRaises(ValueError, time.strftime, '',
- (1900, 1, 1, 0, 0, 0, 0, 1, -2))
- self.assertRaises(ValueError, time.strftime, '',
- (1900, 1, 1, 0, 0, 0, 0, 1, 2))
def test_default_values_for_zero(self):
# Make sure that using all zeros uses the proper default values.
diff --git a/Misc/ACKS b/Misc/ACKS
index b2ada2b..d419b7e 100644
--- a/Misc/ACKS
+++ b/Misc/ACKS
@@ -674,6 +674,7 @@ Jerry Seutter
Denis Severson
Ian Seyer
Ha Shao
+Richard Shapiro
Bruce Sherwood
Pete Shinners
Michael Shiplett
diff --git a/Modules/timemodule.c b/Modules/timemodule.c
index d8db409..af0e1a7 100644
--- a/Modules/timemodule.c
+++ b/Modules/timemodule.c
@@ -512,11 +512,13 @@ time_strftime(PyObject *self, PyObject *args)
PyErr_SetString(PyExc_ValueError, "day of year out of range");
return NULL;
}
- if (buf.tm_isdst < -1 || buf.tm_isdst > 1) {
- PyErr_SetString(PyExc_ValueError,
- "daylight savings flag out of range");
- return NULL;
- }
+ /* Normalize tm_isdst just in case someone foolishly implements %Z
+ based on the assumption that tm_isdst falls within the range of
+ [-1, 1] */
+ if (buf.tm_isdst < -1)
+ buf.tm_isdst = -1;
+ else if (buf.tm_isdst > 1)
+ buf.tm_isdst = 1;
#ifdef HAVE_WCSFTIME
tmpfmt = PyBytes_FromStringAndSize(NULL,