aboutsummaryrefslogtreecommitdiffstats
path: root/activesupport
diff options
context:
space:
mode:
authorSebi Burkhard <sebi.burkhard@gmail.com>2011-08-15 16:54:13 +0700
committerSebi Burkhard <sebi.burkhard@gmail.com>2011-08-15 16:54:13 +0700
commit7b53d1372df4bbc7a539b5e493ff1491ec460397 (patch)
treee0bbc310f37c6c6099cc07973b587ca208ddd89a /activesupport
parent652ab436db674a112bcbc72d8c73e21f2ced512a (diff)
downloadrails-7b53d1372df4bbc7a539b5e493ff1491ec460397.tar.gz
rails-7b53d1372df4bbc7a539b5e493ff1491ec460397.tar.bz2
rails-7b53d1372df4bbc7a539b5e493ff1491ec460397.zip
JSON: Encode infinite or NaN floats as null to generate valid JSON.
Diffstat (limited to 'activesupport')
-rw-r--r--activesupport/lib/active_support/json/encoding.rb4
-rw-r--r--activesupport/test/json/encoding_test.rb3
2 files changed, 7 insertions, 0 deletions
diff --git a/activesupport/lib/active_support/json/encoding.rb b/activesupport/lib/active_support/json/encoding.rb
index 67698c1cff..a7a09d5bbe 100644
--- a/activesupport/lib/active_support/json/encoding.rb
+++ b/activesupport/lib/active_support/json/encoding.rb
@@ -186,6 +186,10 @@ class Numeric
def encode_json(encoder) to_s end #:nodoc:
end
+class Float
+ def as_json(options = nil) finite? ? self : NilClass::AS_JSON end #:nodoc:
+end
+
class BigDecimal
# A BigDecimal would be naturally represented as a JSON number. Most libraries,
# however, parse non-integer JSON numbers directly as floats. Clients using
diff --git a/activesupport/test/json/encoding_test.rb b/activesupport/test/json/encoding_test.rb
index 8cf1a54a99..018207853f 100644
--- a/activesupport/test/json/encoding_test.rb
+++ b/activesupport/test/json/encoding_test.rb
@@ -27,6 +27,9 @@ class TestJSONEncoding < Test::Unit::TestCase
NilTests = [[ nil, %(null) ]]
NumericTests = [[ 1, %(1) ],
[ 2.5, %(2.5) ],
+ [ 0.0/0.0, %(null) ],
+ [ 1.0/0.0, %(null) ],
+ [ -1.0/0.0, %(null) ],
[ BigDecimal('2.5'), %("#{BigDecimal('2.5').to_s}") ]]
StringTests = [[ 'this is the <string>', %("this is the \\u003Cstring\\u003E")],