123456789_123456789_123456789_123456789_123456789_

Class: ActiveModel::Attribute

Do not use. This class is for internal use only.

Class Method Summary

Instance Attribute Summary

Instance Method Summary

Constructor Details

.new(name, value_before_type_cast, type, original_attribute = nil, value = nil) ⇒ Attribute

This method should not be called directly. Use #from_database or #from_user

[ GitHub ]

  
# File 'activemodel/lib/active_model/attribute.rb', line 33

def initialize(name, value_before_type_cast, type, original_attribute = nil, value = nil)
  @name = name
  @value_before_type_cast = value_before_type_cast
  @type = type
  @original_attribute = original_attribute
  @value = value unless value.nil?
end

Class Method Details

.from_database(name, value_before_type_cast, type, value = nil)

[ GitHub ]

  
# File 'activemodel/lib/active_model/attribute.rb', line 8

def from_database(name, value_before_type_cast, type, value = nil)
  FromDatabase.new(name, value_before_type_cast, type, nil, value)
end

.from_user(name, value_before_type_cast, type, original_attribute = nil)

[ GitHub ]

  
# File 'activemodel/lib/active_model/attribute.rb', line 12

def from_user(name, value_before_type_cast, type, original_attribute = nil)
  FromUser.new(name, value_before_type_cast, type, original_attribute)
end

.null(name)

[ GitHub ]

  
# File 'activemodel/lib/active_model/attribute.rb', line 20

def null(name)
  Null.new(name)
end

.uninitialized(name, type)

[ GitHub ]

  
# File 'activemodel/lib/active_model/attribute.rb', line 24

def uninitialized(name, type)
  Uninitialized.new(name, type)
end

.with_cast_value(name, value_before_type_cast, type)

[ GitHub ]

  
# File 'activemodel/lib/active_model/attribute.rb', line 16

def with_cast_value(name, value_before_type_cast, type)
  WithCastValue.new(name, value_before_type_cast, type)
end

Instance Attribute Details

#assigned? (readonly, private)

Alias for #original_attribute.

[ GitHub ]

  
# File 'activemodel/lib/active_model/attribute.rb', line 161

alias :assigned? :original_attribute

#came_from_user?Boolean (readonly)

[ GitHub ]

  
# File 'activemodel/lib/active_model/attribute.rb', line 115

def came_from_user?
  false
end

#changed?Boolean (readonly)

[ GitHub ]

  
# File 'activemodel/lib/active_model/attribute.rb', line 66

def changed?
  changed_from_assignment? || changed_in_place?
end

#changed_from_assignment?Boolean (readonly, private)

[ GitHub ]

  
# File 'activemodel/lib/active_model/attribute.rb', line 169

def changed_from_assignment?
  assigned? && type.changed?(original_value, value, value_before_type_cast)
end

#changed_in_place?Boolean (readonly)

[ GitHub ]

  
# File 'activemodel/lib/active_model/attribute.rb', line 70

def changed_in_place?
  has_been_read? && type.changed_in_place?(original_value_for_database, value)
end

#has_been_read?Boolean (readonly)

[ GitHub ]

  
# File 'activemodel/lib/active_model/attribute.rb', line 119

def has_been_read?
  defined?(@value)
end

#initialized?Boolean (readonly)

[ GitHub ]

  
# File 'activemodel/lib/active_model/attribute.rb', line 111

def initialized?
  true
end

#name (readonly)

[ GitHub ]

  
# File 'activemodel/lib/active_model/attribute.rb', line 29

attr_reader :name, :value_before_type_cast, :type

#original_attribute (readonly, private) Also known as: #assigned?

[ GitHub ]

  
# File 'activemodel/lib/active_model/attribute.rb', line 160

attr_reader :original_attribute

#type (readonly)

[ GitHub ]

  
# File 'activemodel/lib/active_model/attribute.rb', line 29

attr_reader :name, :value_before_type_cast, :type

#value_before_type_cast (readonly)

[ GitHub ]

  
# File 'activemodel/lib/active_model/attribute.rb', line 29

attr_reader :name, :value_before_type_cast, :type

Instance Method Details

#==(other) Also known as: #eql?

[ GitHub ]

  
# File 'activemodel/lib/active_model/attribute.rb', line 123

def ==(other)
  self.class == other.class &&
    name == other.name &&
    value_before_type_cast == other.value_before_type_cast &&
    type == other.type
end

#_original_value_for_database (private)

[ GitHub ]

  
# File 'activemodel/lib/active_model/attribute.rb', line 177

def _original_value_for_database
  type.serialize(original_value)
end

#_value_for_database (private)

