much less test code (s-exps) needed because compiler defaults to main

but some compilation outside needed, hence clean_compile
This commit is contained in:
Torsten Ruger 2016-12-17 00:19:23 +02:00
parent 5c34835ae3
commit 1a224f904b
9 changed files with 24 additions and 22 deletions

View File

@ -13,10 +13,8 @@ class HelloTest < MiniTest::Test
end end
def test_string_put def test_string_put
@input = s(:statements, s(:class, :Space, s(:derives, nil), @input = s(:statements, s(:return, s(:call, s(:name, :putstring), s(:arguments),
s(:statements, s(:function, :Integer, s(:name, :main), s(:parameters), s(:receiver, s(:string, "Hello again\\n")))))
s(:statements, s(:return, s(:call, s(:name, :putstring), s(:arguments),
s(:receiver, s(:string, "Hello again\\n")))))))))
check check
end end
end end

View File

@ -11,7 +11,7 @@ class Space
end end
end end
HERE HERE
@input = s(:statements, s(:class, :Space, s(:derives, nil), s(:statements, s(:function, :Integer, s(:name, :main), s(:parameters), s(:statements, s(:return, s(:operator_value, :+, s(:int, 5), s(:int, 7)))))))) @input = s(:statements, s(:return, s(:operator_value, :+, s(:int, 5), s(:int, 7))))
super super
end end

View File

@ -4,7 +4,7 @@ class AddChange < MiniTest::Test
include Ticker include Ticker
def setup def setup
@input = s(:statements, s(:class, :Space, s(:derives, nil), s(:statements, s(:function, :Integer, s(:name, :main), s(:parameters), s(:statements, s(:return, s(:operator_value, :+, s(:int, 5), s(:int, 7)))))))) @input = s(:statements, s(:return, s(:operator_value, :+, s(:int, 5), s(:int, 7))))
@state_events = {} @state_events = {}
@instruction_events = [] @instruction_events = []
super super

View File

@ -11,12 +11,10 @@ class Space
end end
end end
HERE HERE
@input = s(:statements, s(:class, :Space, s(:derives, nil), s(:statements, @input = s(:statements, s(:call,
s(:function, :Integer, s(:name, :main), s(:parameters),
s(:statements, s(:call,
s(:name, :set_internal_byte), s(:name, :set_internal_byte),
s(:arguments, s(:int, 1), s(:int, 104)), s(:arguments, s(:int, 1), s(:int, 104)),
s(:receiver, s(:string, "Hello")))))))) s(:receiver, s(:string, "Hello"))))
super super
end end

View File

@ -2,6 +2,7 @@ require_relative "helper"
class IfTest < MiniTest::Test class IfTest < MiniTest::Test
include Ticker include Ticker
include Compiling
def setup def setup
@string_input = <<HERE @string_input = <<HERE
@ -19,10 +20,17 @@ class Space
end end
end end
HERE HERE
@input = s(:statements, s(:class, :Space, s(:derives, nil), s(:statements, s(:function, :Integer, s(:name, :itest), s(:parameters, s(:parameter, :Integer, :n)), s(:statements, s(:if_statement, :zero, s(:condition, s(:operator_value, :-, s(:name, :n), s(:int, 12))), s(:true_statements, s(:call, s(:name, :putstring), s(:arguments), s(:receiver, s(:string, "then")))), s(:false_statements, s(:call, s(:name, :putstring), s(:arguments), s(:receiver, s(:string, "else"))))))), s(:function, :Integer, s(:name, :main), s(:parameters), s(:statements, s(:call, s(:name, :itest), s(:arguments, s(:int, 20)))))))) @input = s(:statements, s(:call, s(:name, :itest), s(:arguments, s(:int, 20))))
super super
end end
# must be after boot, but before main compile, to define method
def do_clean_compile
clean_compile :Space , :itest , {:n => :Integer} ,
s(:statements, s(:if_statement, :zero, s(:condition, s(:operator_value, :-, s(:name, :n), s(:int, 12))),
s(:true_statements, s(:call, s(:name, :putstring), s(:arguments), s(:receiver, s(:string, "then")))),
s(:false_statements, s(:call, s(:name, :putstring), s(:arguments), s(:receiver, s(:string, "else"))))))
end
def test_if def test_if
#show_ticks # get output of what is #show_ticks # get output of what is
check_chain ["Branch","Label","LoadConstant","GetSlot","SetSlot", check_chain ["Branch","Label","LoadConstant","GetSlot","SetSlot",

View File

@ -13,7 +13,7 @@ class Space
end end
HERE HERE
@input = s(:statements, s(:class, :Space, s(:derives, nil), s(:statements, s(:function, :Integer, s(:name, :main), s(:parameters), s(:statements, s(:return, s(:operator_value, :*, s(:int, 2147483648), s(:int, 2147483648)))))))) @input = s(:statements, s(:return, s(:operator_value, :*, s(:int, 2147483648), s(:int, 2147483648))))
super super
end end

View File

@ -11,7 +11,7 @@ class Space
end end
end end
HERE HERE
@input = s(:statements, s(:class, :Space, s(:derives, nil), s(:statements, s(:function, :Integer, s(:name, :main), s(:parameters), s(:statements, s(:return, s(:operator_value, :+, s(:int, 4611686018427387903), s(:int, 1)))))))) @input = s(:statements, s(:return, s(:operator_value, :+, s(:int, 4611686018427387903), s(:int, 1))))
super super
end end

View File

@ -11,7 +11,7 @@ class Space
end end
end end
HERE HERE
@input = s(:statements, s(:class, :Space, s(:derives, nil), s(:statements, s(:function, :Integer, s(:name, :main), s(:parameters), s(:statements, s(:call, s(:name, :putstring), s(:arguments), s(:receiver, s(:string, "Hello again")))))))) @input = s(:statements, s(:call, s(:name, :putstring), s(:arguments), s(:receiver, s(:string, "Hello again"))))
super super
end end

View File

@ -11,12 +11,10 @@ class Space
end end
end end
HERE HERE
@input = s(:statements, s(:class, :Space, s(:derives, nil), s(:statements, @input = s(:statements, s(:call,
s(:function, :Integer, s(:name, :main), s(:parameters),
s(:statements, s(:call,
s(:name, :get_internal_byte), s(:name, :get_internal_byte),
s(:arguments, s(:int, 1)), s(:arguments, s(:int, 1)),
s(:receiver, s(:string, "Hello")))))))) s(:receiver, s(:string, "Hello"))))
super super
end end