diff options
author | Rafael França <rafaelmfranca@gmail.com> | 2017-06-27 12:22:46 -0400 |
---|---|---|
committer | GitHub <noreply@github.com> | 2017-06-27 12:22:46 -0400 |
commit | adea9413665ce7885f1c408b21616c72f768c509 (patch) | |
tree | 33b0696efb420d3c07ba3e790901ddbc19fce2df | |
parent | 61cc630ac7e7f8554dc049a3e5a2509c00303ef8 (diff) | |
parent | 0496b7b3b2f38cba8b6fc7fbbff70a0bb5e4bc43 (diff) | |
download | rails-adea9413665ce7885f1c408b21616c72f768c509.tar.gz rails-adea9413665ce7885f1c408b21616c72f768c509.tar.bz2 rails-adea9413665ce7885f1c408b21616c72f768c509.zip |
Merge pull request #29587 from kamipo/skip_instantiating_null_preloader
Skip instantiating `NullPreloader` if `assoc.klass` is nil
-rw-r--r-- | activerecord/lib/active_record/associations/preloader.rb | 14 |
1 files changed, 3 insertions, 11 deletions
diff --git a/activerecord/lib/active_record/associations/preloader.rb b/activerecord/lib/active_record/associations/preloader.rb index 9f77f38b35..208d1b2670 100644 --- a/activerecord/lib/active_record/associations/preloader.rb +++ b/activerecord/lib/active_record/associations/preloader.rb @@ -147,7 +147,7 @@ module ActiveRecord def preloaders_for_one(association, records, scope) grouped_records(association, records).flat_map do |reflection, klasses| klasses.map do |rhs_klass, rs| - loader = preloader_for(reflection, rs, rhs_klass).new(rhs_klass, rs, reflection, scope) + loader = preloader_for(reflection, rs).new(rhs_klass, rs, reflection, scope) loader.run self loader end @@ -159,6 +159,7 @@ module ActiveRecord records.each do |record| next unless record assoc = record.association(association) + next unless assoc.klass klasses = h[assoc.reflection] ||= {} (klasses[assoc.klass] ||= []) << record end @@ -180,20 +181,11 @@ module ActiveRecord end end - class NullPreloader # :nodoc: - def self.new(klass, owners, reflection, preload_scope); self; end - def self.run(preloader); end - def self.preloaded_records; []; end - def self.owners; []; end - end - # Returns a class containing the logic needed to load preload the data # and attach it to a relation. For example +Preloader::Association+ or # +Preloader::HasManyThrough+. The class returned implements a `run` method # that accepts a preloader. - def preloader_for(reflection, owners, rhs_klass) - return NullPreloader unless rhs_klass - + def preloader_for(reflection, owners) if owners.first.association(reflection.name).loaded? return AlreadyLoaded end |