2016-12-10 18:06:57 +02:00
|
|
|
require_relative '../helper'
|
2015-10-15 09:47:11 +03:00
|
|
|
|
2017-01-03 22:37:25 +02:00
|
|
|
module Register
|
2017-01-15 14:44:23 +02:00
|
|
|
module SpaceHack
|
|
|
|
# test hack to in place change object type
|
|
|
|
def add_space_field(name,type)
|
|
|
|
class_type = Parfait.object_space.get_class_by_name(:Space).instance_type
|
|
|
|
class_type.send(:private_add_instance_variable, name , type)
|
|
|
|
end
|
|
|
|
end
|
2017-01-03 22:37:25 +02:00
|
|
|
module ExpressionHelper
|
2017-01-15 14:44:23 +02:00
|
|
|
include SpaceHack
|
2017-01-03 22:37:25 +02:00
|
|
|
|
|
|
|
def check
|
|
|
|
Register.machine.boot unless Register.machine.booted
|
2017-01-14 19:28:44 +02:00
|
|
|
compiler = Vm::MethodCompiler.new Parfait.object_space.get_main
|
|
|
|
code = Vm.ast_to_code @input
|
2017-01-03 22:37:25 +02:00
|
|
|
assert code.to_s , @input
|
|
|
|
produced = compiler.process( code )
|
|
|
|
assert @output , "No output given"
|
|
|
|
assert_equal produced.class , @output , "Wrong class"
|
|
|
|
produced
|
|
|
|
end
|
2017-01-03 22:18:41 +02:00
|
|
|
|
|
|
|
end
|
2015-10-15 09:47:11 +03:00
|
|
|
|
2017-01-03 22:37:25 +02:00
|
|
|
module Statements
|
|
|
|
include AST::Sexp
|
|
|
|
include Compiling
|
2017-01-15 14:44:23 +02:00
|
|
|
include SpaceHack
|
|
|
|
|
2017-01-03 22:37:25 +02:00
|
|
|
def setup
|
|
|
|
Register.machine.boot # force boot to reset main
|
|
|
|
end
|
2016-12-10 18:48:41 +02:00
|
|
|
|
2017-01-04 21:38:03 +02:00
|
|
|
def preamble
|
|
|
|
[Label, SlotToReg , LoadConstant, RegToSlot, LoadConstant,RegToSlot, LoadConstant, SlotToReg, SlotToReg ]
|
|
|
|
end
|
|
|
|
def postamble
|
|
|
|
[ Label, FunctionReturn]
|
|
|
|
end
|
|
|
|
def check_nil
|
2017-01-03 22:37:25 +02:00
|
|
|
assert @expect , "No output given"
|
2017-01-14 19:28:44 +02:00
|
|
|
compiler = Vm::MethodCompiler.new
|
|
|
|
code = Vm.ast_to_code( @input )
|
2017-01-03 22:37:25 +02:00
|
|
|
assert code.to_s , @input
|
|
|
|
produced = compiler.process( code )
|
|
|
|
produced = Parfait.object_space.get_main.instructions
|
|
|
|
compare_instructions produced , @expect
|
2017-01-04 21:38:03 +02:00
|
|
|
end
|
|
|
|
def check_return
|
|
|
|
was = check_nil
|
|
|
|
raise was if was
|
|
|
|
Parfait.object_space.get_main.instructions
|
2017-01-03 22:37:25 +02:00
|
|
|
end
|
2015-10-23 21:27:36 +03:00
|
|
|
|
2017-01-04 21:38:03 +02:00
|
|
|
def compare_instructions( instruction , expect )
|
2017-01-03 22:37:25 +02:00
|
|
|
index = 0
|
2017-01-04 21:38:03 +02:00
|
|
|
all = instruction.to_arr
|
|
|
|
full_expect = preamble + expect + postamble
|
|
|
|
full_expect = expect
|
2017-01-03 22:37:25 +02:00
|
|
|
begin
|
2017-01-04 21:38:03 +02:00
|
|
|
should = full_expect[index]
|
|
|
|
return "No instruction at #{index}" unless should
|
|
|
|
return "Expected at #{index+1}\n#{should(all)}" unless instruction.class == should
|
2017-01-03 22:37:25 +02:00
|
|
|
index += 1
|
|
|
|
instruction = instruction.next
|
|
|
|
end while( instruction )
|
2017-01-04 21:38:03 +02:00
|
|
|
nil
|
2017-01-03 22:37:25 +02:00
|
|
|
end
|
2017-01-04 21:38:03 +02:00
|
|
|
def should( all )
|
|
|
|
#preamble.each {all.shift}
|
|
|
|
#postamble.each {all.pop}
|
|
|
|
str = all.to_s.gsub("Register::","")
|
2017-01-03 22:37:25 +02:00
|
|
|
ret = ""
|
2017-01-04 21:38:03 +02:00
|
|
|
str.split(",").each_slice(6).each do |line|
|
2017-01-03 22:37:25 +02:00
|
|
|
ret += " " + line.join(",") + " ,\n"
|
|
|
|
end
|
|
|
|
ret
|
2015-11-02 20:11:40 +02:00
|
|
|
end
|
|
|
|
end
|
2015-10-15 09:47:11 +03:00
|
|
|
end
|