Class: ActiveModel::Type::ImmutableString
- Defined in:
- lib/active_model/type/immutable_string.rb
Overview
Active Model ImmutableString Type
Attribute type to represent immutable strings. It casts incoming values to frozen strings.
class Person
include ActiveModel::Attributes
attribute :name, :immutable_string
end
person = Person.new
person.name = 1
person.name # => "1"
person.name.frozen? # => true
Values are coerced to strings using their to_s
method. Boolean values are treated differently, however: true
will be cast to "t"
and false
will be cast to "f"
. These strings can be customized when declaring an attribute:
class Person
include ActiveModel::Attributes
attribute :active, :immutable_string, true: "aye", false: "nay"
end
person = Person.new
person.active = true
person.active # => "aye"
Direct Known Subclasses
Instance Attribute Summary
Attributes inherited from Value
Instance Method Summary collapse
-
#initialize(**args) ⇒ ImmutableString
constructor
A new instance of ImmutableString.
- #serialize(value) ⇒ Object
-
#serialize_cast_value(value) ⇒ Object
:nodoc:.
- #type ⇒ Object
Methods inherited from Value
#==, #as_json, #assert_valid_value, #binary?, #cast, #changed?, #changed_in_place?, #deserialize, #force_equality?, #hash, #map, #mutable?, #serializable?, #serialized?, #type_cast_for_schema, #value_constructed_by_mass_assignment?
Methods included from SerializeCastValue
included, #itself_if_serialize_cast_value_compatible, serialize
Constructor Details
#initialize(**args) ⇒ ImmutableString
Returns a new instance of ImmutableString.
38 39 40 41 42 |
# File 'lib/active_model/type/immutable_string.rb', line 38 def initialize(**args) @true = -(args.delete(:true)&.to_s || "t") @false = -(args.delete(:false)&.to_s || "f") super end |
Instance Method Details
#serialize(value) ⇒ Object
48 49 50 51 52 53 54 55 |
# File 'lib/active_model/type/immutable_string.rb', line 48 def serialize(value) case value when ::Numeric, ::Symbol, ActiveSupport::Duration then value.to_s when true then @true when false then @false else super end end |
#serialize_cast_value(value) ⇒ Object
:nodoc:
57 58 59 |
# File 'lib/active_model/type/immutable_string.rb', line 57 def serialize_cast_value(value) # :nodoc: value end |
#type ⇒ Object
44 45 46 |
# File 'lib/active_model/type/immutable_string.rb', line 44 def type :string end |