move fix_types in order of usage

This commit is contained in:
Torsten Ruger 2016-12-31 14:54:34 +02:00
parent 853a531578
commit 838aba470d

View File

@ -50,6 +50,7 @@ module Register
# - flesh out the types , create the real space # - flesh out the types , create the real space
# - and finally load the methods # - and finally load the methods
def boot_parfait! def boot_parfait!
Parfait.set_object_space( nil )
types = boot_types types = boot_types
boot_boot_space( types ) boot_boot_space( types )
classes = boot_classes( types ) classes = boot_classes( types )
@ -89,17 +90,6 @@ module Register
Parfait.set_object_space( boot_space ) Parfait.set_object_space( boot_space )
end end
# Types are hollow shells before this, so we need to set the object_class
# and initialize the list variables (which we now can with .new)
def fix_types(types , classes)
type_names.each do |name , ivars |
type = types[name]
clazz = classes[name]
type.set_object_class( clazz )
type.init_lists({:type => :Type }.merge(ivars))
end
end
# when running code instantiates a class, a type is created automatically # when running code instantiates a class, a type is created automatically
# but even to get our space up, we have already instantiated all types # but even to get our space up, we have already instantiated all types
# so we have to continue and allocate classes and fill the data by hand # so we have to continue and allocate classes and fill the data by hand
@ -113,6 +103,17 @@ module Register
classes classes
end end
# Types are hollow shells before this, so we need to set the object_class
# and initialize the list variables (which we now can with .new)
def fix_types(types , classes)
type_names.each do |name , ivars |
type = types[name]
clazz = classes[name]
type.set_object_class( clazz )
type.init_lists({:type => :Type }.merge(ivars))
end
end
# superclasses other than default object # superclasses other than default object
def super_class_names def super_class_names
{ :Object => :Kernel , :Kernel => :Value , :Integer => :Value , :BinaryCode => :Word } { :Object => :Kernel , :Kernel => :Value , :Integer => :Value , :BinaryCode => :Word }