summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorAlex Martelli <aleaxit@gmail.com>2006-08-23 20:42:02 +0000
committerAlex Martelli <aleaxit@gmail.com>2006-08-23 20:42:02 +0000
commit20362a820bd09617a33721191aa966416b03427c (patch)
treed23425e8b6a7c9d56c9fe9500bf887c5007a14ae
parent29bef0bbaae7f670e65c81173b8c1afc148aa248 (diff)
downloadcpython-git-20362a820bd09617a33721191aa966416b03427c.tar.gz
x**2 should about equal x*x (including for a float x such that the result is
inf) but didn't; added a test to test_float to verify that, and ignored the ERANGE value for errno in the pow operation to make the new test pass (with help from Marilyn Davis at the Google Python Sprint -- thanks!).
-rw-r--r--Lib/test/test_float.py15
-rw-r--r--Objects/floatobject.c6
2 files changed, 17 insertions, 4 deletions
diff --git a/Lib/test/test_float.py b/Lib/test/test_float.py
index fb47db8eb0..d616ad9543 100644
--- a/Lib/test/test_float.py
+++ b/Lib/test/test_float.py
@@ -99,12 +99,25 @@ class IEEEFormatTestCase(unittest.TestCase):
('<f', LE_FLOAT_NAN)]:
struct.unpack(fmt, data)
+# on an IEEE platform, "overflowing" operations produce infinity
+
+class IEEEOperationsTestCase(unittest.TestCase):
+ if float.__getformat__("double").startswith("IEEE"):
+ def test_double_infinity(self):
+ big = 4.8e159
+ pro = big*big
+ self.assertEquals(repr(pro), 'inf')
+ sqr = big**2
+ self.assertEquals(repr(sqr), 'inf')
+
def test_main():
test_support.run_unittest(
FormatFunctionsTestCase,
UnknownFormatTestCase,
- IEEEFormatTestCase)
+ IEEEFormatTestCase,
+ IEEEOperationsTestCase,
+ )
if __name__ == '__main__':
test_main()
diff --git a/Objects/floatobject.c b/Objects/floatobject.c
index fa09084669..5aeabd9d93 100644
--- a/Objects/floatobject.c
+++ b/Objects/floatobject.c
@@ -821,12 +821,12 @@ float_pow(PyObject *v, PyObject *w, PyObject *z)
ix = pow(iv, iw);
PyFPE_END_PROTECT(ix)
Py_ADJUST_ERANGE1(ix);
- if (errno != 0) {
+ /* we need to ignore ERANGE here and just return inf */
+ if (errno != 0 && errno != ERANGE) {
/* We don't expect any errno value other than ERANGE, but
* the range of libm bugs appears unbounded.
*/
- PyErr_SetFromErrno(errno == ERANGE ? PyExc_OverflowError :
- PyExc_ValueError);
+ PyErr_SetFromErrno(PyExc_ValueError);
return NULL;
}
return PyFloat_FromDouble(ix);