1
0
Fork 0
mirror of https://github.com/rails/rails.git synced 2022-11-09 12:12:34 -05:00

Make arel methods private API

Since its conception arel was made to be private API of Active Record.
If users want to use arel features directly we should provide a way
using the Active Record API without exposing the arel implementation.
This commit is contained in:
Rafael Mendonça França 2014-02-01 16:16:06 -02:00
parent 83ea905fd1
commit cd93d7175e
2 changed files with 5 additions and 6 deletions

View file

@ -138,12 +138,12 @@ module ActiveRecord
# class Post < ActiveRecord::Base # class Post < ActiveRecord::Base
# scope :published_and_commented, -> { published.and(self.arel_table[:comments_count].gt(0)) } # scope :published_and_commented, -> { published.and(self.arel_table[:comments_count].gt(0)) }
# end # end
def arel_table def arel_table # :nodoc:
@arel_table ||= Arel::Table.new(table_name, arel_engine) @arel_table ||= Arel::Table.new(table_name, arel_engine)
end end
# Returns the Arel engine. # Returns the Arel engine.
def arel_engine def arel_engine # :nodoc:
@arel_engine ||= @arel_engine ||=
if Base == self || connection_handler.retrieve_connection_pool(self) if Base == self || connection_handler.retrieve_connection_pool(self)
self self

View file

@ -824,11 +824,12 @@ module ActiveRecord
end end
# Returns the Arel object associated with the relation. # Returns the Arel object associated with the relation.
def arel def arel # :nodoc:
@arel ||= build_arel @arel ||= build_arel
end end
# Like #arel, but ignores the default scope of the model. private
def build_arel def build_arel
arel = Arel::SelectManager.new(table.engine, table) arel = Arel::SelectManager.new(table.engine, table)
@ -854,8 +855,6 @@ module ActiveRecord
arel arel
end end
private
def symbol_unscoping(scope) def symbol_unscoping(scope)
if !VALID_UNSCOPING_VALUES.include?(scope) if !VALID_UNSCOPING_VALUES.include?(scope)
raise ArgumentError, "Called unscope() with invalid unscoping argument ':#{scope}'. Valid arguments are :#{VALID_UNSCOPING_VALUES.to_a.join(", :")}." raise ArgumentError, "Called unscope() with invalid unscoping argument ':#{scope}'. Valid arguments are :#{VALID_UNSCOPING_VALUES.to_a.join(", :")}."