basic assembly frame

This commit is contained in:
Torsten Ruger 2014-08-26 22:35:56 +03:00
parent 8f9bbe2f1d
commit 97f68a1a54
3 changed files with 71 additions and 40 deletions

View File

@ -17,6 +17,24 @@ module Register
link_object(@space , 0)
end
def assemble
link
@stream = StringIO.new
assemble_object( @space )
puts "leng #{@stream.length}"
end
def assemble_object object
slot = @objects[object.object_id]
raise "No slot for #{object_id}" unless slot
if object.is_a? Instruction
object.assemble( @stream , self )
else
clazz = object.class.name.split("::").last
len = send("assemble_#{clazz}".to_sym , object)
end
end
def link_object(object , at)
slot = @objects[object.object_id]
unless slot
@ -24,11 +42,11 @@ module Register
@objects[object.object_id] = slot
end
if object.is_a? Instruction
len = 4
else
clazz = object.class.name.split("::").last
len = send("link_#{clazz}".to_sym , object , at)
else
len = 4
end
end
slot.length = len
len
end
@ -38,9 +56,22 @@ module Register
space.classes.values.each do |cl|
len += link_object(cl , at + len)
end
space.objects.each do |o|
len += link_object(o , at + len)
end
len
end
def assemble_BootSpace(space)
# assemble in the same order as linked
space.classes.values.each do |cl|
assemble_object(cl)
end
space.objects.each do |o|
assemble_object(o)
end
end
def link_BootClass(clazz , at)
len = link_object(clazz.name , at)
len += link_object(clazz.super_class_name , at + len)
@ -50,14 +81,29 @@ module Register
len
end
def assemble_BootClass(clazz)
assemble_object(clazz.name)
assemble_object(clazz.super_class_name)
clazz.instance_methods.each do |meth|
assemble_object(meth)
end
end
def link_MethodDefinition(method , at)
len = link_object method.name ,at
method.blocks.each do |block|
link_object( block , at + len)
len += link_object( block , at + len)
end
len
end
def assemble_MethodDefinition(method)
assemble_object(method.name)
method.blocks.each do |block|
assemble_object(block)
end
end
def link_Block(block , at)
len = 0
block.codes.each do |code|
@ -66,14 +112,34 @@ module Register
len
end
def assemble_Block(block)
block.codes.each do |code|
assemble_object(code)
end
end
def link_String( str , at)
return (str.length / 4) + 1 + 2
end
def assemble_String( str )
@stream.write str
end
def link_Symbol(sym , at)
return link_String(sym.to_s , at)
end
def assemble_Symbol(sym)
return assemble_String(sym.to_s)
end
def link_StringConstant( sc , at)
return link_String(sc.string,at)
end
def assemble_StringConstant( sc)
return assemble_String(sc.string)
end
end
Sof::Volotile.add(Register::Assembler , [:objects])

View File

@ -102,40 +102,5 @@ module Virtual
end
c
end
# linking entry , exit , main , classes , objects
def link_at( start , context)
super
@entry.link_at( start , context )
start += @entry.length
@exit.link_at( start , context)
start += @exit.length
@main.link_at( start , context )
start += @main.length
@classes.values.each do |clazz|
clazz.link_at(start , context)
start += clazz.length
end
@objects.each do |o|
o.link_at(start , context)
start += o.length
end
end
# assemble in the same order as linked
def assemble( io )
link_at( @position , nil) #second link in case of forward declarations
@entry.assemble( io )
@exit.assemble( io )
@main.assemble( io )
@classes.values.each do |clazz|
clazz.assemble(io)
end
@objects.each do |o|
o.assemble(io)
end
io
end
end
end

View File

@ -9,7 +9,7 @@ class HelloTest < MiniTest::Test
puts ""
Virtual::BootSpace.space.run_passes
ass = Register::Assembler.new(Virtual::BootSpace.space)
ass.link
ass.assemble
puts Sof::Writer.write(expressions)
# puts Sof::Writer.write(Virtual::BootSpace.space)
end