Message359683
It's a bug in _PyTime_FromDouble() which fails to detect the integer overflow when casting a C double to a C _PyTime_T (int64_t): bug in _Py_InIntegralTypeRange(_PyTime_t, d) where d is a C double.
On my Fedora 31, double is a 64-bit IEEE 754 float, _PyTime_t is int64_t (64-bit signed integer).
_PyTime_t maximum is 9223372036854775807. But casted as C double, it becomes 9223372036854775808:
>>> int(float(9223372036854775807))
9223372036854775808 |
|
| Date |
User |
Action |
Args |
| 2020-01-09 14:52:07 | vstinner | set | recipients:
+ vstinner, benjamin.peterson, graingert |
| 2020-01-09 14:52:07 | vstinner | set | messageid: <1578581527.5.0.932903594264.issue39277@roundup.psfhosted.org> |
| 2020-01-09 14:52:07 | vstinner | link | issue39277 messages |
| 2020-01-09 14:52:07 | vstinner | create | |
|