diff options
Diffstat (limited to 'activerecord/lib/active_record')
| -rw-r--r-- | activerecord/lib/active_record/associations/collection_association.rb | 26 | ||||
| -rw-r--r-- | activerecord/lib/active_record/associations/collection_proxy.rb | 5 | 
2 files changed, 14 insertions, 17 deletions
| diff --git a/activerecord/lib/active_record/associations/collection_association.rb b/activerecord/lib/active_record/associations/collection_association.rb index 1a424896fe..38e7ba39d3 100644 --- a/activerecord/lib/active_record/associations/collection_association.rb +++ b/activerecord/lib/active_record/associations/collection_association.rb @@ -74,23 +74,19 @@ module ActiveRecord        end        def find(*args) -        if block_given? -          load_target.find(*args) { |*block_args| yield(*block_args) } -        else -          if options[:inverse_of] && loaded? -            args_flatten = args.flatten -            raise RecordNotFound, "Couldn't find #{scope.klass.name} without an ID" if args_flatten.blank? -            result = find_by_scan(*args) - -            result_size = Array(result).size -            if !result || result_size != args_flatten.size -              scope.raise_record_not_found_exception!(args_flatten, result_size, args_flatten.size) -            else -              result -            end +        if options[:inverse_of] && loaded? +          args_flatten = args.flatten +          raise RecordNotFound, "Couldn't find #{scope.klass.name} without an ID" if args_flatten.blank? +          result = find_by_scan(*args) + +          result_size = Array(result).size +          if !result || result_size != args_flatten.size +            scope.raise_record_not_found_exception!(args_flatten, result_size, args_flatten.size)            else -            scope.find(*args) +            result            end +        else +          scope.find(*args)          end        end diff --git a/activerecord/lib/active_record/associations/collection_proxy.rb b/activerecord/lib/active_record/associations/collection_proxy.rb index 0678b07699..412e89255d 100644 --- a/activerecord/lib/active_record/associations/collection_proxy.rb +++ b/activerecord/lib/active_record/associations/collection_proxy.rb @@ -135,8 +135,9 @@ module ActiveRecord        #   #       #<Pet id: 2, name: "Spook", person_id: 1>,        #   #       #<Pet id: 3, name: "Choo-Choo", person_id: 1>        #   #    ] -      def find(*args, &block) -        @association.find(*args, &block) +      def find(*args) +        return super if block_given? +        @association.find(*args)        end        ## | 
