lib/active_support/vendor/builder/blankslate.rb in activesupport-1.3.1 vs lib/active_support/vendor/builder/blankslate.rb in activesupport-1.4.0
- old
+ new
@@ -12,29 +12,36 @@
# BlankSlate provides an abstract base class with no predefined
# methods (except for <tt>\_\_send__</tt> and <tt>\_\_id__</tt>).
# BlankSlate is useful as a base class when writing classes that
# depend upon <tt>method_missing</tt> (e.g. dynamic proxies).
- class BlankSlate #:nodoc:
+ class BlankSlate
class << self
+
+ # Hide the method named +name+ in the BlankSlate class. Don't
+ # hide +instance_eval+ or any method beginning with "__".
def hide(name)
- undef_method name if
- instance_methods.include?(name.to_s) and
- name !~ /^(__|instance_eval)/
+ undef_method name if
+ instance_methods.include?(name.to_s) and
+ name !~ /^(__|instance_eval)/
end
end
instance_methods.each { |m| hide(m) }
end
end
# Since Ruby is very dynamic, methods added to the ancestors of
# BlankSlate <em>after BlankSlate is defined</em> will show up in the
-# list of available BlankSlate methods. We handle this by defining a hook in the Object and Kernel classes that will hide any defined
+# list of available BlankSlate methods. We handle this by defining a
+# hook in the Object and Kernel classes that will hide any defined
module Kernel #:nodoc:
class << self
alias_method :blank_slate_method_added, :method_added
+
+ # Detect method additions to Kernel and remove them in the
+ # BlankSlate class.
def method_added(name)
blank_slate_method_added(name)
return if self != Kernel
Builder::BlankSlate.hide(name)
end
@@ -42,12 +49,15 @@
end
class Object #:nodoc:
class << self
alias_method :blank_slate_method_added, :method_added
+
+ # Detect method additions to Object and remove them in the
+ # BlankSlate class.
def method_added(name)
blank_slate_method_added(name)
- return if self != Object
+ return if self != Object
Builder::BlankSlate.hide(name)
end
end
end