diff options
| author | Mark Dickinson <dickinsm@gmail.com> | 2010-12-04 12:30:41 (GMT) |
|---|---|---|
| committer | Mark Dickinson <dickinsm@gmail.com> | 2010-12-04 12:30:41 (GMT) |
| commit | ecf8ec67ce26dc7612742019cea5c8b190048993 (patch) | |
| tree | 76c35e05c64f7c40e40d5f2dd161c28aca0f0656 /Objects/floatobject.c | |
| parent | c1d0ed29077f1f1f4b2e6e91880c030c28fe52b8 (diff) | |
| download | cpython-ecf8ec67ce26dc7612742019cea5c8b190048993.zip cpython-ecf8ec67ce26dc7612742019cea5c8b190048993.tar.gz cpython-ecf8ec67ce26dc7612742019cea5c8b190048993.tar.bz2 | |
Merged revisions 87032 via svnmerge from
svn+ssh://pythondev@svn.python.org/python/branches/py3k
........
r87032 | mark.dickinson | 2010-12-04 12:25:30 +0000 (Sat, 04 Dec 2010) | 3 lines
Issue #10596: Fix float.__mod__ to have the same behaviour as
float.__divmod__ with respect to signed zeros.
........
Diffstat (limited to 'Objects/floatobject.c')
| -rw-r--r-- | Objects/floatobject.c | 18 |
1 files changed, 14 insertions, 4 deletions
diff --git a/Objects/floatobject.c b/Objects/floatobject.c index 8217ee6..77b1005 100644 --- a/Objects/floatobject.c +++ b/Objects/floatobject.c @@ -716,10 +716,20 @@ float_rem(PyObject *v, PyObject *w) #endif PyFPE_START_PROTECT("modulo", return 0) mod = fmod(vx, wx); - /* note: checking mod*wx < 0 is incorrect -- underflows to - 0 if wx < sqrt(smallest nonzero double) */ - if (mod && ((wx < 0) != (mod < 0))) { - mod += wx; + if (mod) { + /* ensure the remainder has the same sign as the denominator */ + if ((wx < 0) != (mod < 0)) { + mod += wx; + } + } + else { + /* the remainder is zero, and in the presence of signed zeroes + fmod returns different results across platforms; ensure + it has the same sign as the denominator; we'd like to do + "mod = wx * 0.0", but that may get optimized away */ + mod *= mod; /* hide "mod = +0" from optimizer */ + if (wx < 0.0) + mod = -mod; } PyFPE_END_PROTECT(mod) return PyFloat_FromDouble(mod); |
