2015-05-31 11:07:49 +03:00
|
|
|
module Virtual
|
|
|
|
|
2015-05-31 13:02:29 +03:00
|
|
|
# collect anything that is in the space but and reachable from init
|
2015-05-31 11:07:49 +03:00
|
|
|
class Collector
|
|
|
|
def run
|
2015-05-31 13:02:29 +03:00
|
|
|
# init= Parfait::Space.object_space.get_class_by_name("Kernel").get_instance_method "__init__"
|
2015-07-30 19:18:41 +03:00
|
|
|
Virtual.machine.objects.clear
|
|
|
|
keep Parfait::Space.object_space , 0
|
2015-05-31 11:07:49 +03:00
|
|
|
end
|
|
|
|
|
2015-07-30 19:18:41 +03:00
|
|
|
def keep object , depth
|
2015-05-31 13:02:29 +03:00
|
|
|
return if object.nil?
|
2015-07-30 19:18:41 +03:00
|
|
|
#puts "adding #{' ' * depth}:#{object.class}"
|
|
|
|
#puts "ADD #{object.first.class}, #{object.last.class}" if object.is_a? Array
|
2015-06-01 08:40:17 +03:00
|
|
|
return unless Virtual.machine.add_object object
|
2015-07-21 15:40:25 +03:00
|
|
|
return unless object.respond_to? :has_layout?
|
2015-06-01 08:33:23 +03:00
|
|
|
if( object.is_a? Parfait::Method)
|
2015-07-21 19:41:30 +03:00
|
|
|
object.source.constants.each{|c|
|
2015-07-30 19:18:41 +03:00
|
|
|
#puts "keeping constant #{c.class}:#{c.object_id}"
|
|
|
|
keep(c , depth + 1)
|
2015-07-21 19:41:30 +03:00
|
|
|
}
|
2015-06-01 08:33:23 +03:00
|
|
|
end
|
2015-05-31 13:02:29 +03:00
|
|
|
layout = object.get_layout
|
2015-07-30 19:18:41 +03:00
|
|
|
keep(layout , depth + 1)
|
2015-07-21 15:40:25 +03:00
|
|
|
layout.object_instance_names.each do |name|
|
2015-08-06 18:27:25 +03:00
|
|
|
#puts "Keep #{name}"
|
2015-07-21 19:41:30 +03:00
|
|
|
inst = object.get_instance_variable name
|
2015-07-30 19:18:41 +03:00
|
|
|
keep(inst , depth + 1)
|
2015-05-31 11:07:49 +03:00
|
|
|
end
|
|
|
|
if object.is_a? Parfait::List
|
|
|
|
object.each do |item|
|
2015-08-06 18:27:25 +03:00
|
|
|
#puts "Keep item "
|
2015-07-30 19:18:41 +03:00
|
|
|
keep(item , depth + 1)
|
2015-05-31 11:07:49 +03:00
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|