mirror of
https://github.com/python/cpython.git
synced 2025-08-03 08:34:29 +00:00
Merged revisions 79804 via svnmerge from
svn+ssh://pythondev@svn.python.org/python/trunk ........ r79804 | mark.dickinson | 2010-04-05 19:07:51 +0100 (Mon, 05 Apr 2010) | 5 lines Use a more robust infinity check in _Py_HashDouble. This fixes a test_decimal failure on FreeBSD 8.0. (modf apparently doesn't follow C99 Annex F on FreeBSD.) ........
This commit is contained in:
parent
19192dd402
commit
5daab45158
2 changed files with 12 additions and 3 deletions
|
@ -656,15 +656,15 @@ _Py_HashDouble(double v)
|
|||
* of mapping keys will turn out weird.
|
||||
*/
|
||||
|
||||
if (Py_IS_INFINITY(v))
|
||||
/* can't convert to long int -- arbitrary */
|
||||
v = v < 0 ? -271828.0 : 314159.0;
|
||||
fractpart = modf(v, &intpart);
|
||||
if (fractpart == 0.0) {
|
||||
/* This must return the same hash as an equal int or long. */
|
||||
if (intpart > LONG_MAX/2 || -intpart > LONG_MAX/2) {
|
||||
/* Convert to long and use its hash. */
|
||||
PyObject *plong; /* converted to Python long */
|
||||
if (Py_IS_INFINITY(intpart))
|
||||
/* can't convert to long int -- arbitrary */
|
||||
v = v < 0 ? -271828.0 : 314159.0;
|
||||
plong = PyLong_FromDouble(v);
|
||||
if (plong == NULL)
|
||||
return -1;
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue