2015-10-22 14:34:47 +02:00
|
|
|
require_relative "helper"
|
|
|
|
|
|
|
|
class AddTest < MiniTest::Test
|
|
|
|
include Ticker
|
|
|
|
include AST::Sexp
|
|
|
|
|
|
|
|
def test_if
|
|
|
|
@string_input = <<HERE
|
|
|
|
class Object
|
|
|
|
int itest(int n)
|
|
|
|
if_zero( n - 12)
|
|
|
|
"then".putstring()
|
|
|
|
else
|
|
|
|
"else".putstring()
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
int main()
|
|
|
|
itest(20)
|
|
|
|
end
|
|
|
|
end
|
|
|
|
HERE
|
2015-10-22 17:16:29 +02:00
|
|
|
machine = Register.machine.boot
|
2015-10-22 14:34:47 +02:00
|
|
|
syntax = Parser::Salama.new.parse_with_debug(@string_input)
|
|
|
|
parts = Parser::Transform.new.apply(syntax)
|
|
|
|
#puts parts.inspect
|
2015-10-23 13:22:55 +02:00
|
|
|
Soml::Compiler.compile( parts )
|
2015-10-22 14:34:47 +02:00
|
|
|
machine.collect
|
2015-10-22 17:16:29 +02:00
|
|
|
# statements = Register.machine.boot.parse_and_compile @string_input
|
2015-10-23 13:22:55 +02:00
|
|
|
# Soml::Compiler.compile( statements , Register.machine.space.get_main )
|
2015-10-22 14:34:47 +02:00
|
|
|
@interpreter = Interpreter::Interpreter.new
|
2015-10-22 17:16:29 +02:00
|
|
|
@interpreter.start Register.machine.init
|
2015-10-22 14:34:47 +02:00
|
|
|
#show_ticks # get output of what is
|
|
|
|
["Branch","LoadConstant","GetSlot","SetSlot","RegisterTransfer",
|
|
|
|
"FunctionCall","SaveReturn","GetSlot","GetSlot","SetSlot",
|
|
|
|
"LoadConstant","SetSlot","LoadConstant","SetSlot","RegisterTransfer",
|
|
|
|
"FunctionCall","SaveReturn","GetSlot","LoadConstant","OperatorInstruction",
|
|
|
|
"IsZero","GetSlot","LoadConstant","SetSlot","LoadConstant",
|
|
|
|
"SetSlot","RegisterTransfer","FunctionCall","SaveReturn","GetSlot",
|
|
|
|
"RegisterTransfer","Syscall","RegisterTransfer","RegisterTransfer","SetSlot",
|
|
|
|
"RegisterTransfer","GetSlot","FunctionReturn","GetSlot","Branch",
|
|
|
|
"RegisterTransfer","GetSlot","FunctionReturn","GetSlot","RegisterTransfer",
|
|
|
|
"GetSlot","FunctionReturn","RegisterTransfer","Syscall","NilClass"].each_with_index do |name , index|
|
|
|
|
got = ticks(1)
|
|
|
|
assert got.class.name.index(name) , "Wrong class for #{index+1}, expect #{name} , got #{got}"
|
|
|
|
end
|
|
|
|
#puts @interpreter.block.inspect
|
|
|
|
|
|
|
|
end
|
|
|
|
end
|