module Arel::Predications
def between(other)
def between(other) if unboundable?(other.begin) == 1 || unboundable?(other.end) == -1 self.in([]) elsif open_ended?(other.begin) if open_ended?(other.end) if infinity?(other.begin) == 1 || infinity?(other.end) == -1 self.in([]) else not_in([]) end elsif other.exclude_end? lt(other.end) else lteq(other.end) end elsif open_ended?(other.end) gteq(other.begin) elsif other.exclude_end? gteq(other.begin).and(lt(other.end)) else left = quoted_node(other.begin) right = quoted_node(other.end) Nodes::Between.new(self, Nodes::And.new([left, right])) end end
def concat(other)
def concat(other) Nodes::Concat.new self, other end
def contains(other)
def contains(other) Arel::Nodes::Contains.new self, quoted_node(other) end
def does_not_match(other, escape = nil, case_sensitive = false)
def does_not_match(other, escape = nil, case_sensitive = false) Nodes::DoesNotMatch.new self, quoted_node(other), escape, case_sensitive end
def does_not_match_all(others, escape = nil)
def does_not_match_all(others, escape = nil) grouping_all :does_not_match, others, escape end
def does_not_match_any(others, escape = nil)
def does_not_match_any(others, escape = nil) grouping_any :does_not_match, others, escape end
def does_not_match_regexp(other, case_sensitive = true)
def does_not_match_regexp(other, case_sensitive = true) Nodes::NotRegexp.new self, quoted_node(other), case_sensitive end
def eq(other)
def eq(other) Nodes::Equality.new self, quoted_node(other) end
def eq_all(others)
def eq_all(others) grouping_all :eq, quoted_array(others) end
def eq_any(others)
def eq_any(others) grouping_any :eq, others end
def grouping_all(method_id, others, *extras)
def grouping_all(method_id, others, *extras) nodes = others.map { |expr| send(method_id, expr, *extras) } Nodes::Grouping.new Nodes::And.new(nodes) end
def grouping_any(method_id, others, *extras)
def grouping_any(method_id, others, *extras) nodes = others.map { |expr| send(method_id, expr, *extras) } Nodes::Grouping.new nodes.inject { |memo, node| Nodes::Or.new(memo, node) } end
def gt(right)
def gt(right) Nodes::GreaterThan.new self, quoted_node(right) end
def gt_all(others)
def gt_all(others) grouping_all :gt, others end
def gt_any(others)
def gt_any(others) grouping_any :gt, others end
def gteq(right)
def gteq(right) Nodes::GreaterThanOrEqual.new self, quoted_node(right) end
def gteq_all(others)
def gteq_all(others) grouping_all :gteq, others end
def gteq_any(others)
def gteq_any(others) grouping_any :gteq, others end
def in(other)
def in(other) case other when Arel::SelectManager Arel::Nodes::In.new(self, other.ast) when Enumerable Nodes::In.new self, quoted_array(other) else Nodes::In.new self, quoted_node(other) end end
def in_all(others)
def in_all(others) grouping_all :in, others end
def in_any(others)
def in_any(others) grouping_any :in, others end
def infinity?(value)
def infinity?(value) value.respond_to?(:infinite?) && value.infinite? end
def is_distinct_from(other)
def is_distinct_from(other) Nodes::IsDistinctFrom.new self, quoted_node(other) end
def is_not_distinct_from(other)
def is_not_distinct_from(other) Nodes::IsNotDistinctFrom.new self, quoted_node(other) end
def lt(right)
def lt(right) Nodes::LessThan.new self, quoted_node(right) end
def lt_all(others)
def lt_all(others) grouping_all :lt, others end
def lt_any(others)
def lt_any(others) grouping_any :lt, others end
def lteq(right)
def lteq(right) Nodes::LessThanOrEqual.new self, quoted_node(right) end
def lteq_all(others)
def lteq_all(others) grouping_all :lteq, others end
def lteq_any(others)
def lteq_any(others) grouping_any :lteq, others end
def matches(other, escape = nil, case_sensitive = false)
def matches(other, escape = nil, case_sensitive = false) Nodes::Matches.new self, quoted_node(other), escape, case_sensitive end
def matches_all(others, escape = nil, case_sensitive = false)
def matches_all(others, escape = nil, case_sensitive = false) grouping_all :matches, others, escape, case_sensitive end
def matches_any(others, escape = nil, case_sensitive = false)
def matches_any(others, escape = nil, case_sensitive = false) grouping_any :matches, others, escape, case_sensitive end
def matches_regexp(other, case_sensitive = true)
def matches_regexp(other, case_sensitive = true) Nodes::Regexp.new self, quoted_node(other), case_sensitive end
def not_between(other)
def not_between(other) if unboundable?(other.begin) == 1 || unboundable?(other.end) == -1 not_in([]) elsif open_ended?(other.begin) if open_ended?(other.end) if infinity?(other.begin) == 1 || infinity?(other.end) == -1 not_in([]) else self.in([]) end elsif other.exclude_end? gteq(other.end) else gt(other.end) end elsif open_ended?(other.end) lt(other.begin) else left = lt(other.begin) right = if other.exclude_end? gteq(other.end) else gt(other.end) end left.or(right) end end
def not_eq(other)
def not_eq(other) Nodes::NotEqual.new self, quoted_node(other) end
def not_eq_all(others)
def not_eq_all(others) grouping_all :not_eq, others end
def not_eq_any(others)
def not_eq_any(others) grouping_any :not_eq, others end
def not_in(other)
def not_in(other) case other when Arel::SelectManager Arel::Nodes::NotIn.new(self, other.ast) when Enumerable Nodes::NotIn.new self, quoted_array(other) else Nodes::NotIn.new self, quoted_node(other) end end
def not_in_all(others)
def not_in_all(others) grouping_all :not_in, others end
def not_in_any(others)
def not_in_any(others) grouping_any :not_in, others end
def open_ended?(value)
def open_ended?(value) value.nil? || infinity?(value) || unboundable?(value) end
def overlaps(other)
def overlaps(other) Arel::Nodes::Overlaps.new self, quoted_node(other) end
def quoted_array(others)
def quoted_array(others) others.map { |v| quoted_node(v) } end
def quoted_node(other)
def quoted_node(other) Nodes.build_quoted(other, self) end
def unboundable?(value)
def unboundable?(value) value.respond_to?(:unboundable?) && value.unboundable? end
def when(right)
def when(right) Nodes::Case.new(self).when quoted_node(right) end