2019-10-03 21:07:55 +03:00
|
|
|
module SlotMachine
|
2017-09-14 16:07:02 +03:00
|
|
|
|
2019-10-03 21:07:55 +03:00
|
|
|
# SlotMachine internal check, as the name says to see if two values are not the same
|
2017-09-14 16:07:02 +03:00
|
|
|
# In other words, we this checks identity, bit-values, pointers
|
|
|
|
#
|
2020-02-11 16:19:52 +07:00
|
|
|
# The values that are compared are defined as Slots, ie can be anything
|
2017-09-14 16:07:02 +03:00
|
|
|
# available to the machine through frame message or self
|
|
|
|
#
|
2019-10-03 21:07:55 +03:00
|
|
|
# Acording to SlotMachine::Check logic, we jump to the given label is the values are the same
|
2018-03-24 17:54:15 +02:00
|
|
|
#
|
2017-09-14 16:07:02 +03:00
|
|
|
class NotSameCheck < Check
|
|
|
|
attr_reader :left , :right
|
|
|
|
|
2018-03-21 12:38:28 +05:30
|
|
|
def initialize(left, right , label)
|
|
|
|
super(label)
|
2017-09-14 16:07:02 +03:00
|
|
|
@left , @right = left , right
|
|
|
|
end
|
2018-03-13 16:16:06 +05:30
|
|
|
|
2018-04-17 20:26:15 +03:00
|
|
|
def to_s
|
|
|
|
"NotSameCheck: #{left}:#{right}"
|
|
|
|
end
|
|
|
|
|
2018-03-24 17:54:15 +02:00
|
|
|
# basically move both left and right values into register
|
|
|
|
# subtract them and see if IsZero comparison
|
2018-03-21 12:38:28 +05:30
|
|
|
def to_risc(compiler)
|
2018-08-19 13:18:25 +03:00
|
|
|
l_reg = left.to_register(compiler, self)
|
|
|
|
r_reg = right.to_register(compiler, self)
|
|
|
|
compiler.add_code Risc.op( self , :- , l_reg , r_reg)
|
2020-02-19 02:16:44 +07:00
|
|
|
compiler.add_code Risc::IsZero.new( self, false_label.risc_label(compiler))
|
2018-03-13 16:16:06 +05:30
|
|
|
end
|
2017-09-14 16:07:02 +03:00
|
|
|
end
|
|
|
|
end
|