rubyx/lib/risc/instructions/operator_instruction.rb

35 lines
986 B
Ruby
Raw Normal View History

module Risc
2015-08-04 22:01:20 +03:00
def self.operators
[:+, :-, :>>, :<<, :*, :&, :|]
end
2018-03-24 17:53:27 +02:00
# Destructive operator instructions on the two registers given
#
# left = left OP right
#
# With OP being the normal logical and mathematical operations provided by
# cpus. Ie "+" , "-", ">>", "<<", "*", "&", "|"
#
2015-08-04 22:01:20 +03:00
class OperatorInstruction < Instruction
2018-03-24 17:53:27 +02:00
def initialize( source , operator , left , right )
2015-08-04 22:01:20 +03:00
super(source)
@operator = operator
raise "unsuported operator :#{operator}:" unless Risc.operators.include?(operator)
2015-08-04 22:01:20 +03:00
@left = left
@right = right
raise "Not register #{left}" unless RegisterValue.look_like_reg(left)
raise "Not register #{right}" unless RegisterValue.look_like_reg(right)
2015-08-04 22:01:20 +03:00
end
2015-08-07 16:46:55 +03:00
attr_reader :operator, :left , :right
2015-08-04 22:01:20 +03:00
def to_s
2018-03-22 18:38:19 +02:00
class_source "#{left} #{operator} #{right}"
2015-08-04 22:01:20 +03:00
end
2015-11-21 14:17:54 +02:00
end
2018-03-24 17:53:27 +02:00
def self.op( source , operator , left , right )
OperatorInstruction.new( source , operator , left , right )
2015-08-04 22:01:20 +03:00
end
end