bpo-31373: remove overly strict float range checks (#3486)

This undoes a853a8ba78 except for the pytime.c
parts. We want to continue to allow IEEE 754 doubles larger than FLT_MAX to be
rounded into finite floats. Tests were added to very this behavior.
This commit is contained in:
Benjamin Peterson 2017-09-10 23:50:46 -07:00 committed by GitHub
parent 252033d50e
commit 2bb69a5b4e
4 changed files with 14 additions and 6 deletions

View file

@ -2233,13 +2233,13 @@ _PyFloat_Pack4(double x, unsigned char *p, int le)
}
else {
float y = (float)x;
int i, incr = 1;
if (fabs(x) > FLT_MAX && !Py_IS_INFINITY(x))
if (Py_IS_INFINITY(y) && !Py_IS_INFINITY(x))
goto Overflow;
unsigned char s[sizeof(float)];
float y = (float)x;
memcpy(s, &y, sizeof(float));
if ((float_format == ieee_little_endian_format && !le)