summaryrefslogtreecommitdiffstats
path: root/Modules/timemodule.c
diff options
context:
space:
mode:
authorVictor Stinner <victor.stinner@gmail.com>2013-06-25 20:54:35 (GMT)
committerVictor Stinner <victor.stinner@gmail.com>2013-06-25 20:54:35 (GMT)
commit93037498d1f61f31e5b52d2f8d4aa437a26bc14e (patch)
treef538d8f9b5dbcba7473bb454c92206c5b9426884 /Modules/timemodule.c
parent5ac1b936ef00841e6c5452d1ef360ab539d31dc2 (diff)
downloadcpython-93037498d1f61f31e5b52d2f8d4aa437a26bc14e.zip
cpython-93037498d1f61f31e5b52d2f8d4aa437a26bc14e.tar.gz
cpython-93037498d1f61f31e5b52d2f8d4aa437a26bc14e.tar.bz2
Fix time.mktime() and datetime.datetime.timestamp() on AIX
On AIX, the C function mktime() alwaysd sets tm_wday, even on error. So tm_wday cannot be used as a sentinel to detect an error, we can only check if the result is (time_t)-1.
Diffstat (limited to 'Modules/timemodule.c')
-rw-r--r--Modules/timemodule.c11
1 files changed, 10 insertions, 1 deletions
diff --git a/Modules/timemodule.c b/Modules/timemodule.c
index 4b526d4..297467f 100644
--- a/Modules/timemodule.c
+++ b/Modules/timemodule.c
@@ -807,7 +807,16 @@ time_mktime(PyObject *self, PyObject *tup)
tt = mktime(&buf);
/* Return value of -1 does not necessarily mean an error, but tm_wday
* cannot remain set to -1 if mktime succeeded. */
- if (tt == (time_t)(-1) && buf.tm_wday == -1) {
+ if (tt == (time_t)(-1)
+#ifndef _AIX
+ /* Return value of -1 does not necessarily mean an error, but
+ * tm_wday cannot remain set to -1 if mktime succeeded. */
+ && buf.tm_wday == -1
+#else
+ /* on AIX, tm_wday is always sets, even on error */
+#endif
+ )
+ {
PyErr_SetString(PyExc_OverflowError,
"mktime argument out of range");
return NULL;