1
0
Fork 0
mirror of https://github.com/rails/rails.git synced 2022-11-09 12:12:34 -05:00
rails--rails/activerecord/lib/arel/nodes/casted.rb
eileencodes 200058b011
Revert "Merge pull request #39022 from kamipo/perf_where_in"
This reverts commit 9817d74f3b, reversing
changes made to d326b029e0.

Just making this easier to merge our PR in. Otherwise there's tons of
conflicts and our PR is faster.
2020-05-05 12:45:10 -04:00

62 lines
1.5 KiB
Ruby

# frozen_string_literal: true
module Arel # :nodoc: all
module Nodes
class Casted < Arel::Nodes::NodeExpression # :nodoc:
attr_reader :value, :attribute
alias :value_before_type_cast :value
def initialize(value, attribute)
@value = value
@attribute = attribute
super()
end
def nil?; value.nil?; end
def value_for_database
if attribute.able_to_type_cast?
attribute.type_cast_for_database(value)
else
value
end
end
def hash
[self.class, value, attribute].hash
end
def eql?(other)
self.class == other.class &&
self.value == other.value &&
self.attribute == other.attribute
end
alias :== :eql?
end
class Quoted < Arel::Nodes::Unary # :nodoc:
alias :value_for_database :value
alias :value_before_type_cast :value
def nil?; value.nil?; end
def infinite?
value.respond_to?(:infinite?) && value.infinite?
end
end
def self.build_quoted(other, attribute = nil)
case other
when Arel::Nodes::Node, Arel::Attributes::Attribute, Arel::Table, Arel::Nodes::BindParam, Arel::SelectManager, Arel::Nodes::Quoted, Arel::Nodes::SqlLiteral
other
else
case attribute
when Arel::Attributes::Attribute
Casted.new other, attribute
else
Quoted.new other
end
end
end
end
end