2017-01-14 19:28:44 +02:00
|
|
|
module Vm
|
2016-12-09 14:17:01 +02:00
|
|
|
module OperatorExpression
|
2015-10-07 10:05:34 +03:00
|
|
|
|
2016-03-07 11:55:28 +02:00
|
|
|
def on_OperatorExpression statement
|
2016-12-09 14:17:01 +02:00
|
|
|
# operator , left_e , right_e = *statement
|
2015-10-15 09:32:47 +03:00
|
|
|
# left and right must be expressions. Expressions return a register when compiled
|
2016-03-07 11:55:28 +02:00
|
|
|
left_reg = process(statement.left_expression)
|
|
|
|
right_reg = process(statement.right_expression)
|
2015-10-15 09:32:47 +03:00
|
|
|
raise "Not register #{left_reg}" unless left_reg.is_a?(Register::RegisterValue)
|
|
|
|
raise "Not register #{right_reg}" unless right_reg.is_a?(Register::RegisterValue)
|
2016-03-07 11:55:28 +02:00
|
|
|
add_code Register::OperatorInstruction.new(statement,statement.operator,left_reg,right_reg)
|
2015-10-15 09:32:47 +03:00
|
|
|
return left_reg # though this has wrong value attached
|
2015-09-19 16:28:41 +03:00
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|