Class: ActiveRecord::Relation::QueryAttribute
Do not use. This class is for internal use only.
Relationships & Source Files | |
Super Chains via Extension / Inclusion / Inheritance | |
Class Chain:
self,
::ActiveModel::Attribute
|
|
Instance Chain:
self,
::ActiveModel::Attribute
|
|
Inherits: |
ActiveModel::Attribute
|
Defined in: | activerecord/lib/active_record/relation/query_attribute.rb |
Class Method Summary
- .new ⇒ QueryAttribute constructor
::ActiveModel::Attribute
- Inherited
.from_database, .from_user, | |
.new | This method should not be called directly. |
.null, .uninitialized, .with_cast_value |
Instance Attribute Summary
- #infinite? ⇒ Boolean readonly
- #nil? ⇒ Boolean readonly
- #unboundable? ⇒ Boolean readonly
::ActiveModel::Attribute
- Inherited
Instance Method Summary
- #==(other) (also: #eql?)
-
#eql?(other)
Alias for #==.
- #hash
- #type_cast(value)
- #value_for_database
- #with_cast_value(value)
- #infinity?(value) ⇒ Boolean private
::ActiveModel::Attribute
- Inherited
Constructor Details
.new ⇒ QueryAttribute
# File 'activerecord/lib/active_record/relation/query_attribute.rb', line 8
def initialize(...) super # The query attribute value may be mutated before we actually "compile" the query. # To avoid that if the type uses a serializer we eagerly compute the value for database if value_before_type_cast.is_a?(StatementCache::Substitute) # we don't need to serialize StatementCache::Substitute elsif @type.serialized? value_for_database elsif @type.mutable? # If the type is simply mutable, we deep_dup it. unless @value_before_type_cast.frozen? @value_before_type_cast = @value_before_type_cast.deep_dup end end end
Instance Attribute Details
#infinite? ⇒ Boolean
(readonly)
[ GitHub ]
# File 'activerecord/lib/active_record/relation/query_attribute.rb', line 44
def infinite? infinity?(value_before_type_cast) || serializable? && infinity?(value_for_database) end
#nil? ⇒ Boolean
(readonly)
[ GitHub ]
# File 'activerecord/lib/active_record/relation/query_attribute.rb', line 37
def nil? unless value_before_type_cast.is_a?(StatementCache::Substitute) value_before_type_cast.nil? || (type.respond_to?(:subtype) || type.respond_to?(:normalizer)) && serializable? && value_for_database.nil? end end
#unboundable? ⇒ Boolean
(readonly)
[ GitHub ]
# File 'activerecord/lib/active_record/relation/query_attribute.rb', line 48
def unboundable? unless defined?(@_unboundable) serializable? { |value| @_unboundable = value <=> 0 } && @_unboundable = nil end @_unboundable end
Instance Method Details
#==(other) Also known as: #eql?
[ GitHub ]# File 'activerecord/lib/active_record/relation/query_attribute.rb', line 55
def ==(other) super && value_for_database == other.value_for_database end
#eql?(other)
Alias for #==.
# File 'activerecord/lib/active_record/relation/query_attribute.rb', line 58
alias eql? ==
#hash
[ GitHub ]# File 'activerecord/lib/active_record/relation/query_attribute.rb', line 60
def hash [self.class, name, value_for_database, type].hash end
#infinity?(value) ⇒ Boolean
(private)
#type_cast(value)
[ GitHub ]# File 'activerecord/lib/active_record/relation/query_attribute.rb', line 24
def type_cast(value) value end
#value_for_database
[ GitHub ]# File 'activerecord/lib/active_record/relation/query_attribute.rb', line 28
def value_for_database @value_for_database = _value_for_database unless defined?(@value_for_database) @value_for_database end
#with_cast_value(value)
[ GitHub ]# File 'activerecord/lib/active_record/relation/query_attribute.rb', line 33
def with_cast_value(value) QueryAttribute.new(name, value, type) end