summaryrefslogtreecommitdiff
path: root/Lib/decimal.py
diff options
context:
space:
mode:
authorMark Dickinson <mdickinson@enthought.com>2012-08-24 20:06:30 +0100
committerMark Dickinson <mdickinson@enthought.com>2012-08-24 20:06:30 +0100
commit088cec3ab70f83564d14a43f802e01d63a5fc905 (patch)
treed990cea66a4acde4600bc8fb5f9ab87a94aa19c2 /Lib/decimal.py
parent85ede8da006212c923acc049124eb6f5b1866f29 (diff)
downloadcpython-git-088cec3ab70f83564d14a43f802e01d63a5fc905.tar.gz
Issue #15544: Fix Decimal.__float__ to work with payload-carrying NaNs.
Diffstat (limited to 'Lib/decimal.py')
-rw-r--r--Lib/decimal.py8
1 files changed, 7 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."""