while compiles. jo

This commit is contained in:
Torsten Ruger 2014-05-14 12:02:54 +03:00
parent d50c38f5ad
commit d6b5d46165
5 changed files with 18 additions and 11 deletions

View File

@ -26,10 +26,15 @@ module Arm
end
def integer_load block , left , right
reg = "r#{left.register}".to_sym
block.add_code mov( :left => reg , :right => right )
block.add_code mov( :left => left , :right => right )
left
end
def integer_move block , left , right
block.add_code mov( :left => left , :right => right )
left
end
def string_load block , str_lit , reg
block.add_code add( :left => "r#{reg}".to_sym , :extra => str_lit ) #right is pc, implicit
#second arg is a hack to get the stringlength without coding

View File

@ -13,7 +13,6 @@ module Ast
call = Vm::CallSite.new( name , params , function)
call.load_args into
call.do_call into
call
end
def inspect

View File

@ -16,8 +16,7 @@ module Vm
if arg.is_a? IntegerConstant
Vm::Integer.new(index).load into , arg
else
raise "no #{arg.inspect}" if arg.register != index
#arg.load( into , index )
arg.move( into , index ) if arg.register != index
end
end
end

View File

@ -73,6 +73,11 @@ module Vm
def load block , right
CMachine.instance.integer_load block , self , right
end
def move block , right
CMachine.instance.integer_move block , self , right
end
end
end
require_relative "constants"

View File

@ -23,15 +23,14 @@ class TestRunner < MiniTest::Test
program = Vm::Program.new "Arm"
syntax = parser.parse_with_debug(string)
parts = Parser::Transform.new.apply(syntax)
# file is a list of expressions, al but the last must be a function
# file is a list of expressions, all but the last must be a function
# and the last is wrapped as a main
parts.each_with_index do |part,index|
if index = parts.length
expr = part.compile( program.context , nil )
program.main = expr
else
if index == (parts.length - 1)
expr = part.compile( program.context , program.main )
raise "should be function definition for now" unless expr.is_a? Function
else
expr = part.compile( program.context , nil )
raise "should be function definition for now" unless expr.is_a? Vm::Function
program.add_function expr
end
end