fix mod and tests
This commit is contained in:
parent
3a983b4fc8
commit
9f609bdb06
@ -9,7 +9,7 @@ module SlotMachine
|
||||
integer_self = message[:receiver].reduce_int(false)
|
||||
load_object( 2 , integer_1)
|
||||
result = integer_self.op :>> , integer_1
|
||||
integer_tmp[Parfait::Integer.integer_index] << result.result
|
||||
integer_tmp[Parfait::Integer.integer_index] << result
|
||||
message[:return_value] << integer_tmp
|
||||
end
|
||||
return compiler
|
||||
|
@ -16,56 +16,41 @@ module Risc
|
||||
check_main_chain [LoadConstant, SlotToReg, RegToSlot, LoadConstant, SlotToReg, #5
|
||||
RegToSlot, LoadConstant, SlotToReg, RegToSlot, LoadConstant, #10
|
||||
SlotToReg, RegToSlot, SlotToReg, FunctionCall, LoadConstant, #15
|
||||
SlotToReg, LoadConstant, OperatorInstruction, IsNotZero, SlotToReg, #20
|
||||
LoadConstant, SlotToReg, OperatorInstruction, IsNotZero, SlotToReg, #20
|
||||
RegToSlot, SlotToReg, SlotToReg, SlotToReg, SlotToReg, #25
|
||||
OperatorInstruction, RegToSlot, RegToSlot, SlotToReg, RegToSlot, #30
|
||||
Branch, Branch, SlotToReg, SlotToReg, RegToSlot, #35
|
||||
SlotToReg, SlotToReg, SlotToReg, FunctionReturn, SlotToReg, #40
|
||||
RegToSlot, Branch, SlotToReg, SlotToReg, RegToSlot, #45
|
||||
SlotToReg, SlotToReg, SlotToReg, FunctionReturn, Transfer, #50
|
||||
SlotToReg, SlotToReg, Syscall, NilClass,] #55
|
||||
Branch, SlotToReg, SlotToReg, RegToSlot, SlotToReg, #35
|
||||
SlotToReg, FunctionReturn, SlotToReg, RegToSlot, Branch, #40
|
||||
SlotToReg, SlotToReg, RegToSlot, SlotToReg, SlotToReg, #45
|
||||
FunctionReturn, Transfer, SlotToReg, SlotToReg, Transfer, #50
|
||||
Syscall, NilClass,] #55
|
||||
assert_equal 10 , get_return
|
||||
end
|
||||
def base_ticks(num)
|
||||
main_ticks(14 + num)
|
||||
end
|
||||
def test_base
|
||||
assert_equal FunctionCall , main_ticks( 14 ).class
|
||||
end
|
||||
|
||||
def test_load_factory
|
||||
lod = base_ticks( 1 )
|
||||
assert_load( lod , Parfait::Factory , :r2)
|
||||
assert_equal :next_integer , lod.constant.attribute_name
|
||||
end
|
||||
def test_slot_receiver #load next_object from factory
|
||||
sl = base_ticks( 2 )
|
||||
assert_slot_to_reg( sl , :r2 , 2 , :r1)
|
||||
assert_load( 15 , Parfait::Factory , "id_factory_")
|
||||
assert_equal :next_integer , @instruction.constant.attribute_name
|
||||
end
|
||||
def test_load_nil
|
||||
lod = base_ticks( 3 )
|
||||
assert_load( lod , Parfait::NilClass , :r3)
|
||||
assert_load( 16 , Parfait::NilClass , "id_nilclass_")
|
||||
end
|
||||
def test_slot_receiver #load next_object from factory
|
||||
assert_slot_to_reg( 17 , "id_factory_" , 2 , "id_factory_.next_object")
|
||||
end
|
||||
def test_nil_check
|
||||
op = base_ticks(4)
|
||||
assert_equal OperatorInstruction , op.class
|
||||
assert_equal :- , op.operator
|
||||
assert_equal :r3 , op.left.symbol
|
||||
assert_equal :r1 , op.right.symbol
|
||||
assert_equal ::Integer , @interpreter.get_register(:r3).class
|
||||
assert 0 != @interpreter.get_register(:r3)
|
||||
assert_operator 18 , :- , "id_nilclass_" , "id_factory_.next_object" , "op_-_"
|
||||
value = @interpreter.get_register(@instruction.result)
|
||||
assert_equal ::Integer , value.class
|
||||
assert 0 != value
|
||||
end
|
||||
def test_branch
|
||||
br = base_ticks( 5 )
|
||||
assert_equal IsNotZero , br.class
|
||||
assert br.label.name.start_with?("cont_label")
|
||||
assert_not_zero 19 , "cont_label"
|
||||
end
|
||||
def test_load_next_int
|
||||
sl = base_ticks( 6 )
|
||||
assert_slot_to_reg( sl , :r1 , 1 , :r4)
|
||||
assert_slot_to_reg( 20 , "id_factory_.next_object" , 1 , "id_factory_.next_object.next_integer")
|
||||
end
|
||||
def test_move_next_back_to_factory
|
||||
int = base_ticks( 7 )
|
||||
assert_reg_to_slot( int , :r4 , :r2 , 2)
|
||||
assert_reg_to_slot( 21 , "id_factory_.next_object.next_integer" , "id_factory_" , 2)
|
||||
end
|
||||
end
|
||||
end
|
||||
|
@ -11,23 +11,23 @@ module Risc
|
||||
end
|
||||
|
||||
def test_chain
|
||||
#show_main_ticks # get output of what is
|
||||
# show_main_ticks # get output of what is
|
||||
check_main_chain [LoadConstant, SlotToReg, RegToSlot, LoadConstant, SlotToReg, #5
|
||||
RegToSlot, LoadConstant, SlotToReg, RegToSlot, SlotToReg, #10
|
||||
FunctionCall, LoadConstant, SlotToReg, LoadConstant, OperatorInstruction, #15
|
||||
FunctionCall, LoadConstant, LoadConstant, SlotToReg, OperatorInstruction, #15
|
||||
IsNotZero, SlotToReg, RegToSlot, SlotToReg, SlotToReg, #20
|
||||
Transfer, Transfer, LoadData, OperatorInstruction, LoadData, #25
|
||||
OperatorInstruction, OperatorInstruction, Branch, LoadData, Transfer, #30
|
||||
OperatorInstruction, OperatorInstruction, LoadData, Branch, Transfer, #30
|
||||
OperatorInstruction, OperatorInstruction, LoadData, Transfer, OperatorInstruction, #35
|
||||
OperatorInstruction, LoadData, Transfer, OperatorInstruction, OperatorInstruction, #40
|
||||
LoadData, OperatorInstruction, LoadData, Transfer, OperatorInstruction, #45
|
||||
OperatorInstruction, Transfer, LoadData, OperatorInstruction, LoadData, #50
|
||||
OperatorInstruction, OperatorInstruction, RegToSlot, RegToSlot, SlotToReg, #55
|
||||
RegToSlot, Branch, SlotToReg, SlotToReg, RegToSlot, #60
|
||||
SlotToReg, SlotToReg, SlotToReg, FunctionReturn, SlotToReg, #65
|
||||
RegToSlot, Branch, SlotToReg, Branch, SlotToReg, #60
|
||||
RegToSlot, SlotToReg, SlotToReg, FunctionReturn, SlotToReg, #65
|
||||
RegToSlot, Branch, SlotToReg, SlotToReg, RegToSlot, #70
|
||||
SlotToReg, SlotToReg, SlotToReg, FunctionReturn, Transfer, #75
|
||||
SlotToReg, SlotToReg, Syscall, NilClass,] #80
|
||||
SlotToReg, SlotToReg, FunctionReturn, Transfer, SlotToReg, #75
|
||||
SlotToReg, Transfer, Syscall, NilClass,] #80
|
||||
assert_equal 2 , get_return
|
||||
end
|
||||
|
||||
@ -37,10 +37,10 @@ module Risc
|
||||
assert_equal 25 , @interpreter.get_register(load_ins.register).value
|
||||
end
|
||||
def test_return_class
|
||||
ret = main_ticks(74)
|
||||
ret = risc(73)
|
||||
assert_equal FunctionReturn , ret.class
|
||||
link = @interpreter.get_register( ret.register )
|
||||
assert_equal ::Integer , link.class
|
||||
assert_equal Parfait::ReturnAddress , link.class
|
||||
end
|
||||
end
|
||||
end
|
||||
|
@ -15,30 +15,27 @@ module Risc
|
||||
check_main_chain [LoadConstant, SlotToReg, RegToSlot, LoadConstant, SlotToReg, #5
|
||||
RegToSlot, LoadConstant, SlotToReg, RegToSlot, LoadConstant, #10
|
||||
SlotToReg, RegToSlot, SlotToReg, FunctionCall, LoadConstant, #15
|
||||
SlotToReg, LoadConstant, OperatorInstruction, IsNotZero, SlotToReg, #20
|
||||
LoadConstant, SlotToReg, OperatorInstruction, IsNotZero, SlotToReg, #20
|
||||
RegToSlot, SlotToReg, SlotToReg, SlotToReg, SlotToReg, #25
|
||||
OperatorInstruction, RegToSlot, RegToSlot, SlotToReg, RegToSlot, #30
|
||||
Branch, Branch, SlotToReg, SlotToReg, RegToSlot, #35
|
||||
SlotToReg, SlotToReg, SlotToReg, FunctionReturn, SlotToReg, #40
|
||||
RegToSlot, Branch, SlotToReg, SlotToReg, RegToSlot, #45
|
||||
SlotToReg, SlotToReg, SlotToReg, FunctionReturn, Transfer, #50
|
||||
SlotToReg, SlotToReg, Syscall, NilClass,] #55
|
||||
Branch, SlotToReg, SlotToReg, RegToSlot, SlotToReg, #35
|
||||
SlotToReg, FunctionReturn, SlotToReg, RegToSlot, Branch, #40
|
||||
SlotToReg, SlotToReg, RegToSlot, SlotToReg, SlotToReg, #45
|
||||
FunctionReturn, Transfer, SlotToReg, SlotToReg, Transfer, #50
|
||||
Syscall, NilClass,] #55
|
||||
assert_equal 1 , get_return
|
||||
end
|
||||
def test_op
|
||||
op = main_ticks(26)
|
||||
assert_equal OperatorInstruction , op.class
|
||||
assert_equal :- , op.operator
|
||||
assert_equal :r2 , op.left.symbol
|
||||
assert_equal :r3 , op.right.symbol
|
||||
assert_equal 1 , @interpreter.get_register(:r2)
|
||||
assert_equal 5 , @interpreter.get_register(:r3)
|
||||
assert_operator 26 , :- , "message.receiver.data_1" , "message.arg1.data_1" , "op_-_"
|
||||
assert_equal 1 , @interpreter.get_register(@instruction.result)
|
||||
assert_equal 6 , @interpreter.get_register(:"message.receiver.data_1")
|
||||
assert_equal 5 , @interpreter.get_register(:"message.arg1.data_1")
|
||||
end
|
||||
def test_return
|
||||
ret = main_ticks(49)
|
||||
ret = main_ticks(46)
|
||||
assert_equal FunctionReturn , ret.class
|
||||
assert_equal :r3 , ret.register.symbol
|
||||
assert_equal 36540 , @interpreter.get_register(ret.register)
|
||||
assert_equal :"message.return_address" , ret.register.symbol
|
||||
assert_equal 36572 , @interpreter.get_register(ret.register).value
|
||||
end
|
||||
end
|
||||
end
|
||||
|
@ -14,25 +14,21 @@ module Risc
|
||||
#show_main_ticks # get output of what is
|
||||
check_main_chain [LoadConstant, SlotToReg, RegToSlot, LoadConstant, SlotToReg, #5
|
||||
RegToSlot, LoadConstant, SlotToReg, RegToSlot, SlotToReg, #10
|
||||
FunctionCall, LoadConstant, SlotToReg, LoadConstant, OperatorInstruction, #15
|
||||
FunctionCall, LoadConstant, LoadConstant, SlotToReg, OperatorInstruction, #15
|
||||
IsNotZero, SlotToReg, RegToSlot, SlotToReg, SlotToReg, #20
|
||||
LoadData, OperatorInstruction, RegToSlot, RegToSlot, SlotToReg, #25
|
||||
RegToSlot, Branch, SlotToReg, SlotToReg, RegToSlot, #30
|
||||
SlotToReg, SlotToReg, SlotToReg, FunctionReturn, SlotToReg, #35
|
||||
RegToSlot, Branch, SlotToReg, Branch, SlotToReg, #30
|
||||
RegToSlot, SlotToReg, SlotToReg, FunctionReturn, SlotToReg, #35
|
||||
RegToSlot, Branch, SlotToReg, SlotToReg, RegToSlot, #40
|
||||
SlotToReg, SlotToReg, SlotToReg, FunctionReturn, Transfer, #45
|
||||
SlotToReg, SlotToReg, Syscall, NilClass,] #50
|
||||
SlotToReg, SlotToReg, FunctionReturn, Transfer, SlotToReg, #45
|
||||
SlotToReg, Transfer, Syscall, NilClass,] #50
|
||||
assert_equal 2 , get_return
|
||||
end
|
||||
|
||||
def test_op
|
||||
op = main_ticks(22)
|
||||
assert_equal OperatorInstruction , op.class
|
||||
assert_equal :>> , op.operator
|
||||
assert_equal :r2 , op.left.symbol
|
||||
assert_equal :r3 , op.right.symbol
|
||||
assert_equal 2 , @interpreter.get_register(:r2)
|
||||
assert_equal 2 , @interpreter.get_register(:r3)
|
||||
assert_operator 22 , :>>, "message.receiver.data_1" , "integer_1" , "op_>>_"
|
||||
assert_equal 2 , @interpreter.get_register(:integer_1)
|
||||
assert_equal 9 , @interpreter.get_register(:"message.receiver.data_1")
|
||||
end
|
||||
end
|
||||
end
|
||||
|
@ -15,14 +15,14 @@ module Risc
|
||||
check_main_chain [LoadConstant, SlotToReg, RegToSlot, LoadConstant, SlotToReg, #5
|
||||
RegToSlot, LoadConstant, SlotToReg, RegToSlot, LoadConstant, #10
|
||||
SlotToReg, RegToSlot, SlotToReg, FunctionCall, LoadConstant, #15
|
||||
SlotToReg, LoadConstant, OperatorInstruction, IsNotZero, SlotToReg, #20
|
||||
LoadConstant, SlotToReg, OperatorInstruction, IsNotZero, SlotToReg, #20
|
||||
RegToSlot, SlotToReg, SlotToReg, SlotToReg, SlotToReg, #25
|
||||
OperatorInstruction, RegToSlot, RegToSlot, SlotToReg, RegToSlot, #30
|
||||
Branch, Branch, SlotToReg, SlotToReg, RegToSlot, #35
|
||||
SlotToReg, SlotToReg, SlotToReg, FunctionReturn, SlotToReg, #40
|
||||
RegToSlot, Branch, SlotToReg, SlotToReg, RegToSlot, #45
|
||||
SlotToReg, SlotToReg, SlotToReg, FunctionReturn, Transfer, #50
|
||||
SlotToReg, SlotToReg, Syscall, NilClass,] #55
|
||||
Branch, SlotToReg, SlotToReg, RegToSlot, SlotToReg, #35
|
||||
SlotToReg, FunctionReturn, SlotToReg, RegToSlot, Branch, #40
|
||||
SlotToReg, SlotToReg, RegToSlot, SlotToReg, SlotToReg, #45
|
||||
FunctionReturn, Transfer, SlotToReg, SlotToReg, Transfer, #50
|
||||
Syscall, NilClass,] #55
|
||||
assert_equal 0 , get_return
|
||||
end
|
||||
def test_zero
|
||||
@ -30,12 +30,9 @@ module Risc
|
||||
assert @interpreter.flags[:zero]
|
||||
end
|
||||
def test_op
|
||||
op = main_ticks(26)
|
||||
assert_equal OperatorInstruction , op.class
|
||||
assert_equal :r2 , op.left.symbol
|
||||
assert_equal :r3 , op.right.symbol
|
||||
assert_equal 0 , @interpreter.get_register(:r2)
|
||||
assert_equal 2**31 , @interpreter.get_register(:r3)
|
||||
assert_operator 26 , :*, "message.receiver.data_1" , "message.arg1.data_1" , "op_*_"
|
||||
assert_equal 2147483648 , @interpreter.get_register(:"message.arg1.data_1")
|
||||
assert_equal 2147483648 , @interpreter.get_register(:"message.receiver.data_1")
|
||||
end
|
||||
def test_overflow
|
||||
main_ticks( 26 )
|
||||
|
@ -25,22 +25,6 @@ module Risc
|
||||
Syscall, NilClass,] #55
|
||||
assert_equal 10 , get_return
|
||||
end
|
||||
def test_base
|
||||
assert_function_call 0 , :main
|
||||
end
|
||||
def test_load_receiver
|
||||
assert_slot_to_reg( 22 , :message , 2 , "message.receiver")
|
||||
end
|
||||
def test_reduce_receiver
|
||||
assert_slot_to_reg( 23 , "message.receiver" , 2 , "message.receiver.data_1" )
|
||||
end
|
||||
def test_slot_args #load args from message
|
||||
assert_slot_to_reg( 24 , :message , 9 , "message.arg1")
|
||||
end
|
||||
def test_reduce_arg
|
||||
assert_slot_to_reg( 25 , "message.arg1" , 2 , "message.arg1.data_1")
|
||||
assert_equal 5 , @interpreter.get_register(:"message.arg1.data_1")
|
||||
end
|
||||
def test_op
|
||||
assert_operator 26, :+ , "message.receiver.data_1" , "message.arg1.data_1" , "op_+_"
|
||||
assert_equal 10 , @interpreter.get_register(@instruction.result.symbol)
|
||||
|
Loading…
Reference in New Issue
Block a user