class ActiveModel::Type::Decimal
end
attribute :weight, :decimal, precision: 24
include ActiveModel::Attributes
class BagOfCoffee
attribute:
Decimal precision defaults to 18, and can be customized when declaring an
bag.weight # => nil (the result of ‘.to_s.to_d`)
bag.weight = :arbitrary
bag.weight # => nil
bag.weight = “”
bag.weight # => 0.1e-1
bag.weight = “0.01”
bag.weight # => 0.1e-1
bag.weight = 0.01
bag = BagOfCoffee.new
to a string using to_s
, which is then cast using to_d
.
cast to nil
. If a to_d
method is not defined, the object is converted
are cast using their to_d
method, except for blank strings, which are
Numeric instances are converted to BigDecimal instances. Any other objects
end
attribute :weight, :decimal
include ActiveModel::Attributes
class BagOfCoffee
representation. It is registered under the :decimal
key.
Attribute type for decimal, high-precision floating point numeric
= Active Model Decimal Type
def apply_scale(value)
def apply_scale(value) if scale value.round(scale) else value end end
def cast_value(value)
def cast_value(value) casted_value = \ case value when ::Float convert_float_to_big_decimal(value) when ::Numeric BigDecimal(value, precision || BIGDECIMAL_PRECISION) when ::String begin value.to_d rescue ArgumentError BigDecimal(0) end else if value.respond_to?(:to_d) value.to_d else cast_value(value.to_s) end end apply_scale(casted_value) end
def convert_float_to_big_decimal(value)
def convert_float_to_big_decimal(value) if precision BigDecimal(apply_scale(value), float_precision) else value.to_d end end
def float_precision
def float_precision if precision.to_i > ::Float::DIG + 1 ::Float::DIG + 1 else precision.to_i end end
def type
def type :decimal end
def type_cast_for_schema(value)
def type_cast_for_schema(value) value.to_s.inspect end