fix operators registers

This commit is contained in:
Torsten 2020-03-10 18:56:06 +02:00
parent 8867d60c13
commit 3a3a9277b3
2 changed files with 17 additions and 18 deletions

View File

@ -11,10 +11,8 @@ module SlotMachine
integer_tmp = builder.allocate_int integer_tmp = builder.allocate_int
operator = @operator # make accessible in block operator = @operator # make accessible in block
builder.build do builder.build do
integer! << message[:receiver] integer = message[:receiver].to_reg.reduce_int(false)
integer.reduce_int integer_reg = message[:arg1].to_reg.reduce_int(false)
integer_reg! << message[:arg1] #"other"
integer_reg.reduce_int
integer.op operator , integer_reg integer.op operator , integer_reg
integer_tmp[Parfait::Integer.integer_index] << integer integer_tmp[Parfait::Integer.integer_index] << integer
message[:return_value] << integer_tmp message[:return_value] << integer_tmp

View File

@ -14,7 +14,7 @@ module SlotMachine
assert_equal Risc::MethodCompiler , @method.to_risc.class assert_equal Risc::MethodCompiler , @method.to_risc.class
end end
def test_risc_length def test_risc_length
assert_equal 42 , @method.to_risc.risc_instructions.length assert_equal 40 , @method.to_risc.risc_instructions.length
end end
end end
class TestIntOpMM < BootTest class TestIntOpMM < BootTest
@ -29,26 +29,27 @@ module SlotMachine
assert_equal Risc::MethodCompiler , @method.to_risc.class assert_equal Risc::MethodCompiler , @method.to_risc.class
end end
def test_risc_length def test_risc_length
assert_equal 42 , @method.to_risc.risc_instructions.length assert_equal 40 , @method.to_risc.risc_instructions.length
end end
def test_allocate def test_allocate
assert_allocate assert_allocate
end end
def test_all def test_all
assert_slot_to_reg risc(23),:r0 , 2 , :r2 s = Risc.allocate_length
assert_slot_to_reg risc(24),:r2 , 2 , :r2 assert_slot_to_reg s + 1 ,:message , 2 , "message.receiver"
assert_slot_to_reg risc(25),:r0 , 9 , :r3 assert_slot_to_reg s + 2 ,"message.receiver" , 2 , "message.receiver.data_1"
assert_slot_to_reg risc(26),:r3 , 2 , :r3 assert_slot_to_reg s + 3 ,:message , 9 , "message.arg1"
assert_operator risc(27) , :| , :r2 , :r3 assert_slot_to_reg s + 4 , "message.arg1" , 2 , "message.arg1.data_1"
assert_reg_to_slot risc(28) , :r2 , :r1 , 2 assert_operator s + 5 , :| , "message.receiver.data_1" , "message.arg1.data_1"
assert_reg_to_slot risc(29) , :r1 , :r0 , 5 assert_reg_to_slot s + 6 , "message.receiver.data_1" , "id_factory_.next_object" , 2
assert_slot_to_reg risc(30),:r0 , 5 , :r2 assert_reg_to_slot s + 7 , "id_factory_.next_object" , :message , 5
assert_reg_to_slot risc(31) , :r2 , :r0 , 5 assert_slot_to_reg s + 8 ,:message , 5 , "message.return_value"
assert_branch risc(32) , "return_label" assert_reg_to_slot s + 9 , "message.return_value" , :message , 5
assert_label risc(33) , "return_label" assert_branch s + 10 , "return_label"
assert_label s + 11 , "return_label"
end end
def test_return def test_return
assert_return(33) assert_return(32)
end end
end end
end end