shuffling and rename dummy

This commit is contained in:
Torsten Ruger 2015-07-28 16:18:32 +03:00
parent 36f635f7c1
commit 5fd04ee0c5
3 changed files with 39 additions and 28 deletions

View File

@ -12,7 +12,7 @@ module Virtual
def initialize(name , method ) def initialize(name , method )
super() super()
@method = method @method = method
raise "Method is not Method, but #{method.class}" unless method == :dummy or method.is_a?(Parfait::Method) raise "Method is not Method, but #{method.class}" unless method == :__init__ or method.is_a?(Parfait::Method)
@name = name.to_sym @name = name.to_sym
@branch = nil @branch = nil
@codes = [] @codes = []

View File

@ -6,9 +6,9 @@ module Virtual
# The general idea is that compiling is creating an object graph. Functionally # The general idea is that compiling is creating an object graph. Functionally
# one tends to think of methods, and that is complicated enough, sure. # one tends to think of methods, and that is complicated enough, sure.
# but for an object system the graph includes classes and all instance variables # But for an object system the graph includes classes and all instance variables
# #
# And so we have a chicken and egg problem. At the end of the function we want to have a # And so we have a chicken and egg problem. At the end of the boot function we want to have a
# working Space object # working Space object
# But that has instance variables (List and Dictionary) and off course a class. # But that has instance variables (List and Dictionary) and off course a class.
# Or more precisely in salama, a Layout, that points to a class. # Or more precisely in salama, a Layout, that points to a class.
@ -16,20 +16,27 @@ module Virtual
# #
# The way out is to build empty shell objects and stuff the neccessary data into them # The way out is to build empty shell objects and stuff the neccessary data into them
# (not use the normal initialize way) # (not use the normal initialize way)
# # (PPS: The "real" solution is to read a sof graph and not do this by hand
# That graph can be programatically built and written (with this to boot that process :-))
# There are some helpers below, but the roadmap is something like: # There are some helpers below, but the roadmap is something like:
# - create all the layouts, with thier layouts, but no classes # - create all the layouts, with thier layouts, but no classes
# - create a space by "hand" , using allocate, not new # - create a space by "hand" , using allocate, not new
# - create the class objects and assign them to the layouts # - create the class objects and assign them to the layouts
def boot_space def boot_parfait!
space_dict = object_with_layout Parfait::Dictionary boot_layouts
space_dict.keys = object_with_layout Parfait::List boot_space
space_dict.values = object_with_layout Parfait::List boot_classes
@space = object_with_layout Parfait::Space @space.late_init
@space.classes = space_dict
Parfait::Space.set_object_space @space #puts Sof.write(@space)
boot_functions!
end end
# layouts is where the snake bites its tail. Every chain end at a layout and then it
# goes around (circular references). We create them from the list below and keep them
# in an instance variable (that is a smell, because after booting it is not needed)
def boot_layouts def boot_layouts
@layouts = {} @layouts = {}
layout_names.each do |name , ivars | layout_names.each do |name , ivars |
@ -41,11 +48,23 @@ module Virtual
end end
end end
# once we have the layouts we can create the space by creating the instance variables
# by hand (can't call new yet as that uses the space)
def boot_space
space_dict = object_with_layout Parfait::Dictionary
space_dict.keys = object_with_layout Parfait::List
space_dict.values = object_with_layout Parfait::List
@space = object_with_layout Parfait::Space
@space.classes = space_dict
Parfait::Space.set_object_space @space
end
# when running code instantiates a class, a layout is created automatically
# but even to get our space up, we have already instantiated all layouts
# so we have to continue and allocate classes and fill the data by hand
# and off cource we can't use space.create_class , but still they need to go there
def boot_classes def boot_classes
# when running code instantiates a class, a layout is created automatically
# but even to get our space up, we have already instantiated all layouts
# so we have to continue and allocate classes and fill the data by hand
# and off cource we can't use space.create_class , but still they need to go there
classes = space.classes classes = space.classes
layout_names.each do |name , vars| layout_names.each do |name , vars|
cl = object_with_layout Parfait::Class cl = object_with_layout Parfait::Class
@ -72,17 +91,6 @@ module Virtual
end end
end end
def boot_parfait!
boot_layouts
boot_space
boot_classes
@space.late_init
#puts Sof.write(@space)
boot_functions!
end
# helper to create a Layout, name is the parfait name, ie :Layout # helper to create a Layout, name is the parfait name, ie :Layout
def layout_for( name , ivars ) def layout_for( name , ivars )
l = Parfait::Layout.allocate.fake_init l = Parfait::Layout.allocate.fake_init
@ -101,6 +109,9 @@ module Virtual
o o
end end
# the function really just returns a constant (just avoiding the constant)
# unfortuantely that constant condenses every detail about the system, class names
# and all instance variable names. Really have to find a better way
def layout_names def layout_names
{ :Word => [] , { :Word => [] ,
:List => [] , :List => [] ,
@ -138,7 +149,7 @@ module Virtual
obj.add_instance_method Register::Builtin::Object.send(f , nil) obj.add_instance_method Register::Builtin::Object.send(f , nil)
end end
obj = @space.get_class_by_name(:Kernel) obj = @space.get_class_by_name(:Kernel)
# create dummy main first, __init__ calls it # create __init__ main first, __init__ calls it
[:exit,:__send , :__init__ ].each do |f| [:exit,:__send , :__init__ ].each do |f|
obj.add_instance_method Register::Builtin::Kernel.send(f , nil) obj.add_instance_method Register::Builtin::Kernel.send(f , nil)
end end

View File

@ -123,7 +123,7 @@ module Virtual
return self return self
end end
boot_parfait! boot_parfait!
@init = Block.new("init", :dummy ) @init = Block.new("init", :__init__ )
@init.add_code Virtual::VirtualMain.new( self.space.get_init ) @init.add_code Virtual::VirtualMain.new( self.space.get_init )
@booted = true @booted = true
self self