object_and_class.rb 1.7 KB
Newer Older
1
class Object #:nodoc:
2 3 4 5
  def remove_subclasses_of(*superclasses)
    subclasses_of(*superclasses).each do |subclass|
      Object.send(:remove_const, subclass.to_s) rescue nil
    end
6
  end
7
  
8
  def subclasses_of(*superclasses)
9 10
    subclasses = []
    ObjectSpace.each_object(Class) do |k|
11 12
      next if (k.ancestors & superclasses).empty? || superclasses.include?(k) || k.to_s.include?("::") || subclasses.include?(k)
      subclasses << k
13 14 15
    end
    subclasses
  end
16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35
  
  def extended_by
    ancestors = class << self; ancestors end
    ancestors.select { |mod| mod.class == Module } - [ Object, Kernel ]
  end
  
  def copy_instance_variables_from(object, exclude = [])
    exclude += object.protected_instance_variables if
      object.respond_to? :protected_instance_variables
    
    instance_variables = object.instance_variables - exclude.map { |name| name.to_s }
    instance_variables.each do |name|
      instance_variable_set name, object.instance_variable_get(name)
    end
  end
  
  def extend_with_included_modules_from(object)
    object.extended_by.each { |mod| extend mod }
  end
  
36
  # "", "   ", nil, [], and {} are blank
37
  def blank?
38
    if respond_to?(:empty?) && respond_to?(:strip)
39 40
      empty? or strip.empty?
    elsif respond_to?(:empty?)
41 42 43 44 45
      empty?
    else
      !self
    end
  end
46

47 48 49 50 51 52
  def suppress(*exception_classes)
    begin yield
    rescue Exception => e
      raise unless exception_classes.any? {|cls| e.kind_of? cls}
    end
  end
53 54 55 56
  
  def with_options(options)
    yield ActiveSupport::OptionMerger.new(self, options)
  end
57 58 59 60 61 62 63 64
end

class Class #:nodoc:
  def remove_subclasses
    Object.remove_subclasses_of(self)
  end

  def subclasses
65
    Object.subclasses_of(self).map { |o| o.to_s }
66 67
  end
end