[ GitHub ]

  
# File 'activemodel/lib/active_model/attribute.rb', line 173

def _value_for_database
  type.serialize(value)
end

#dup_or_share

[ GitHub ]

  
# File 'activemodel/lib/active_model/attribute.rb', line 99

def dup_or_share # :nodoc:
  if @type.mutable?
    dup
  else
    self # If the underlying type is immutable we can get away with not duping
  end
end

#encode_with(coder)

[ GitHub ]

  
# File 'activemodel/lib/active_model/attribute.rb', line 143

def encode_with(coder)
  coder["name"] = name
  coder["value_before_type_cast"] = value_before_type_cast unless value_before_type_cast.nil?
  coder["type"] = type if type
  coder["original_attribute"] = original_attribute if original_attribute
  coder["value"] = value if defined?(@value)
end

#eql?(other)

Alias for #==.

[ GitHub ]

  
# File 'activemodel/lib/active_model/attribute.rb', line 129

alias eql? ==

#forgetting_assignment

[ GitHub ]

  
# File 'activemodel/lib/active_model/attribute.rb', line 74

def forgetting_assignment
  with_value_from_database(value_for_database)
end

#hash

[ GitHub ]

  
# File 'activemodel/lib/active_model/attribute.rb', line 131

def hash
  [self.class, name, value_before_type_cast, type].hash
end

#init_with(coder)

[ GitHub ]

  
# File 'activemodel/lib/active_model/attribute.rb', line 135

def init_with(coder)
  @name = coder["name"]
  @value_before_type_cast = coder["value_before_type_cast"]
  @type = coder["type"]
  @original_attribute = coder["original_attribute"]
  @value = coder["value"] if coder.map.key?("value")
end

#initialize_dup(other) (private)

[ GitHub ]

  
# File 'activemodel/lib/active_model/attribute.rb', line 163

def initialize_dup(other)
  if @value&.duplicable?
    @value = @value.dup
  end
end

#original_value

[ GitHub ]

  
# File 'activemodel/lib/active_model/attribute.rb', line 47

def original_value
  if assigned?
    original_attribute.original_value
  else
    type_cast(value_before_type_cast)
  end
end

#original_value_for_database

[ GitHub ]

  
# File 'activemodel/lib/active_model/attribute.rb', line 151

def original_value_for_database
  if assigned?
    original_attribute.original_value_for_database
  else
    _original_value_for_database
  end
end

#serializable?(&block) ⇒ Boolean

[ GitHub ]

  
# File 'activemodel/lib/active_model/attribute.rb', line 62

def serializable?(&block)
  type.serializable?(value, &block)
end

#type_cast

Raises:

  • (NotImplementedError)
[ GitHub ]

  
# File 'activemodel/lib/active_model/attribute.rb', line 107

def type_cast(*)
  raise NotImplementedError
end

#value(&_)

[ GitHub ]

  
# File 'activemodel/lib/active_model/attribute.rb', line 41

def value(&_)
  # `defined?` is cheaper than `||=` when we get back falsy values
  @value = type_cast(value_before_type_cast) unless defined?(@value)
  @value
end

#value_for_database

[ GitHub ]

  
# File 'activemodel/lib/active_model/attribute.rb', line 55

def value_for_database
  if !defined?(@value_for_database) || type.changed_in_place?(@value_for_database, value)
    @value_for_database = _value_for_database
  end
  @value_for_database
end

#with_cast_value(value)

[ GitHub ]

  
# File 'activemodel/lib/active_model/attribute.rb', line 87

def with_cast_value(value)
  self.class.with_cast_value(name, value, type)
end

#with_type(type)

[ GitHub ]

  
# File 'activemodel/lib/active_model/attribute.rb', line 91

def with_type(type)
  if changed_in_place?
    with_value_from_user(value).with_type(type)
  else
    self.class.new(name, value_before_type_cast, type, original_attribute)
  end
end

#with_user_default(value)

[ GitHub ]

  
# File 'activemodel/lib/active_model/attribute/user_provided_default.rb', line 7

def with_user_default(value)
  UserProvidedDefault.new(name, value, type, self.is_a?(FromDatabase) ? self : original_attribute)
end

#with_value_from_database(value)

[ GitHub ]

  
# File 'activemodel/lib/active_model/attribute.rb', line 83

def with_value_from_database(value)
  self.class.from_database(name, value, type)
end

#with_value_from_user(value)

[ GitHub ]

  
# File 'activemodel/lib/active_model/attribute.rb', line 78

def with_value_from_user(value)
  type.assert_valid_value(value)
  self.class.from_user(name, value, type, original_attribute || self)
end