diff --git a/test/risc/interpreter/test_div10.rb b/test/risc/interpreter/test_div10.rb index 8ec5de35..af166d83 100644 --- a/test/risc/interpreter/test_div10.rb +++ b/test/risc/interpreter/test_div10.rb @@ -11,41 +11,41 @@ module Risc def test_chain #show_main_ticks # get output of what is - check_main_chain [Label, LoadConstant, SlotToReg, SlotToReg, RegToSlot, - LoadConstant, SlotToReg, SlotToReg, SlotToReg, SlotToReg, - RegToSlot, LoadConstant, SlotToReg, SlotToReg, SlotToReg, - SlotToReg, RegToSlot, LoadConstant, SlotToReg, RegToSlot, - LoadConstant, SlotToReg, RegToSlot, SlotToReg, LoadConstant, - FunctionCall, Label, SlotToReg, SlotToReg, SlotToReg, - SlotToReg, SlotToReg, SlotToReg, LoadData, OperatorInstruction, - LoadData, OperatorInstruction, OperatorInstruction, LoadData, Transfer, + check_main_chain [Label, LoadConstant, LoadConstant, SlotToReg, RegToSlot, + RegToSlot, SlotToReg, SlotToReg, RegToSlot, SlotToReg, + SlotToReg, RegToSlot, SlotToReg, RegToSlot, SlotToReg, + RegToSlot, LoadConstant, SlotToReg, RegToSlot, LoadConstant, + SlotToReg, RegToSlot, SlotToReg, LoadConstant, FunctionCall, + Label, SlotToReg, SlotToReg, SlotToReg, SlotToReg, + SlotToReg, SlotToReg, LoadData, OperatorInstruction, LoadData, OperatorInstruction, OperatorInstruction, LoadData, Transfer, OperatorInstruction, OperatorInstruction, LoadData, Transfer, OperatorInstruction, OperatorInstruction, - LoadData, OperatorInstruction, LoadData, Transfer, OperatorInstruction, - OperatorInstruction, Transfer, LoadData, OperatorInstruction, LoadData, - OperatorInstruction, OperatorInstruction, LoadConstant, SlotToReg, SlotToReg, - RegToSlot, RegToSlot, RegToSlot, SlotToReg, SlotToReg, - RegToSlot, SlotToReg, SlotToReg, FunctionReturn, SlotToReg, - SlotToReg, RegToSlot, SlotToReg, SlotToReg, RegToSlot, - SlotToReg, SlotToReg, RegToSlot, SlotToReg, SlotToReg, - FunctionReturn, Transfer, Syscall, NilClass] + LoadData, Transfer, OperatorInstruction, OperatorInstruction, LoadData, + OperatorInstruction, LoadData, Transfer, OperatorInstruction, OperatorInstruction, + Transfer, LoadData, OperatorInstruction, LoadData, OperatorInstruction, + OperatorInstruction, LoadConstant, SlotToReg, SlotToReg, RegToSlot, + RegToSlot, RegToSlot, SlotToReg, SlotToReg, RegToSlot, + SlotToReg, SlotToReg, FunctionReturn, SlotToReg, SlotToReg, + RegToSlot, SlotToReg, SlotToReg, RegToSlot, SlotToReg, + SlotToReg, RegToSlot, SlotToReg, SlotToReg, FunctionReturn, + Transfer, Syscall, NilClass] assert_equal Parfait::Integer , get_return.class assert_equal 2 , get_return.value end def test_load_25 - load_ins = main_ticks 18 + load_ins = main_ticks 17 assert_equal LoadConstant , load_ins.class assert_equal 25 , @interpreter.get_register(load_ins.register).value end def test_return - ret = main_ticks(74) + ret = main_ticks(73) assert_equal FunctionReturn , ret.class link = @interpreter.get_register( ret.register ) assert_equal Label , link.class end def test_sys - sys = main_ticks(88) + sys = main_ticks(87) assert_equal Syscall , sys.class assert_equal :exit , sys.name end diff --git a/test/risc/interpreter/test_dynamic_call.rb b/test/risc/interpreter/test_dynamic_call.rb index 4b3afe51..dfe8a229 100644 --- a/test/risc/interpreter/test_dynamic_call.rb +++ b/test/risc/interpreter/test_dynamic_call.rb @@ -14,15 +14,15 @@ module Risc check_main_chain [Label, LoadConstant, SlotToReg, RegToSlot, LoadConstant, SlotToReg, SlotToReg, SlotToReg, OperatorInstruction, IsZero, SlotToReg, SlotToReg, LoadConstant, RegToSlot, LoadConstant, - SlotToReg, SlotToReg, RegToSlot, LoadConstant, SlotToReg, - SlotToReg, SlotToReg, SlotToReg, RegToSlot, LoadConstant, - SlotToReg, SlotToReg, SlotToReg, SlotToReg, RegToSlot, - LoadConstant, SlotToReg, RegToSlot, SlotToReg, SlotToReg, - SlotToReg, SlotToReg, RegToSlot, LoadConstant, SlotToReg, - RegToSlot, SlotToReg, LoadConstant, FunctionCall, Label, - SlotToReg, SlotToReg, SlotToReg, SlotToReg, Label, - LoadConstant, SlotToReg, OperatorInstruction, IsZero, Label, - Transfer, Syscall, NilClass] + LoadConstant, SlotToReg, RegToSlot, RegToSlot, SlotToReg, + SlotToReg, RegToSlot, SlotToReg, SlotToReg, RegToSlot, + SlotToReg, RegToSlot, SlotToReg, RegToSlot, LoadConstant, + SlotToReg, RegToSlot, SlotToReg, SlotToReg, SlotToReg, + SlotToReg, RegToSlot, LoadConstant, SlotToReg, RegToSlot, + SlotToReg, LoadConstant, FunctionCall, Label, SlotToReg, + SlotToReg, SlotToReg, SlotToReg, Label, LoadConstant, + SlotToReg, OperatorInstruction, IsZero, Label, Transfer, + Syscall, NilClass] #assert_equal 1 , get_return end @@ -32,17 +32,17 @@ module Risc assert_equal :main , call_ins.method.name end def test_call_resolve - call_ins = main_ticks(44) + call_ins = main_ticks(43) assert_equal FunctionCall , call_ins.class assert_equal :resolve_method , call_ins.method.name end def test_label - call_ins = main_ticks(45) + call_ins = main_ticks(44) assert_equal Label , call_ins.class assert_equal "Word_Type.resolve_method" , call_ins.name end def test_arg_15_to_resolve - sl = main_ticks( 48 ) + sl = main_ticks( 47 ) assert_equal SlotToReg , sl.class assert_equal :r2 , sl.array.symbol #load from message assert_equal 2 , sl.index diff --git a/test/risc/interpreter/test_events.rb b/test/risc/interpreter/test_events.rb index fafc20ec..52152a4a 100644 --- a/test/risc/interpreter/test_events.rb +++ b/test/risc/interpreter/test_events.rb @@ -18,10 +18,12 @@ module Risc def instruction_changed(was , is ) @instruction_events << was end - + def length + 88 + end def test_state_change @interpreter.register_event :state_changed , self - ticks 89 + ticks length assert @state_events[:state_changed] assert_equal 2 , @state_events[:state_changed].length assert_equal :running, @state_events[:state_changed][0] @@ -30,31 +32,31 @@ module Risc def test_instruction_events @interpreter.register_event :instruction_changed , self - ticks 89 - assert_equal 89 , @instruction_events.length + ticks length + assert_equal length , @instruction_events.length @interpreter.unregister_event :instruction_changed , self end def test_chain #show_ticks # get output of what is - check_chain [Branch, Label, LoadConstant, SlotToReg, LoadConstant, - SlotToReg, SlotToReg, RegToSlot, LoadConstant, SlotToReg, - SlotToReg, SlotToReg, SlotToReg, RegToSlot, LoadConstant, - SlotToReg, SlotToReg, SlotToReg, SlotToReg, RegToSlot, - SlotToReg, LoadConstant, RegToSlot, LoadConstant, RegToSlot, - FunctionCall, Label, LoadConstant, SlotToReg, SlotToReg, - RegToSlot, LoadConstant, SlotToReg, SlotToReg, SlotToReg, - SlotToReg, RegToSlot, LoadConstant, SlotToReg, SlotToReg, - SlotToReg, SlotToReg, RegToSlot, LoadConstant, SlotToReg, - RegToSlot, LoadConstant, SlotToReg, SlotToReg, RegToSlot, - LoadConstant, SlotToReg, RegToSlot, SlotToReg, LoadConstant, - FunctionCall, Label, SlotToReg, SlotToReg, SlotToReg, - SlotToReg, SlotToReg, OperatorInstruction, LoadConstant, SlotToReg, - SlotToReg, RegToSlot, RegToSlot, RegToSlot, SlotToReg, - SlotToReg, RegToSlot, SlotToReg, SlotToReg, FunctionReturn, - SlotToReg, SlotToReg, RegToSlot, SlotToReg, SlotToReg, + check_chain [Branch, Label, LoadConstant, SlotToReg, SlotToReg, + RegToSlot, LoadConstant, LoadConstant, SlotToReg, RegToSlot, RegToSlot, SlotToReg, SlotToReg, RegToSlot, SlotToReg, - SlotToReg, FunctionReturn, Transfer, Syscall, NilClass] + SlotToReg, RegToSlot, SlotToReg, RegToSlot, SlotToReg, + RegToSlot, SlotToReg, RegToSlot, LoadConstant, RegToSlot, + FunctionCall, Label, LoadConstant, LoadConstant, SlotToReg, + RegToSlot, RegToSlot, SlotToReg, SlotToReg, RegToSlot, + SlotToReg, SlotToReg, RegToSlot, SlotToReg, RegToSlot, + SlotToReg, RegToSlot, LoadConstant, SlotToReg, RegToSlot, + LoadConstant, SlotToReg, SlotToReg, RegToSlot, LoadConstant, + SlotToReg, RegToSlot, SlotToReg, LoadConstant, FunctionCall, + Label, SlotToReg, SlotToReg, SlotToReg, SlotToReg, + SlotToReg, OperatorInstruction, LoadConstant, SlotToReg, SlotToReg, + RegToSlot, RegToSlot, RegToSlot, SlotToReg, SlotToReg, + RegToSlot, SlotToReg, SlotToReg, FunctionReturn, SlotToReg, + SlotToReg, RegToSlot, SlotToReg, SlotToReg, RegToSlot, + SlotToReg, SlotToReg, RegToSlot, SlotToReg, SlotToReg, + FunctionReturn, Transfer, Syscall, NilClass] assert_equal Parfait::Integer , get_return.class assert_equal 12 , get_return.value end diff --git a/test/risc/interpreter/test_get_byte.rb b/test/risc/interpreter/test_get_byte.rb index 76d53829..2ab1c92c 100644 --- a/test/risc/interpreter/test_get_byte.rb +++ b/test/risc/interpreter/test_get_byte.rb @@ -10,29 +10,29 @@ module Risc end def test_chain #show_main_ticks # get output of what is - check_main_chain [Label, LoadConstant, SlotToReg, SlotToReg, RegToSlot, - LoadConstant, SlotToReg, SlotToReg, SlotToReg, SlotToReg, - RegToSlot, LoadConstant, SlotToReg, SlotToReg, SlotToReg, - SlotToReg, RegToSlot, LoadConstant, SlotToReg, RegToSlot, - LoadConstant, SlotToReg, SlotToReg, RegToSlot, LoadConstant, - SlotToReg, RegToSlot, SlotToReg, LoadConstant, FunctionCall, - Label, SlotToReg, SlotToReg, SlotToReg, SlotToReg, - ByteToReg, LoadConstant, SlotToReg, SlotToReg, RegToSlot, - RegToSlot, RegToSlot, SlotToReg, SlotToReg, RegToSlot, - SlotToReg, SlotToReg, FunctionReturn, SlotToReg, SlotToReg, + check_main_chain [Label, LoadConstant, LoadConstant, SlotToReg, RegToSlot, RegToSlot, SlotToReg, SlotToReg, RegToSlot, SlotToReg, - SlotToReg, RegToSlot, SlotToReg, SlotToReg, FunctionReturn, - Transfer, Syscall, NilClass] + SlotToReg, RegToSlot, SlotToReg, RegToSlot, SlotToReg, + RegToSlot, LoadConstant, SlotToReg, RegToSlot, LoadConstant, + SlotToReg, SlotToReg, RegToSlot, LoadConstant, SlotToReg, + RegToSlot, SlotToReg, LoadConstant, FunctionCall, Label, + SlotToReg, SlotToReg, SlotToReg, SlotToReg, ByteToReg, + LoadConstant, SlotToReg, SlotToReg, RegToSlot, RegToSlot, + RegToSlot, SlotToReg, SlotToReg, RegToSlot, SlotToReg, + SlotToReg, FunctionReturn, SlotToReg, SlotToReg, RegToSlot, + SlotToReg, SlotToReg, RegToSlot, SlotToReg, SlotToReg, + RegToSlot, SlotToReg, SlotToReg, FunctionReturn, Transfer, + Syscall, NilClass] assert_equal Parfait::Integer , get_return.class assert_equal "H".ord , get_return.value end def test_exit - done = main_ticks(62) + done = main_ticks(61) assert_equal Syscall , done.class end def test_byte_to_reg - done = main_ticks(36) + done = main_ticks(35) assert_equal ByteToReg , done.class assert_equal "H".ord , @interpreter.get_register(done.register) end diff --git a/test/risc/interpreter/test_minus.rb b/test/risc/interpreter/test_minus.rb index bb118576..bda8c7a2 100644 --- a/test/risc/interpreter/test_minus.rb +++ b/test/risc/interpreter/test_minus.rb @@ -11,30 +11,30 @@ module Risc def test_minus #show_main_ticks # get output of what is - check_main_chain [Label, LoadConstant, SlotToReg, SlotToReg, RegToSlot, - LoadConstant, SlotToReg, SlotToReg, SlotToReg, SlotToReg, - RegToSlot, LoadConstant, SlotToReg, SlotToReg, SlotToReg, - SlotToReg, RegToSlot, LoadConstant, SlotToReg, RegToSlot, - LoadConstant, SlotToReg, SlotToReg, RegToSlot, LoadConstant, - SlotToReg, RegToSlot, SlotToReg, LoadConstant, FunctionCall, - Label, SlotToReg, SlotToReg, SlotToReg, SlotToReg, - SlotToReg, OperatorInstruction, LoadConstant, SlotToReg, SlotToReg, - RegToSlot, RegToSlot, RegToSlot, SlotToReg, SlotToReg, - RegToSlot, SlotToReg, SlotToReg, FunctionReturn, SlotToReg, - SlotToReg, RegToSlot, SlotToReg, SlotToReg, RegToSlot, - SlotToReg, SlotToReg, RegToSlot, SlotToReg, SlotToReg, - FunctionReturn, Transfer, Syscall, NilClass] + check_main_chain [Label, LoadConstant, LoadConstant, SlotToReg, RegToSlot, + RegToSlot, SlotToReg, SlotToReg, RegToSlot, SlotToReg, + SlotToReg, RegToSlot, SlotToReg, RegToSlot, SlotToReg, + RegToSlot, LoadConstant, SlotToReg, RegToSlot, LoadConstant, + SlotToReg, SlotToReg, RegToSlot, LoadConstant, SlotToReg, + RegToSlot, SlotToReg, LoadConstant, FunctionCall, Label, + SlotToReg, SlotToReg, SlotToReg, SlotToReg, SlotToReg, + OperatorInstruction, LoadConstant, SlotToReg, SlotToReg, RegToSlot, + RegToSlot, RegToSlot, SlotToReg, SlotToReg, RegToSlot, + SlotToReg, SlotToReg, FunctionReturn, SlotToReg, SlotToReg, + RegToSlot, SlotToReg, SlotToReg, RegToSlot, SlotToReg, + SlotToReg, RegToSlot, SlotToReg, SlotToReg, FunctionReturn, + Transfer, Syscall, NilClass] assert_equal Parfait::Integer , get_return.class assert_equal 1 , get_return.value end def test_load_5 - lod = main_ticks( 21 ) + lod = main_ticks( 20 ) assert_equal LoadConstant , lod.class assert_equal Parfait::Integer , lod.constant.class assert_equal 5 , lod.constant.value end def test_op - op = main_ticks(37) + op = main_ticks(36) assert_equal OperatorInstruction , op.class assert_equal :r1 , op.left.symbol assert_equal :r2 , op.right.symbol @@ -42,7 +42,7 @@ module Risc assert_equal 1 , @interpreter.get_register(:r1) end def test_sys - sys = main_ticks(63) + sys = main_ticks(62) assert_equal Syscall , sys.class assert_equal :exit , sys.name end diff --git a/test/risc/interpreter/test_mod.rb b/test/risc/interpreter/test_mod.rb index 6d483664..ff876d9a 100644 --- a/test/risc/interpreter/test_mod.rb +++ b/test/risc/interpreter/test_mod.rb @@ -11,29 +11,29 @@ module Risc def test_chain #show_main_ticks # get output of what is - check_main_chain [Label, LoadConstant, SlotToReg, SlotToReg, RegToSlot, - LoadConstant, SlotToReg, SlotToReg, SlotToReg, SlotToReg, - RegToSlot, LoadConstant, SlotToReg, SlotToReg, SlotToReg, - SlotToReg, RegToSlot, LoadConstant, SlotToReg, RegToSlot, - LoadConstant, SlotToReg, RegToSlot, SlotToReg, LoadConstant, - FunctionCall, Label, SlotToReg, SlotToReg, LoadData, - OperatorInstruction, LoadConstant, SlotToReg, SlotToReg, RegToSlot, - RegToSlot, RegToSlot, SlotToReg, SlotToReg, RegToSlot, - SlotToReg, SlotToReg, FunctionReturn, SlotToReg, SlotToReg, + check_main_chain [Label, LoadConstant, LoadConstant, SlotToReg, RegToSlot, RegToSlot, SlotToReg, SlotToReg, RegToSlot, SlotToReg, - SlotToReg, RegToSlot, SlotToReg, SlotToReg, FunctionReturn, - Transfer, Syscall, NilClass] + SlotToReg, RegToSlot, SlotToReg, RegToSlot, SlotToReg, + RegToSlot, LoadConstant, SlotToReg, RegToSlot, LoadConstant, + SlotToReg, RegToSlot, SlotToReg, LoadConstant, FunctionCall, + Label, SlotToReg, SlotToReg, LoadData, OperatorInstruction, + LoadConstant, SlotToReg, SlotToReg, RegToSlot, RegToSlot, + RegToSlot, SlotToReg, SlotToReg, RegToSlot, SlotToReg, + SlotToReg, FunctionReturn, SlotToReg, SlotToReg, RegToSlot, + SlotToReg, SlotToReg, RegToSlot, SlotToReg, SlotToReg, + RegToSlot, SlotToReg, SlotToReg, FunctionReturn, Transfer, + Syscall, NilClass] assert_equal Parfait::Integer , get_return.class assert_equal 2 , get_return.value end def test_load - lod = main_ticks(18) + lod = main_ticks(17) assert_equal LoadConstant , lod.class assert_equal 9 , lod.constant.value end def test_fix # reduce self to fix - sl = main_ticks(29) + sl = main_ticks(28) assert_equal SlotToReg , sl.class assert_equal :r1 , sl.array.symbol assert_equal 3 , sl.index @@ -42,7 +42,7 @@ module Risc end def test_sys - sys = main_ticks(57) + sys = main_ticks(56) assert_equal Syscall , sys.class assert_equal :exit , sys.name end diff --git a/test/risc/interpreter/test_mult.rb b/test/risc/interpreter/test_mult.rb index 3f9cf895..07c38588 100644 --- a/test/risc/interpreter/test_mult.rb +++ b/test/risc/interpreter/test_mult.rb @@ -11,24 +11,24 @@ module Risc def test_mult #show_main_ticks # get output of what is - check_main_chain [Label, LoadConstant, SlotToReg, SlotToReg, RegToSlot, - LoadConstant, SlotToReg, SlotToReg, SlotToReg, SlotToReg, - RegToSlot, LoadConstant, SlotToReg, SlotToReg, SlotToReg, - SlotToReg, RegToSlot, LoadConstant, SlotToReg, RegToSlot, - LoadConstant, SlotToReg, SlotToReg, RegToSlot, LoadConstant, - SlotToReg, RegToSlot, SlotToReg, LoadConstant, FunctionCall, - Label, SlotToReg, SlotToReg, SlotToReg, SlotToReg, - SlotToReg, OperatorInstruction, LoadConstant, SlotToReg, SlotToReg, - RegToSlot, RegToSlot, RegToSlot, SlotToReg, SlotToReg, - RegToSlot, SlotToReg, SlotToReg, FunctionReturn, SlotToReg, - SlotToReg, RegToSlot, SlotToReg, SlotToReg, RegToSlot, - SlotToReg, SlotToReg, RegToSlot, SlotToReg, SlotToReg, - FunctionReturn, Transfer, Syscall, NilClass] + check_main_chain [Label, LoadConstant, LoadConstant, SlotToReg, RegToSlot, + RegToSlot, SlotToReg, SlotToReg, RegToSlot, SlotToReg, + SlotToReg, RegToSlot, SlotToReg, RegToSlot, SlotToReg, + RegToSlot, LoadConstant, SlotToReg, RegToSlot, LoadConstant, + SlotToReg, SlotToReg, RegToSlot, LoadConstant, SlotToReg, + RegToSlot, SlotToReg, LoadConstant, FunctionCall, Label, + SlotToReg, SlotToReg, SlotToReg, SlotToReg, SlotToReg, + OperatorInstruction, LoadConstant, SlotToReg, SlotToReg, RegToSlot, + RegToSlot, RegToSlot, SlotToReg, SlotToReg, RegToSlot, + SlotToReg, SlotToReg, FunctionReturn, SlotToReg, SlotToReg, + RegToSlot, SlotToReg, SlotToReg, RegToSlot, SlotToReg, + SlotToReg, RegToSlot, SlotToReg, SlotToReg, FunctionReturn, + Transfer, Syscall, NilClass] assert_equal Parfait::Integer , get_return.class assert_equal 0 , get_return.value end def test_op - op = main_ticks(37) + op = main_ticks(36) assert_equal OperatorInstruction , op.class assert_equal :r1 , op.left.symbol assert_equal :r2 , op.right.symbol diff --git a/test/risc/interpreter/test_plus.rb b/test/risc/interpreter/test_plus.rb index 53bdee7f..3c742b5a 100644 --- a/test/risc/interpreter/test_plus.rb +++ b/test/risc/interpreter/test_plus.rb @@ -11,58 +11,58 @@ module Risc def test_add #show_main_ticks # get output of what is - check_main_chain [Label, LoadConstant, SlotToReg, SlotToReg, RegToSlot, - LoadConstant, SlotToReg, SlotToReg, SlotToReg, SlotToReg, - RegToSlot, LoadConstant, SlotToReg, SlotToReg, SlotToReg, - SlotToReg, RegToSlot, LoadConstant, SlotToReg, RegToSlot, - LoadConstant, SlotToReg, SlotToReg, RegToSlot, LoadConstant, - SlotToReg, RegToSlot, SlotToReg, LoadConstant, FunctionCall, - Label, SlotToReg, SlotToReg, SlotToReg, SlotToReg, - SlotToReg, OperatorInstruction, LoadConstant, SlotToReg, SlotToReg, - RegToSlot, RegToSlot, RegToSlot, SlotToReg, SlotToReg, - RegToSlot, SlotToReg, SlotToReg, FunctionReturn, SlotToReg, - SlotToReg, RegToSlot, SlotToReg, SlotToReg, RegToSlot, - SlotToReg, SlotToReg, RegToSlot, SlotToReg, SlotToReg, - FunctionReturn, Transfer, Syscall, NilClass] + check_main_chain [Label, LoadConstant, LoadConstant, SlotToReg, RegToSlot, + RegToSlot, SlotToReg, SlotToReg, RegToSlot, SlotToReg, + SlotToReg, RegToSlot, SlotToReg, RegToSlot, SlotToReg, + RegToSlot, LoadConstant, SlotToReg, RegToSlot, LoadConstant, + SlotToReg, SlotToReg, RegToSlot, LoadConstant, SlotToReg, + RegToSlot, SlotToReg, LoadConstant, FunctionCall, Label, + SlotToReg, SlotToReg, SlotToReg, SlotToReg, SlotToReg, + OperatorInstruction, LoadConstant, SlotToReg, SlotToReg, RegToSlot, + RegToSlot, RegToSlot, SlotToReg, SlotToReg, RegToSlot, + SlotToReg, SlotToReg, FunctionReturn, SlotToReg, SlotToReg, + RegToSlot, SlotToReg, SlotToReg, RegToSlot, SlotToReg, + SlotToReg, RegToSlot, SlotToReg, SlotToReg, FunctionReturn, + Transfer, Syscall, NilClass] assert_equal Parfait::Integer , get_return.class assert_equal 10 , get_return.value end def test_load_5 - lod = main_ticks( 21 ) + lod = main_ticks( 20 ) assert_equal LoadConstant , lod.class assert_equal Parfait::Integer , lod.constant.class assert_equal 5 , lod.constant.value end def test_slot_receiver #load receiver from message - sl = main_ticks( 32 ) + sl = main_ticks( 31 ) assert_equal SlotToReg , sl.class assert_equal :r0 , sl.array.symbol #load from message assert_equal 3 , sl.index assert_equal :r1 , sl.register.symbol end def test_slot_args #load args from message - sl = main_ticks( 33 ) + sl = main_ticks( 32 ) assert_equal SlotToReg , sl.class assert_equal :r0 , sl.array.symbol #load from message assert_equal 9 , sl.index assert_equal :r2 , sl.register.symbol end def test_slot_arg #load arg 1, destructively from args - sl = main_ticks( 34 ) + sl = main_ticks( 33 ) assert_equal SlotToReg , sl.class assert_equal :r2 , sl.array.symbol #load from message assert_equal 2 , sl.index assert_equal :r2 , sl.register.symbol end def test_slot_int1 #load int from object - sl = main_ticks( 35 ) + sl = main_ticks( 34 ) assert_equal SlotToReg , sl.class assert_equal :r1 , sl.array.symbol #load from message assert_equal 3 , sl.index assert_equal :r1 , sl.register.symbol end def test_op - op = main_ticks(37) + op = main_ticks(36) assert_equal OperatorInstruction , op.class assert_equal :r1 , op.left.symbol assert_equal :r2 , op.right.symbol @@ -70,13 +70,13 @@ module Risc assert_equal 10 , @interpreter.get_register(:r1) end def test_load_int_space - cons = main_ticks(38) + cons = main_ticks(37) assert_equal LoadConstant , cons.class assert_equal Parfait::Space , cons.constant.class assert_equal :r3 , cons.register.symbol end def test_load_int_next_space - sl = main_ticks(39) + sl = main_ticks(38) assert_equal SlotToReg , sl.class assert_equal :r3 , sl.array.symbol #load from space assert_equal 5 , sl.index @@ -84,7 +84,7 @@ module Risc assert_equal Parfait::Integer , @interpreter.get_register(:r2).class end def test_load_int_next_int - sl = main_ticks(40) + sl = main_ticks(39) assert_equal SlotToReg , sl.class assert_equal :r2 , sl.array.symbol #load from next_int assert_equal 2 , sl.index @@ -92,14 +92,14 @@ module Risc assert_equal Parfait::Integer , @interpreter.get_register(:r4).class end def test_load_int_next_int2 - sl = main_ticks(41) + sl = main_ticks(40) assert_equal RegToSlot , sl.class assert_equal :r3 , sl.array.symbol #store to space assert_equal 5 , sl.index assert_equal :r4 , sl.register.symbol end def test_sys - sys = main_ticks(63) + sys = main_ticks(62) assert_equal Syscall , sys.class assert_equal :exit , sys.name end diff --git a/test/risc/interpreter/test_puts.rb b/test/risc/interpreter/test_puts.rb index 9ade29d8..205c3b42 100644 --- a/test/risc/interpreter/test_puts.rb +++ b/test/risc/interpreter/test_puts.rb @@ -11,30 +11,30 @@ module Risc def test_chain #show_main_ticks # get output of what is - check_main_chain [Label, LoadConstant, SlotToReg, SlotToReg, RegToSlot, - LoadConstant, SlotToReg, SlotToReg, SlotToReg, SlotToReg, - RegToSlot, LoadConstant, SlotToReg, SlotToReg, SlotToReg, - SlotToReg, RegToSlot, LoadConstant, SlotToReg, RegToSlot, - LoadConstant, SlotToReg, RegToSlot, SlotToReg, LoadConstant, - FunctionCall, Label, SlotToReg, SlotToReg, Transfer, - Syscall, Transfer, Transfer, LoadConstant, SlotToReg, - SlotToReg, RegToSlot, RegToSlot, RegToSlot, SlotToReg, - SlotToReg, RegToSlot, SlotToReg, SlotToReg, FunctionReturn, - SlotToReg, SlotToReg, RegToSlot, SlotToReg, SlotToReg, + check_main_chain [Label, LoadConstant, LoadConstant, SlotToReg, RegToSlot, RegToSlot, SlotToReg, SlotToReg, RegToSlot, SlotToReg, - SlotToReg, FunctionReturn, Transfer, Syscall, NilClass] + SlotToReg, RegToSlot, SlotToReg, RegToSlot, SlotToReg, + RegToSlot, LoadConstant, SlotToReg, RegToSlot, LoadConstant, + SlotToReg, RegToSlot, SlotToReg, LoadConstant, FunctionCall, + Label, SlotToReg, SlotToReg, Transfer, Syscall, + Transfer, Transfer, LoadConstant, SlotToReg, SlotToReg, + RegToSlot, RegToSlot, RegToSlot, SlotToReg, SlotToReg, + RegToSlot, SlotToReg, SlotToReg, FunctionReturn, SlotToReg, + SlotToReg, RegToSlot, SlotToReg, SlotToReg, RegToSlot, + SlotToReg, SlotToReg, RegToSlot, SlotToReg, SlotToReg, + FunctionReturn, Transfer, Syscall, NilClass] assert_equal "Hello again" , @interpreter.stdout assert_equal Parfait::Integer , get_return.class assert_equal 11 , get_return.value #bytes written end def test_call - cal = main_ticks(26) + cal = main_ticks(25) assert_equal FunctionCall , cal.class assert_equal :putstring , cal.method.name end def test_putstring_sys - done = main_ticks(31) + done = main_ticks(30) assert_equal Syscall , done.class assert_equal "Hello again" , @interpreter.stdout assert_equal 11 , @interpreter.get_register(:r0) @@ -42,28 +42,28 @@ module Risc assert_equal "Hello again" , @interpreter.get_register(:r1).to_string end def test_move_sys_return - sl = main_ticks(32) + sl = main_ticks(31) assert_equal Transfer , sl.class assert_equal :r0 , sl.from.symbol assert_equal :r1 , sl.to.symbol assert_equal 11 , @interpreter.get_register(:r1) end def test_restore_message - sl = main_ticks(33) + sl = main_ticks(32) assert_equal Transfer , sl.class assert_equal :r8 , sl.from.symbol assert_equal :r0 , sl.to.symbol assert_equal Parfait::Message , @interpreter.get_register(:r0).class end def test_save_sys_return - sl = main_ticks(38) + sl = main_ticks(37) assert_equal RegToSlot , sl.class assert_equal :r1 , sl.register.symbol #return assert_equal :r2 , sl.array.symbol #parfait integer assert_equal 3 , sl.index end def test_return - done = main_ticks(45) + done = main_ticks(44) assert_equal FunctionReturn , done.class end diff --git a/test/risc/interpreter/test_set_byte.rb b/test/risc/interpreter/test_set_byte.rb index a9b50d6c..79efda55 100644 --- a/test/risc/interpreter/test_set_byte.rb +++ b/test/risc/interpreter/test_set_byte.rb @@ -11,29 +11,29 @@ module Risc def test_chain #show_main_ticks # get output of what is - check_main_chain [Label, LoadConstant, SlotToReg, SlotToReg, RegToSlot, - LoadConstant, SlotToReg, SlotToReg, SlotToReg, SlotToReg, - RegToSlot, LoadConstant, SlotToReg, SlotToReg, SlotToReg, - SlotToReg, RegToSlot, LoadConstant, SlotToReg, RegToSlot, - LoadConstant, SlotToReg, SlotToReg, RegToSlot, LoadConstant, - SlotToReg, SlotToReg, RegToSlot, LoadConstant, SlotToReg, - RegToSlot, SlotToReg, LoadConstant, FunctionCall, Label, - SlotToReg, SlotToReg, SlotToReg, SlotToReg, SlotToReg, - SlotToReg, SlotToReg, RegToByte, RegToSlot, SlotToReg, - SlotToReg, RegToSlot, SlotToReg, SlotToReg, FunctionReturn, - SlotToReg, SlotToReg, RegToSlot, SlotToReg, SlotToReg, + check_main_chain [Label, LoadConstant, LoadConstant, SlotToReg, RegToSlot, RegToSlot, SlotToReg, SlotToReg, RegToSlot, SlotToReg, - SlotToReg, FunctionReturn, Transfer, Syscall, NilClass] + SlotToReg, RegToSlot, SlotToReg, RegToSlot, SlotToReg, + RegToSlot, LoadConstant, SlotToReg, RegToSlot, LoadConstant, + SlotToReg, SlotToReg, RegToSlot, LoadConstant, SlotToReg, + SlotToReg, RegToSlot, LoadConstant, SlotToReg, RegToSlot, + SlotToReg, LoadConstant, FunctionCall, Label, SlotToReg, + SlotToReg, SlotToReg, SlotToReg, SlotToReg, SlotToReg, + SlotToReg, RegToByte, RegToSlot, SlotToReg, SlotToReg, + RegToSlot, SlotToReg, SlotToReg, FunctionReturn, SlotToReg, + SlotToReg, RegToSlot, SlotToReg, SlotToReg, RegToSlot, + SlotToReg, SlotToReg, RegToSlot, SlotToReg, SlotToReg, + FunctionReturn, Transfer, Syscall, NilClass] assert_equal Parfait::Word , get_return.class assert_equal "Kello" , get_return.to_string end def test_reg_to_byte - done = main_ticks(43) + done = main_ticks(42) assert_equal RegToByte , done.class assert_equal "K".ord , @interpreter.get_register(done.register) end def test_exit - done = main_ticks(64) + done = main_ticks(63) assert_equal Syscall , done.class end diff --git a/test/support/interpreter_helpers.rb b/test/support/interpreter_helpers.rb index 4938303c..c61603f6 100644 --- a/test/support/interpreter_helpers.rb +++ b/test/support/interpreter_helpers.rb @@ -19,7 +19,7 @@ module Risc # how many instruction up until the main starts, ie # ticks(main_at) will be the label for main def main_at - 25 + 26 end def get_return