Class: BigDecimal

Inherits:
Object show all
Defined in:
activesupport/lib/active_support/core_ext/object/json.rb,
activesupport/lib/active_support/core_ext/object/duplicable.rb

Instance Method Summary collapse

Instance Method Details

#as_json(options = nil) ⇒ Object

A BigDecimal would be naturally represented as a JSON number. Most libraries, however, parse non-integer JSON numbers directly as floats. Clients using those libraries would get in general a wrong number and no way to recover other than manually inspecting the string with the JSON code itself.

That's why a JSON string is returned. The JSON literal is not numeric, but if the other end knows by contract that the data is supposed to be a BigDecimal, it still has the chance to post-process the string and get the real value.


117
118
119
# File 'activesupport/lib/active_support/core_ext/object/json.rb', line 117

def as_json(options = nil) #:nodoc:
  finite? ? to_s : nil
end

#duplicable?Boolean

BigDecimals are duplicable:

BigDecimal.new(“1.2”).duplicable? # => true BigDecimal.new(“1.2”).dup # => #<BigDecimal:…,'0.12E1',18(18)>

Returns:

  • (Boolean)

85
86
87
# File 'activesupport/lib/active_support/core_ext/object/duplicable.rb', line 85

def duplicable?
  true
end