2017-01-19 09:02:29 +02:00
|
|
|
module Risc
|
2016-12-25 18:11:58 +02:00
|
|
|
# Setter is a base class for set instructions (RegToSlot and RegToByte , possibly more coming)
|
2016-12-11 14:06:09 +02:00
|
|
|
#
|
2016-12-11 14:12:35 +02:00
|
|
|
# The instruction that is modelled is loading data from a register into an array
|
2016-12-11 14:06:09 +02:00
|
|
|
#
|
|
|
|
# Setter has a
|
2017-01-19 09:02:29 +02:00
|
|
|
# - Risc that the data is comes from
|
2016-12-11 14:12:35 +02:00
|
|
|
# - an array where the data goes
|
2016-12-11 14:06:09 +02:00
|
|
|
# - and (array) index
|
2016-12-11 14:12:35 +02:00
|
|
|
|
|
|
|
# Getter and Setter api follow the pattern from -> to
|
|
|
|
|
2016-12-11 14:06:09 +02:00
|
|
|
class Setter < Instruction
|
|
|
|
|
|
|
|
# If you had a c array and index offset
|
|
|
|
# the instruction would do array[index] = register
|
2018-03-14 17:39:49 +05:30
|
|
|
# The arguments are in the order that makes sense for the Instruction name
|
2018-03-22 18:38:19 +02:00
|
|
|
# So RegToSlot means the register (first argument) moves to the slot (array and index)
|
2018-03-14 17:39:49 +05:30
|
|
|
def initialize( source , register , array , index )
|
2016-12-11 14:06:09 +02:00
|
|
|
super(source)
|
|
|
|
@register = register
|
|
|
|
@array = array
|
|
|
|
@index = index
|
|
|
|
raise "index 0 " if index == 0
|
2017-01-19 09:02:29 +02:00
|
|
|
raise "Not integer or reg #{index}" unless index.is_a?(Numeric) or RiscValue.look_like_reg(index)
|
|
|
|
raise "Not register #{register}" unless RiscValue.look_like_reg(register)
|
|
|
|
raise "Not register #{array}" unless RiscValue.look_like_reg(array)
|
2016-12-11 14:06:09 +02:00
|
|
|
end
|
|
|
|
attr_accessor :register , :array , :index
|
|
|
|
|
2016-12-16 00:30:26 +02:00
|
|
|
def to_s
|
2018-03-22 18:38:19 +02:00
|
|
|
class_source "#{register} -> #{array}[#{index}]"
|
2016-12-16 00:30:26 +02:00
|
|
|
end
|
|
|
|
|
2016-12-11 14:06:09 +02:00
|
|
|
end
|
|
|
|
|
|
|
|
end
|