2018-03-15 20:51:46 +05:30
|
|
|
require_relative '../helper'
|
|
|
|
|
|
|
|
module Risc
|
|
|
|
|
|
|
|
module Statements
|
|
|
|
include AST::Sexp
|
|
|
|
include CleanCompile
|
|
|
|
|
|
|
|
def setup
|
|
|
|
Risc.machine.boot # force boot to reset main
|
|
|
|
end
|
|
|
|
|
|
|
|
def preamble
|
|
|
|
[Label, LoadConstant, SlotToReg, RegToSlot ]
|
|
|
|
end
|
|
|
|
def postamble
|
|
|
|
[ Label, FunctionReturn]
|
|
|
|
end
|
2018-03-16 20:25:01 +05:30
|
|
|
# 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
|
2018-03-17 11:13:44 +05:30
|
|
|
def produce_body
|
|
|
|
produced = produce_instructions
|
|
|
|
preamble.each{ produced = produced.next }
|
|
|
|
produced
|
|
|
|
end
|
|
|
|
def produce_instructions
|
2018-03-15 20:51:46 +05:30
|
|
|
assert @expect , "No output given"
|
2018-03-19 13:30:14 +05:30
|
|
|
Vool::VoolCompiler.ruby_to_vool "class Test; def main(arg);#{@input};end;end"
|
|
|
|
test = Parfait.object_space.get_class_by_name :Test
|
|
|
|
test.instance_type.get_method( :main).instructions
|
2018-03-17 11:13:44 +05:30
|
|
|
end
|
|
|
|
def check_nil
|
|
|
|
produced = produce_instructions
|
2018-03-15 20:51:46 +05:30
|
|
|
compare_instructions produced , @expect
|
|
|
|
end
|
|
|
|
def check_return
|
|
|
|
was = check_nil
|
|
|
|
raise was if was
|
2018-03-19 13:30:14 +05:30
|
|
|
test = Parfait.object_space.get_class_by_name :Test
|
|
|
|
test.instance_type.get_method :main
|
2018-03-15 20:51:46 +05:30
|
|
|
end
|
2018-03-17 11:13:44 +05:30
|
|
|
def real_index(index)
|
2018-03-19 13:05:08 +05:30
|
|
|
index - preamble.length
|
2018-03-17 11:13:44 +05:30
|
|
|
end
|
2018-03-15 20:51:46 +05:30
|
|
|
def compare_instructions( instruction , expect )
|
|
|
|
index = 0
|
|
|
|
all = instruction.to_arr
|
|
|
|
full_expect = preamble + expect + postamble
|
|
|
|
#full_expect = expect
|
|
|
|
begin
|
|
|
|
should = full_expect[index]
|
2018-03-19 13:05:08 +05:30
|
|
|
return "No instruction at #{real_index(index)}\n#{should(all)}" unless should
|
2018-03-17 11:13:44 +05:30
|
|
|
return "Expected at #{real_index(index)}\n#{should(all)} was #{instruction.to_s}" unless instruction.class == should
|
|
|
|
#puts instruction.to_s if (index > preamble.length) and (index + postamble.length <= full_expect.length)
|
2018-03-15 20:51:46 +05:30
|
|
|
index += 1
|
|
|
|
instruction = instruction.next
|
|
|
|
end while( instruction )
|
|
|
|
nil
|
|
|
|
end
|
|
|
|
def should( all )
|
|
|
|
preamble.each {all.shift}
|
|
|
|
postamble.each {all.pop}
|
|
|
|
str = all.to_s.gsub("Risc::","")
|
|
|
|
ret = ""
|
|
|
|
str.split(",").each_slice(6).each do |line|
|
|
|
|
ret += " " + line.join(",") + " ,\n"
|
|
|
|
end
|
|
|
|
ret
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|