summaryrefslogtreecommitdiff
path: root/Lib/decimal.py
diff options
context:
space:
mode:
authorAntoine Pitrou <solipsis@pitrou.net>2012-08-24 19:51:09 +0200
committerAntoine Pitrou <solipsis@pitrou.net>2012-08-24 19:51:09 +0200
commit8d649ef9513613b6b9fc413ce64b24e80e7e33c3 (patch)
treed1ede20a95eecfc71941caccfa163df9876913cc /Lib/decimal.py
parent0ac0b11ec1bb471021982fa48d67ce8b11052080 (diff)
parentfc33d4ce0a2a89d26c30cd31ccc1992eb495aff0 (diff)
downloadcpython-git-8d649ef9513613b6b9fc413ce64b24e80e7e33c3.tar.gz
Merge
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 6bd655bdb7..b74ab0134d 100644
--- a/Lib/decimal.py
+++ b/Lib/decimal.py
@@ -1601,7 +1601,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."""