collect all add functions at bottom (rename too)

This commit is contained in:
Torsten Ruger 2014-09-16 18:50:44 +03:00
parent 8b8a8eea56
commit 79e42003b2

View File

@ -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)