collect all add functions at bottom (rename too)
This commit is contained in:
parent
8b8a8eea56
commit
79e42003b2
@ -19,14 +19,16 @@ module Register
|
|||||||
attr_reader :objects
|
attr_reader :objects
|
||||||
|
|
||||||
def link
|
def link
|
||||||
collect_object(@space)
|
add_object(@space)
|
||||||
at = 4
|
at = 4 # first jump instruction
|
||||||
@objects.each do |id , objekt|
|
# then all functions
|
||||||
|
@objects.each_value do | objekt|
|
||||||
next unless objekt.is_a? Virtual::CompiledMethod
|
next unless objekt.is_a? Virtual::CompiledMethod
|
||||||
objekt.set_position(at)
|
objekt.set_position(at)
|
||||||
at += objekt.mem_length
|
at += objekt.mem_length
|
||||||
end
|
end
|
||||||
@objects.each do |id , objekt|
|
#and then all data object
|
||||||
|
@objects.each_value do | objekt|
|
||||||
next if objekt.is_a? Virtual::CompiledMethod
|
next if objekt.is_a? Virtual::CompiledMethod
|
||||||
objekt.set_position at
|
objekt.set_position at
|
||||||
at += objekt.mem_length
|
at += objekt.mem_length
|
||||||
@ -41,11 +43,11 @@ module Register
|
|||||||
initial_jump = RegisterMachine.instance.b( main )
|
initial_jump = RegisterMachine.instance.b( main )
|
||||||
initial_jump.set_position( 0)
|
initial_jump.set_position( 0)
|
||||||
initial_jump.assemble( @stream )
|
initial_jump.assemble( @stream )
|
||||||
@objects.each do |id , objekt|
|
@objects.each_value do |objekt|
|
||||||
next unless objekt.is_a? Virtual::CompiledMethod
|
next unless objekt.is_a? Virtual::CompiledMethod
|
||||||
assemble_object( objekt )
|
assemble_object( objekt )
|
||||||
end
|
end
|
||||||
@objects.each do |id , objekt|
|
@objects.each_value do | objekt|
|
||||||
next if objekt.is_a? Virtual::CompiledMethod
|
next if objekt.is_a? Virtual::CompiledMethod
|
||||||
assemble_object( objekt )
|
assemble_object( objekt )
|
||||||
end
|
end
|
||||||
@ -53,14 +55,6 @@ module Register
|
|||||||
return @stream.string
|
return @stream.string
|
||||||
end
|
end
|
||||||
|
|
||||||
def collect_object(object)
|
|
||||||
return object.mem_length if @objects[object.object_id]
|
|
||||||
@objects[object.object_id] = object
|
|
||||||
collect_object(object.layout[:names])
|
|
||||||
clazz = object.class.name.split("::").last
|
|
||||||
send("collect_#{clazz}".to_sym , object)
|
|
||||||
end
|
|
||||||
|
|
||||||
def assemble_object obj
|
def assemble_object obj
|
||||||
puts "Assemble #{obj.class}(#{obj.object_id}) at stream #{(@stream.length).to_s(16)} pos:#{obj.position.to_s(16)} , len:#{obj.mem_length}"
|
puts "Assemble #{obj.class}(#{obj.object_id}) at stream #{(@stream.length).to_s(16)} pos:#{obj.position.to_s(16)} , len:#{obj.mem_length}"
|
||||||
raise "Assemble #{obj.class} at #{@stream.length.to_s(16)} not #{obj.position.to_s(16)}" if @stream.length != obj.position
|
raise "Assemble #{obj.class} at #{@stream.length.to_s(16)} not #{obj.position.to_s(16)}" if @stream.length != obj.position
|
||||||
@ -93,14 +87,6 @@ module Register
|
|||||||
object.position
|
object.position
|
||||||
end
|
end
|
||||||
|
|
||||||
def collect_Array( array )
|
|
||||||
# also array has constant overhead, the padded helper fixes it to multiple of 8
|
|
||||||
array.each do |elem|
|
|
||||||
collect_object(elem)
|
|
||||||
end
|
|
||||||
padded_words(array.length)
|
|
||||||
end
|
|
||||||
|
|
||||||
def assemble_Array array
|
def assemble_Array array
|
||||||
type = type_word(array)
|
type = type_word(array)
|
||||||
@stream.write_uint32( type )
|
@stream.write_uint32( type )
|
||||||
@ -112,41 +98,19 @@ module Register
|
|||||||
array.position
|
array.position
|
||||||
end
|
end
|
||||||
|
|
||||||
def collect_Hash( hash )
|
|
||||||
#hook the key/values arrays into the layout (just because it was around)
|
|
||||||
collect_object(hash.keys)
|
|
||||||
collect_object(hash.values)
|
|
||||||
padded_words(2)
|
|
||||||
end
|
|
||||||
|
|
||||||
def assemble_Hash hash
|
def assemble_Hash hash
|
||||||
# so here we can be sure to have _identical_ keys/values arrays
|
# so here we can be sure to have _identical_ keys/values arrays
|
||||||
assemble_self( hash , [ hash.layout[:keys] , hash.layout[:values] ] )
|
assemble_self( hash , [ hash.layout[:keys] , hash.layout[:values] ] )
|
||||||
end
|
end
|
||||||
|
|
||||||
def collect_BootSpace(space)
|
|
||||||
collect_object(space.classes)
|
|
||||||
collect_object(space.objects)
|
|
||||||
end
|
|
||||||
|
|
||||||
def assemble_BootSpace(space)
|
def assemble_BootSpace(space)
|
||||||
assemble_self(space , [space.classes,space.objects] )
|
assemble_self(space , [space.classes,space.objects] )
|
||||||
end
|
end
|
||||||
|
|
||||||
def collect_BootClass(clazz)
|
|
||||||
collect_object(clazz.name )
|
|
||||||
collect_object(clazz.super_class_name)
|
|
||||||
collect_object(clazz.instance_methods)
|
|
||||||
end
|
|
||||||
|
|
||||||
def assemble_BootClass(clazz)
|
def assemble_BootClass(clazz)
|
||||||
assemble_self( clazz , [clazz.name , clazz.super_class_name, clazz.instance_methods] )
|
assemble_self( clazz , [clazz.name , clazz.super_class_name, clazz.instance_methods] )
|
||||||
end
|
end
|
||||||
|
|
||||||
def collect_CompiledMethod(method)
|
|
||||||
end
|
|
||||||
|
|
||||||
|
|
||||||
def assemble_CompiledMethod(method)
|
def assemble_CompiledMethod(method)
|
||||||
count = method.blocks.inject(0) { |c , block| c += block.length }
|
count = method.blocks.inject(0) { |c , block| c += block.length }
|
||||||
word = (count+7) / 32 # all object are multiple of 8 words (7 for header)
|
word = (count+7) / 32 # all object are multiple of 8 words (7 for header)
|
||||||
@ -164,15 +128,6 @@ module Register
|
|||||||
pad_after( count )
|
pad_after( count )
|
||||||
end
|
end
|
||||||
|
|
||||||
def collect_String( str)
|
|
||||||
end
|
|
||||||
|
|
||||||
def collect_Symbol(sym)
|
|
||||||
end
|
|
||||||
|
|
||||||
def collect_StringConstant(sc)
|
|
||||||
end
|
|
||||||
|
|
||||||
def assemble_String( str )
|
def assemble_String( str )
|
||||||
str = str.string if str.is_a? Virtual::StringConstant
|
str = str.string if str.is_a? Virtual::StringConstant
|
||||||
str = str.to_s if str.is_a? Symbol
|
str = str.to_s if str.is_a? Symbol
|
||||||
@ -195,10 +150,45 @@ module Register
|
|||||||
return assemble_String(sc)
|
return assemble_String(sc)
|
||||||
end
|
end
|
||||||
|
|
||||||
def position_for object
|
def add_object(object)
|
||||||
s = get_slot(object)
|
return if @objects[object.object_id]
|
||||||
s.position
|
@objects[object.object_id] = object
|
||||||
|
add_object(object.layout[:names])
|
||||||
|
clazz = object.class.name.split("::").last
|
||||||
|
send("add_#{clazz}".to_sym , object)
|
||||||
end
|
end
|
||||||
|
|
||||||
|
def add_Array( array )
|
||||||
|
# also array has constant overhead, the padded helper fixes it to multiple of 8
|
||||||
|
array.each do |elem|
|
||||||
|
add_object(elem)
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
def add_Hash( hash )
|
||||||
|
add_object(hash.keys)
|
||||||
|
add_object(hash.values)
|
||||||
|
end
|
||||||
|
|
||||||
|
def add_BootSpace(space)
|
||||||
|
add_object(space.classes)
|
||||||
|
add_object(space.objects)
|
||||||
|
end
|
||||||
|
|
||||||
|
def add_BootClass(clazz)
|
||||||
|
add_object(clazz.name )
|
||||||
|
add_object(clazz.super_class_name)
|
||||||
|
add_object(clazz.instance_methods)
|
||||||
|
end
|
||||||
|
def add_CompiledMethod(method)
|
||||||
|
end
|
||||||
|
def add_String( str)
|
||||||
|
end
|
||||||
|
def add_Symbol(sym)
|
||||||
|
end
|
||||||
|
def add_StringConstant(sc)
|
||||||
|
end
|
||||||
|
|
||||||
private
|
private
|
||||||
|
|
||||||
# write means we write the resulting address straight into the assembler stream (ie don't return it)
|
# write means we write the resulting address straight into the assembler stream (ie don't return it)
|
||||||
|
Loading…
x
Reference in New Issue
Block a user