aboutsummaryrefslogtreecommitdiffstats
path: root/activesupport/lib/active_support/core_ext/object_and_class.rb
diff options
context:
space:
mode:
authorDavid Heinemeier Hansson <david@loudthinking.com>2005-07-07 14:48:16 +0000
committerDavid Heinemeier Hansson <david@loudthinking.com>2005-07-07 14:48:16 +0000
commit703ac4c5ac68f68b48debd1bfc352cd687b2df30 (patch)
tree8606fe9c0f52beabf8b17decd79c39dcae9e0ad7 /activesupport/lib/active_support/core_ext/object_and_class.rb
parentb640a647603f869eca5cbecce3dbc94cb47447ad (diff)
downloadrails-703ac4c5ac68f68b48debd1bfc352cd687b2df30.tar.gz
rails-703ac4c5ac68f68b48debd1bfc352cd687b2df30.tar.bz2
rails-703ac4c5ac68f68b48debd1bfc352cd687b2df30.zip
Added more efficient implementation of the development mode reset of classes #1638 [Chris McGrath]
git-svn-id: http://svn-commit.rubyonrails.org/rails/trunk@1761 5ecf4fe2-1ee6-0310-87b1-e25e094e27de
Diffstat (limited to 'activesupport/lib/active_support/core_ext/object_and_class.rb')
-rw-r--r--activesupport/lib/active_support/core_ext/object_and_class.rb18
1 files changed, 9 insertions, 9 deletions
diff --git a/activesupport/lib/active_support/core_ext/object_and_class.rb b/activesupport/lib/active_support/core_ext/object_and_class.rb
index bd67b3d1fa..4ad13265d7 100644
--- a/activesupport/lib/active_support/core_ext/object_and_class.rb
+++ b/activesupport/lib/active_support/core_ext/object_and_class.rb
@@ -1,9 +1,9 @@
class Object #:nodoc:
- def remove_subclasses_of(superclass)
- subclasses_of(superclass).each do |subclass|
- # remove_instance_variables_of(klass)
- Object.send(:remove_const, subclass) rescue nil
- end
+ def remove_subclasses_of(*superclasses)
+ subclasses_of(*superclasses).each do |subclass|
+ subclass.instance_variables.each { |v| subclass.send(:remove_instance_variable, v) }
+ Object.send(:remove_const, subclass.to_s) rescue nil
+ end
end
def remove_instance_variables_of(klass)
@@ -14,11 +14,11 @@ class Object #:nodoc:
end
end
- def subclasses_of(superclass)
+ def subclasses_of(*superclasses)
subclasses = []
ObjectSpace.each_object(Class) do |k|
- next if !k.ancestors.include?(superclass) || superclass == k || k.to_s.include?("::") || subclasses.include?(k.to_s)
- subclasses << k.to_s
+ next if (k.ancestors & superclasses).empty? || superclasses.include?(k) || k.to_s.include?("::") || subclasses.include?(k)
+ subclasses << k
end
subclasses
end
@@ -50,6 +50,6 @@ class Class #:nodoc:
end
def subclasses
- Object.subclasses_of(self)
+ Object.subclasses_of(self).map { |o| o.to_s }
end
end