2014-10-03 10:07:18 +02:00
|
|
|
module Register
|
2015-06-21 20:00:16 +02:00
|
|
|
|
|
|
|
# SetSlot moves data into memory from a register.
|
|
|
|
# GetSlot moves data into a register from memory.
|
|
|
|
# Both use a base memory (a register)
|
|
|
|
|
|
|
|
# While the virtual machine has only one instruction (Set) to move data between slots,
|
|
|
|
# the register has two, namely GetSlot and SetSlot
|
2014-10-03 10:07:18 +02:00
|
|
|
#
|
2015-06-21 20:00:16 +02:00
|
|
|
# This is because that is what cpu's can do. In programming terms this would be accessing
|
|
|
|
# an element in an array, in the case of SetSlot setting the register in the array.
|
|
|
|
|
|
|
|
# btw: to move data between registers, use RegisterTransfer
|
|
|
|
|
2014-10-03 10:07:18 +02:00
|
|
|
class SetSlot < Instruction
|
2015-06-21 20:00:16 +02:00
|
|
|
|
|
|
|
# If you had a c array and index offset
|
|
|
|
# the instruction would do array[index] = register
|
2015-06-29 19:56:11 +02:00
|
|
|
# So SetSlot means the register (first argument) moves to the slot (array and index)
|
2015-06-21 20:00:16 +02:00
|
|
|
def initialize register , array , index
|
|
|
|
@register = register
|
|
|
|
@array = array
|
2014-10-03 10:07:18 +02:00
|
|
|
@index = index
|
2015-06-29 19:56:11 +02:00
|
|
|
raise "not integer #{index}" unless index.is_a? Numeric
|
|
|
|
raise "Not register #{register}" unless Register::RegisterReference.look_like_reg(register)
|
|
|
|
raise "Not register #{array}" unless Register::RegisterReference.look_like_reg(array)
|
2014-10-03 10:07:18 +02:00
|
|
|
end
|
2015-06-21 20:00:16 +02:00
|
|
|
attr_accessor :register , :array , :index
|
2014-10-03 10:07:18 +02:00
|
|
|
end
|
|
|
|
end
|