diff options
author | Mark Dickinson <mdickinson@enthought.com> | 2012-08-24 20:06:30 +0100 |
---|---|---|
committer | Mark Dickinson <mdickinson@enthought.com> | 2012-08-24 20:06:30 +0100 |
commit | 088cec3ab70f83564d14a43f802e01d63a5fc905 (patch) | |
tree | d990cea66a4acde4600bc8fb5f9ab87a94aa19c2 | |
parent | 85ede8da006212c923acc049124eb6f5b1866f29 (diff) | |
download | cpython-git-088cec3ab70f83564d14a43f802e01d63a5fc905.tar.gz |
Issue #15544: Fix Decimal.__float__ to work with payload-carrying NaNs.
-rw-r--r-- | Lib/decimal.py | 8 | ||||
-rw-r--r-- | Lib/test/test_decimal.py | 14 | ||||
-rw-r--r-- | Misc/NEWS | 2 |
3 files changed, 23 insertions, 1 deletions
diff --git a/Lib/decimal.py b/Lib/decimal.py index 3cb3b80efd..361126f6d0 100644 --- a/Lib/decimal.py +++ b/Lib/decimal.py @@ -1581,7 +1581,13 @@ class Decimal(object): def __float__(self): """Float representation.""" - return float(str(self)) + if self._isnan(): + if self.is_snan(): + raise ValueError("Cannot convert signaling NaN to float") + s = "-nan" if self._sign else "nan" + else: + s = str(self) + return float(s) def __int__(self): """Converts self to an int, truncating if necessary.""" diff --git a/Lib/test/test_decimal.py b/Lib/test/test_decimal.py index a011b2f76d..6cc3327d76 100644 --- a/Lib/test/test_decimal.py +++ b/Lib/test/test_decimal.py @@ -1448,6 +1448,20 @@ class DecimalUsabilityTest(unittest.TestCase): self.assertEqual(float(d1), 66) self.assertEqual(float(d2), 15.32) + def test_nan_to_float(self): + # Test conversions of decimal NANs to float. + # See http://bugs.python.org/issue15544 + for s in ('nan', 'nan1234', '-nan', '-nan2468'): + f = float(Decimal(s)) + self.assertTrue(math.isnan(f)) + sign = math.copysign(1.0, f) + self.assertEqual(sign, -1.0 if s.startswith('-') else 1.0) + + def test_snan_to_float(self): + for s in ('snan', '-snan', 'snan1357', '-snan1234'): + d = Decimal(s) + self.assertRaises(ValueError, float, d) + def test_eval_round_trip(self): #with zero @@ -95,6 +95,8 @@ Core and Builtins Library ------- +- Issue #15544: Fix Decimal.__float__ to work with payload-carrying NaNs. + - Issue #15199: Fix JavaScript's default MIME type to application/javascript. Patch by Bohuslav Kabrda. |