diff options
author | Diego Algorta <diego@oboxodo.com> | 2009-02-13 03:07:39 -0300 |
---|---|---|
committer | rick <technoweenie@gmail.com> | 2009-02-25 09:21:08 -0800 |
commit | 0dd2f96f5c90f8abacb0fe0757ef7e5db4a4d501 (patch) | |
tree | c696bfc85598fa5a3ad1c5ba0db9636ab90f740a /activerecord/lib | |
parent | 92a30b0c88384feafc0da2864c01ff5c3a6f25ff (diff) | |
download | rails-0dd2f96f5c90f8abacb0fe0757ef7e5db4a4d501.tar.gz rails-0dd2f96f5c90f8abacb0fe0757ef7e5db4a4d501.tar.bz2 rails-0dd2f96f5c90f8abacb0fe0757ef7e5db4a4d501.zip |
Fixed bug that makes named_scopes _forgot_ current scope
Diffstat (limited to 'activerecord/lib')
-rw-r--r-- | activerecord/lib/active_record/named_scope.rb | 13 |
1 files changed, 11 insertions, 2 deletions
diff --git a/activerecord/lib/active_record/named_scope.rb b/activerecord/lib/active_record/named_scope.rb index 989b2a1ec5..022fdaf9b2 100644 --- a/activerecord/lib/active_record/named_scope.rb +++ b/activerecord/lib/active_record/named_scope.rb @@ -100,7 +100,7 @@ module ActiveRecord end class Scope - attr_reader :proxy_scope, :proxy_options + attr_reader :proxy_scope, :proxy_options, :current_scoped_methods_when_defined NON_DELEGATE_METHODS = %w(nil? send object_id class extend find size count sum average maximum minimum paginate first last empty? any? respond_to?).to_set [].methods.each do |m| unless m =~ /^__/ || NON_DELEGATE_METHODS.include?(m.to_s) @@ -113,6 +113,9 @@ module ActiveRecord def initialize(proxy_scope, options, &block) [options[:extend]].flatten.each { |extension| extend extension } if options[:extend] extend Module.new(&block) if block_given? + unless Scope === proxy_scope + @current_scoped_methods_when_defined = proxy_scope.send(:current_scoped_methods) + end @proxy_scope, @proxy_options = proxy_scope, options.except(:extend) end @@ -168,7 +171,13 @@ module ActiveRecord else with_scope :find => proxy_options, :create => proxy_options[:conditions].is_a?(Hash) ? proxy_options[:conditions] : {} do method = :new if method == :build - proxy_scope.send(method, *args, &block) + if current_scoped_methods_when_defined + with_scope current_scoped_methods_when_defined do + proxy_scope.send(method, *args, &block) + end + else + proxy_scope.send(method, *args, &block) + end end end end |