aboutsummaryrefslogtreecommitdiffstats
path: root/activerecord/lib/active_record/associations/association_proxy.rb
diff options
context:
space:
mode:
authorDavid Heinemeier Hansson <david@loudthinking.com>2005-11-03 09:06:42 +0000
committerDavid Heinemeier Hansson <david@loudthinking.com>2005-11-03 09:06:42 +0000
commit8c512a1caffa11d1522cef5d2a35e2888c608581 (patch)
tree4fc18e0b02824638eb87d815231f470b9523231a /activerecord/lib/active_record/associations/association_proxy.rb
parentf109bfb765fd54ef8bb94751c671a097089d7f53 (diff)
downloadrails-8c512a1caffa11d1522cef5d2a35e2888c608581.tar.gz
rails-8c512a1caffa11d1522cef5d2a35e2888c608581.tar.bz2
rails-8c512a1caffa11d1522cef5d2a35e2888c608581.zip
Added extension capabilities to has_many and has_and_belongs_to_many proxies [DHH]
git-svn-id: http://svn-commit.rubyonrails.org/rails/trunk@2861 5ecf4fe2-1ee6-0310-87b1-e25e094e27de
Diffstat (limited to 'activerecord/lib/active_record/associations/association_proxy.rb')
-rw-r--r--activerecord/lib/active_record/associations/association_proxy.rb7
1 files changed, 5 insertions, 2 deletions
diff --git a/activerecord/lib/active_record/associations/association_proxy.rb b/activerecord/lib/active_record/associations/association_proxy.rb
index c8d72c9f25..8245234854 100644
--- a/activerecord/lib/active_record/associations/association_proxy.rb
+++ b/activerecord/lib/active_record/associations/association_proxy.rb
@@ -2,7 +2,8 @@ module ActiveRecord
module Associations
class AssociationProxy #:nodoc:
alias_method :proxy_respond_to?, :respond_to?
- instance_methods.each { |m| undef_method m unless m =~ /(^__|^nil\?|^proxy_respond_to\?|^send)/ }
+ alias_method :proxy_extend, :extend
+ instance_methods.each { |m| undef_method m unless m =~ /(^__|^nil\?|^proxy_respond_to\?|^proxy_extend|^send)/ }
def initialize(owner, association_name, association_class_name, association_class_primary_key_name, options)
@owner = owner
@@ -11,6 +12,8 @@ module ActiveRecord
@association_class = eval(association_class_name, nil, __FILE__, __LINE__)
@association_class_primary_key_name = association_class_primary_key_name
+ proxy_extend(options[:extend]) if options[:extend]
+
reset
end
@@ -95,4 +98,4 @@ module ActiveRecord
end
end
end
-end
+end \ No newline at end of file