Class: ActiveRecord::Type::Serialized
Relationships & Source Files | |
Super Chains via Extension / Inclusion / Inheritance | |
Class Chain:
|
|
Instance Chain:
|
|
Inherits: |
ActiveModel::Type::Value
|
Defined in: | activerecord/lib/active_record/type/serialized.rb |
Class Method Summary
::ActiveModel::Type::Value
- Inherited
.new | Initializes a type with three basic configuration settings: precision, limit, and scale. |
Instance Attribute Summary
- #coder readonly
- #serialized? ⇒ Boolean readonly
- #subtype readonly
::ActiveModel::Type::Helpers::Mutable
- Included
::ActiveModel::Type::Value
- Inherited
#limit, #precision, #scale, | |
#binary? | These predicates are not documented, as I need to look further into their use, and see if they can be removed entirely. |
#mutable?, #serialized? |
Instance Method Summary
- #accessor
- #assert_valid_value(value)
- #changed_in_place?(raw_old_value, value) ⇒ Boolean
- #deserialize(value)
- #force_equality?(value) ⇒ Boolean
- #serialize(value)
- #default_value?(value) ⇒ Boolean private
- #encoded(value) private
::ActiveModel::Type::Helpers::Mutable
- Included
#cast, | |
#changed_in_place? |
|
::ActiveModel::Type::Value
- Inherited
#==, #as_json, #assert_valid_value, | |
#cast |
|
#changed? | Determines whether a value has changed for dirty checking. |
#changed_in_place? | Determines whether the mutable value has been modified since it was read. |
#deserialize | Converts a value from database input to the appropriate ruby type. |
#eql? | Alias for ActiveModel::Type::Value#==. |
#hash, | |
#serializable? | Returns true if this type can convert |
#serialize | Casts a value from the ruby type to a type that the database knows how to understand. |
#type | Returns the unique type name as a |
#cast_value | Convenience method for types which do not need separate type casting behavior for user and database inputs. |
#force_equality?, #map, | |
#type_cast_for_schema |
|
#value_constructed_by_mass_assignment? |
::ActiveModel::Type::SerializeCastValue
- Included
Constructor Details
.new(subtype, coder, comparable: false) ⇒ Serialized
Instance Attribute Details
#coder (readonly)
[ GitHub ]# File 'activerecord/lib/active_record/type/serialized.rb', line 10
attr_reader :subtype, :coder
#serialized? ⇒ Boolean (readonly)
[ GitHub ]# File 'activerecord/lib/active_record/type/serialized.rb', line 63
def serialized? # :nodoc: true end
#subtype (readonly)
[ GitHub ]# File 'activerecord/lib/active_record/type/serialized.rb', line 10
attr_reader :subtype, :coder
Instance Method Details
#accessor
[ GitHub ]# File 'activerecord/lib/active_record/type/serialized.rb', line 49
def accessor ActiveRecord::Store::IndifferentHashAccessor end
#assert_valid_value(value)
[ GitHub ]#changed_in_place?(raw_old_value, value) ⇒ Boolean
# File 'activerecord/lib/active_record/type/serialized.rb', line 36
def changed_in_place?(raw_old_value, value) return false if value.nil? if @comparable old_value = deserialize(raw_old_value) old_value != value else raw_new_value = encoded(value) raw_old_value.nil? != raw_new_value.nil? || subtype.changed_in_place?(raw_old_value, raw_new_value) end end
#default_value?(value) ⇒ Boolean (private)
# File 'activerecord/lib/active_record/type/serialized.rb', line 68
def default_value?(value) value == coder.load(nil) end
#deserialize(value)
[ GitHub ]# File 'activerecord/lib/active_record/type/serialized.rb', line 19
def deserialize(value) if default_value?(value) value else coder.load(super) end end
#encoded(value) (private)
[ GitHub ]# File 'activerecord/lib/active_record/type/serialized.rb', line 72
def encoded(value) return if default_value?(value) payload = coder.dump(value) if payload && @subtype.binary? ActiveModel::Type::Binary::Data.new(payload) else payload end end
#force_equality?(value) ⇒ Boolean
#serialize(value)
[ GitHub ]# File 'activerecord/lib/active_record/type/serialized.rb', line 27
def serialize(value) return if value.nil? unless default_value?(value) super coder.dump(value) end end