Sha256: 61e3bd4bf43111d22a6c0206fa0e0aa746deda485b874c0c064a92b2aef224d3

Contents?: true

Size: 1.12 KB

Versions: 7

Compression:

Stored size: 1.12 KB

Contents

require 'bigdecimal'

begin
  require 'psych'
rescue LoadError
end

require 'yaml'

class BigDecimal
  YAML_TAG = 'tag:yaml.org,2002:float'
  YAML_MAPPING = { 'Infinity' => '.Inf', '-Infinity' => '-.Inf', 'NaN' => '.NaN' }

  # This emits the number without any scientific notation.
  # This is better than self.to_f.to_s since it doesn't lose precision.
  #
  # Note that reconstituting YAML floats to native floats may lose precision.
  def to_yaml(opts = {})
    return super if
      (defined?(YAML::ENGINE) && !YAML::ENGINE.syck?) ||
      (defined?(Psych) && YAML == Psych)

    YAML.quick_emit(nil, opts) do |out|
      string = to_s
      out.scalar(YAML_TAG, YAML_MAPPING[string] || string, :plain)
    end
  end

  def encode_with(coder)
    string = to_s
    coder.represent_scalar(nil, YAML_MAPPING[string] || string)
  end

  # Backport this method if it doesn't exist
  unless method_defined?(:to_d)
    def to_d
      self
    end
  end

  DEFAULT_STRING_FORMAT = 'F'
  def to_formatted_s(format = DEFAULT_STRING_FORMAT)
    _original_to_s(format)
  end
  alias_method :_original_to_s, :to_s
  alias_method :to_s, :to_formatted_s
end

Version data entries

7 entries across 7 versions & 2 rubygems

Version Path
mdg-1.0.1 vendor/bundle/ruby/2.3.0/gems/activesupport-3.2.22.5/lib/active_support/core_ext/big_decimal/conversions.rb
activesupport-3.2.22.5 lib/active_support/core_ext/big_decimal/conversions.rb
activesupport-3.2.22.4 lib/active_support/core_ext/big_decimal/conversions.rb
activesupport-3.2.22.3 lib/active_support/core_ext/big_decimal/conversions.rb
activesupport-3.2.22.2 lib/active_support/core_ext/big_decimal/conversions.rb
activesupport-3.2.22.1 lib/active_support/core_ext/big_decimal/conversions.rb
activesupport-3.2.22 lib/active_support/core_ext/big_decimal/conversions.rb