boot process 90 percent done

Creating the class and layout objects in the
right order was tricky, but  now mostly done
This commit is contained in:
Torsten Ruger 2015-05-23 12:15:06 +03:00
parent 94f49bf5c2
commit 1d9ef6d5c8
4 changed files with 36 additions and 35 deletions

View File

@ -19,37 +19,41 @@ module Virtual
values = [ "Value" , "Integer" , "Kernel" , "Object"].collect {|cl| Virtual.new_word(cl) } values = [ "Value" , "Integer" , "Kernel" , "Object"].collect {|cl| Virtual.new_word(cl) }
value_classes = values.collect { |cl| @space.create_class(cl) } value_classes = values.collect { |cl| @space.create_class(cl) }
rest = [ "Word", "Space", "Layout", "Module" , layouts = { "Word" => [] ,
"Class" , "Dictionary", "List"] "Space" => ["classes","objects"],
rest_layouts = { Virtual.new_word("Word") => [] , "Layout" => ["object_class"] ,
Virtual.new_word("Space") => ["classes","objects"], "Method" => ["name" , "arg_names" , "locals" , "tmps"] ,
Virtual.new_word("Layout") => ["object_class"] , "Module" => ["name","instance_methods", "super_class", "meta_class"],
Virtual.new_word("Module") => ["name","instance_methods", "super_class", "meta_class"], "Class" => ["object_layout"],
Virtual.new_word("Class") => ["object_layout"], "Dictionary" => ["keys" , "values"],
Virtual.new_word("Dictionary") => ["keys" , "values"], "List" => [] }
Virtual.new_word("List") => [] } # map from the vm - class_name to the Parfait class (which carries parfait name)
rest_classes = rest_layouts.collect { |cl , lay| @space.create_class(cl) } class_mappings = {}
rest_classes[1].set_super_class( value_classes[0] ) # #set superclass for object layouts.each do |name , layout|
rest_classes[3].set_super_class( value_classes[0] ) # and integer class_mappings[name] = @space.create_class(Virtual.new_word(name))
rest_classes.each do |cl| # and the rest end
cl.set_super_class(value_classes[3]) value_classes[1].set_super_class( value_classes[0] ) # #set superclass (value) for object
value_classes[3].set_super_class( value_classes[0] ) # and integer
class_mappings.each do |name , clazz| # and the rest
clazz.set_super_class(value_classes[3]) # superclasses are object
end end
# next create layouts by adding instance variable names to the layouts # next create layouts by adding instance variable names to the layouts
rest_classes.each do |cl| class_mappings.each do |name , clazz|
name = cl.name variables = layouts[name]
variables = rest_layouts[name]
variables.each do |var_name| variables.each do |var_name|
cl.object_layout.add_instance_variable Virtual.new_word(var_name) clazz.object_layout.add_instance_variable Virtual.new_word(var_name)
end end
end end
# now store the classes so we can hand them out later during object creation
# this can not be done earlier, as parfait objects are all the time created and would
# lookup half created class info
# but it must be done before going through the objects (next step)
@class_mappings = class_mappings
# now update the layout on all objects created so far, # now update the layout on all objects created so far,
# go through objects in space # go through objects in space
@space.objects.each do | o | @space.objects.each do | o |
vm_name = o.class.name.split("::").last o.init_layout
index = rest.index(vm_name)
raise "Class not found #{o.class}" unless index
o.set_layout rest_classes[index].object_layout
puts "index #{index}"
end end
# and go through the space instance variables which get created before the object list # and go through the space instance variables which get created before the object list
end end

View File

@ -38,7 +38,7 @@ module Virtual
@passes = [ "Virtual::SendImplementation" ] @passes = [ "Virtual::SendImplementation" ]
# @message = Message.new(the_end , the_end , "Object" ) # @message = Message.new(the_end , the_end , "Object" )
end end
attr_reader :message , :passes , :space , :init , :main attr_reader :message , :passes , :space , :init , :main , :class_mappings
def run_passes def run_passes
#TODO puts "INIT #{@init}" #TODO puts "INIT #{@init}"

View File

@ -6,23 +6,20 @@
module FakeMem module FakeMem
def initialize def initialize
if( self.class.name == "Parfait::Space")
puts "YES , I am SPACE"
end
@memory = [0,nil] @memory = [0,nil]
if Parfait::Space.object_space and Parfait::Space.object_space.objects if Parfait::Space.object_space and Parfait::Space.object_space.objects
Parfait::Space.object_space.add_object self Parfait::Space.object_space.add_object self
puts "got it #{self.class.name}"
else else
puts "it escaped #{self.class.name}" #TODO, must go through spce instance variables "by hand"
puts "fixme, no layout for #{self.class.name}"
end end
init_layout if Virtual::Machine.instance.class_mappings
end end
def init_layout def init_layout
class_name = self.class.name vm_name = self.class.name.split("::").last
puts "CLASS #{class_name}" clazz = Virtual::Machine.instance.class_mappings[vm_name]
puts "Check for #{class_name}" raise "Class not found #{vm_name}" unless clazz
cl = Parfait::Space.space.get_class(class_name) self.set_layout clazz.object_layout
puts "found #{cl}" if cl
end end
end end

View File

@ -23,7 +23,7 @@ module Virtual
# get the function from my class. easy peasy # get the function from my class. easy peasy
puts "Me is #{me.class}" puts "Me is #{me.class}"
method = me.get_class.get_instance_method(code.name) method = me.get_class.get_instance_method(code.name)
raise "Method not implemented #{clazz.name}.#{code.name}" unless method raise "Method not implemented #{me.class}.#{code.name}" unless method
new_codes << MethodCall.new( method ) new_codes << MethodCall.new( method )
else else
# note: this is the current view: call internal send, even the method name says else # note: this is the current view: call internal send, even the method name says else