rubyx/lib/risc/collector.rb
Torsten Ruger 4a88f342d3 random checkin
still suffering -1 trauma
2018-05-14 12:38:44 +03:00

56 lines
1.7 KiB
Ruby

module Risc
# collect anything that is in the space but and reachable from init
module Collector
def self.collect_space
@objects = {}
keep Parfait.object_space , 0
Risc.machine.constants.each {|obj| keep(obj,0)}
@objects
end
def self.keep( object , depth )
return if object.nil?
return unless add_object( object , depth )
return unless object.respond_to? :has_type?
type = object.get_type
keep(type , depth + 1)
return if object.is_a? Symbol
type.names.each do |name|
keep(name , depth + 1)
inst = object.get_instance_variable name
keep(inst , depth + 1)
end
if object.is_a? Parfait::List
object.each do |item|
keep(item , depth + 1)
end
end
end
# Objects are data and get assembled after functions
def self.add_object( objekt , depth)
return false if @objects[objekt.object_id]
return true if objekt.is_a? Fixnum
return true if objekt.is_a?( Risc::Label)
#puts message(objekt , depth)
#puts "ADD #{objekt.inspect}, #{objekt.name}" if objekt.is_a? Parfait::TypedMethod
unless objekt.is_a?( Parfait::Object) or objekt.is_a?( Symbol)
raise "adding non parfait #{objekt.class}:#{objekt}"
end
#raise "Method #{objekt.name}" if objekt.is_a? Parfait::TypedMethod
@objects[objekt.object_id] = objekt
true
end
def self.message(object , depth)
msg = "adding #{depth}#{' ' * depth}:"
if( object.respond_to?(:rxf_reference_name))
msg + object.rxf_reference_name.to_s
else
msg + object.class.name
end
end
end
end