]> granicus.if.org Git - python/commitdiff
Replace more float hacks with correct math functions
authorChristian Heimes <christian@cheimes.de>
Wed, 7 May 2008 22:54:17 +0000 (22:54 +0000)
committerChristian Heimes <christian@cheimes.de>
Wed, 7 May 2008 22:54:17 +0000 (22:54 +0000)
Lib/json/encoder.py

index d8d4770fd0edd43c299f1b132e8a7290255a5602..b1dd5703dc520575e74ee633bae3b431d6565746 100644 (file)
@@ -2,6 +2,7 @@
 """
 
 import re
+import math
 
 try:
     from _json import encode_basestring_ascii as c_encode_basestring_ascii
@@ -25,20 +26,19 @@ ESCAPE_DCT = {
 for i in range(0x20):
     ESCAPE_DCT.setdefault(chr(i), '\\u{0:04x}'.format(i))
 
-# Assume this produces an infinity on all machines (probably not guaranteed)
-INFINITY = float('1e66666')
 FLOAT_REPR = repr
 
 def floatstr(o, allow_nan=True):
     # Check for specials.  Note that this type of test is processor- and/or
     # platform-specific, so do tests which don't depend on the internals.
 
-    if o != o:
+    if math.isnan(o):
         text = 'NaN'
-    elif o == INFINITY:
-        text = 'Infinity'
-    elif o == -INFINITY:
-        text = '-Infinity'
+    elif math.isinf(o):
+        if math.copysign(1., o) == 1.:
+            text = 'Infinity'
+        else:
+            text = '-Infinity'
     else:
         return FLOAT_REPR(o)