diff --git a/lib/ast/return_expression.rb b/lib/ast/return_expression.rb index 761ec217..b664a91f 100644 --- a/lib/ast/return_expression.rb +++ b/lib/ast/return_expression.rb @@ -14,7 +14,7 @@ module Ast [:expression] end def compile context , into - expression_value = condition.compile(context , into) + expression_value = expression.compile(context , into) puts "compiled return expression #{expression_value.inspect}" return expression_value end diff --git a/test/fragments/test_while.rb b/test/fragments/test_while.rb deleted file mode 100644 index 774ea5bf..00000000 --- a/test/fragments/test_while.rb +++ /dev/null @@ -1,28 +0,0 @@ -require_relative 'helper' - -class TestWhileFragment < MiniTest::Test - include Fragments - - def test_while - @string_input = < 1 ) do #BUG comment lines + comments behind function calls - tmp = a # r3 <- r1 - a = b # r1 <- r2 - b = tmp + b # r4 = r2 + r3 (r4 transient) r2 <- r4 - n = n - 1 # r0 <- r2 for call, #call ok - end #r5 <- r0 - 1 n=n-1 through r5 tmp - putint(b) - end # r0 <- r5 - - fibonaccit( 10 ) -HERE - @should = [0x0,0xb0,0xa0,0xe3,0xa,0x10,0xa0,0xe3,0x2,0x0,0x0,0xeb,0x1,0x70,0xa0,0xe3,0x0,0x0,0x0,0xef,0x0,0x70,0xa0,0xe1,0x0,0x40,0x2d,0xe9,0x0,0x20,0xa0,0xe3,0x1,0x30,0xa0,0xe3,0x1,0x0,0x51,0xe3,0x6,0x0,0x0,0xda,0x2,0x40,0xa0,0xe1,0x3,0x20,0xa0,0xe1,0x3,0x50,0x84,0xe0,0x5,0x30,0xa0,0xe1,0x1,0x60,0x41,0xe2,0x6,0x10,0xa0,0xe1,0xf6,0xff,0xff,0xea,0x7e,0x0,0x2d,0xe9,0x3,0x10,0xa0,0xe1,0x12,0x0,0x0,0xeb,0x7e,0x0,0xbd,0xe8,0x0,0x80,0xbd,0xe8,0x0,0x40,0x2d,0xe9,0xa,0x30,0x42,0xe2,0x22,0x21,0x42,0xe0,0x22,0x22,0x82,0xe0,0x22,0x24,0x82,0xe0,0x22,0x28,0x82,0xe0,0xa2,0x21,0xa0,0xe1,0x2,0x41,0x82,0xe0,0x84,0x30,0x53,0xe0,0x1,0x20,0x82,0x52,0xa,0x30,0x83,0x42,0x30,0x30,0x83,0xe2,0x0,0x30,0xc1,0xe5,0x1,0x10,0x41,0xe2,0x0,0x0,0x52,0xe3,0xef,0xff,0xff,0x1b,0x0,0x80,0xbd,0xe8,0x0,0x40,0x2d,0xe9,0x1,0x20,0xa0,0xe1,0x20,0x10,0x8f,0xe2,0x9,0x10,0x81,0xe2,0xe9,0xff,0xff,0xeb,0x14,0x10,0x8f,0xe2,0xc,0x20,0xa0,0xe3,0x1,0x0,0xa0,0xe3,0x4,0x70,0xa0,0xe3,0x0,0x0,0x0,0xef,0x0,0x70,0xa0,0xe1,0x0,0x80,0xbd,0xe8,0x20,0x20,0x20,0x20,0x20,0x20,0x20,0x20,0x20,0x20,0x20,0x20] - @output = " 55 " - parse - write "while" - end -end - diff --git a/test/fragments/test_while_fibo.rb b/test/fragments/test_while_fibo.rb new file mode 100644 index 00000000..ccdec74b --- /dev/null +++ b/test/fragments/test_while_fibo.rb @@ -0,0 +1,28 @@ +require_relative 'helper' + +class TestWhileFragment < MiniTest::Test + include Fragments + + def test_while + @string_input = < 1 ) do #BUG comment lines + comments behind function calls + tmp = a # r3 <- r1 + a = b # r1 <- r2 + b = tmp + b # r4 = r2 + r3 (r4 transient) r2 <- r4 + n = n - 1 # r0 <- r2 for call, #call ok + end #r5 <- r0 - 1 n=n-1 through r5 tmp + return b + end # r0 <- r5 + + putint(fibonaccit( 10 )) +HERE + @should = [0x0,0xb0,0xa0,0xe3,0xa,0x10,0xa0,0xe3,0x4,0x0,0x0,0xeb,0x7,0x10,0xa0,0xe1,0x21,0x0,0x0,0xeb,0x1,0x70,0xa0,0xe3,0x0,0x0,0x0,0xef,0x0,0x70,0xa0,0xe1,0x0,0x40,0x2d,0xe9,0x0,0x20,0xa0,0xe3,0x1,0x30,0xa0,0xe3,0x1,0x0,0x51,0xe3,0x6,0x0,0x0,0xda,0x2,0x40,0xa0,0xe1,0x3,0x20,0xa0,0xe1,0x3,0x50,0x84,0xe0,0x5,0x30,0xa0,0xe1,0x1,0x60,0x41,0xe2,0x6,0x10,0xa0,0xe1,0xf6,0xff,0xff,0xea,0x3,0x70,0xa0,0xe1,0x0,0x80,0xbd,0xe8,0x0,0x40,0x2d,0xe9,0xa,0x30,0x42,0xe2,0x22,0x21,0x42,0xe0,0x22,0x22,0x82,0xe0,0x22,0x24,0x82,0xe0,0x22,0x28,0x82,0xe0,0xa2,0x21,0xa0,0xe1,0x2,0x41,0x82,0xe0,0x84,0x30,0x53,0xe0,0x1,0x20,0x82,0x52,0xa,0x30,0x83,0x42,0x30,0x30,0x83,0xe2,0x0,0x30,0xc1,0xe5,0x1,0x10,0x41,0xe2,0x0,0x0,0x52,0xe3,0xef,0xff,0xff,0x1b,0x0,0x80,0xbd,0xe8,0x0,0x40,0x2d,0xe9,0x1,0x20,0xa0,0xe1,0x20,0x10,0x8f,0xe2,0x9,0x10,0x81,0xe2,0xe9,0xff,0xff,0xeb,0x14,0x10,0x8f,0xe2,0xc,0x20,0xa0,0xe3,0x1,0x0,0xa0,0xe3,0x4,0x70,0xa0,0xe3,0x0,0x0,0x0,0xef,0x0,0x70,0xa0,0xe1,0x0,0x80,0xbd,0xe8,0x20,0x20,0x20,0x20,0x20,0x20,0x20,0x20,0x20,0x20,0x20,0x20] + @output = " 55 " + parse + write "while" + end +end +