diff options
author | Rafael Mendonça França <rafaelmfranca@gmail.com> | 2015-05-28 01:52:14 -0300 |
---|---|---|
committer | Rafael Mendonça França <rafaelmfranca@gmail.com> | 2015-05-28 01:52:14 -0300 |
commit | 7cc9754209c0ae00d70bdd629fa4a81a1c74cc6f (patch) | |
tree | 0205c87c305afffd9876c676f23526fe23a6e9c3 /activerecord/lib | |
parent | be18476fb24ef21a956e79143b6bcde3ec744a64 (diff) | |
parent | a01d164b948371c3405635713d9361f67d10a8bf (diff) | |
download | rails-7cc9754209c0ae00d70bdd629fa4a81a1c74cc6f.tar.gz rails-7cc9754209c0ae00d70bdd629fa4a81a1c74cc6f.tar.bz2 rails-7cc9754209c0ae00d70bdd629fa4a81a1c74cc6f.zip |
Merge pull request #20196 from huoxito/preload-association-and-merges
Properly append preload / includes args on Merger
Diffstat (limited to 'activerecord/lib')
-rw-r--r-- | activerecord/lib/active_record/relation/merger.rb | 24 |
1 files changed, 23 insertions, 1 deletions
diff --git a/activerecord/lib/active_record/relation/merger.rb b/activerecord/lib/active_record/relation/merger.rb index c3054f1fe9..01c05462b2 100644 --- a/activerecord/lib/active_record/relation/merger.rb +++ b/activerecord/lib/active_record/relation/merger.rb @@ -50,7 +50,7 @@ module ActiveRecord NORMAL_VALUES = Relation::VALUE_METHODS - Relation::CLAUSE_METHODS - - [:joins, :order, :reverse_order, :lock, :create_with, :reordering] # :nodoc: + [:includes, :preload, :joins, :order, :reverse_order, :lock, :create_with, :reordering] # :nodoc: def normal_values NORMAL_VALUES @@ -75,6 +75,7 @@ module ActiveRecord merge_multi_values merge_single_values merge_clauses + merge_preloads merge_joins relation @@ -82,6 +83,27 @@ module ActiveRecord private + def merge_preloads + return if other.preload_values.empty? && other.includes_values.empty? + + if other.klass == relation.klass + relation.preload! other.preload_values unless other.preload_values.empty? + relation.includes! other.includes_values unless other.includes_values.empty? + else + reflection = relation.klass.reflect_on_all_associations.find do |reflection| + reflection.class_name == other.klass.name + end || return + + unless other.preload_values.empty? + relation.preload! reflection.name => other.preload_values + end + + unless other.includes_values.empty? + relation.includes! reflection.name => other.includes_values + end + end + end + def merge_joins return if other.joins_values.blank? |