2014-05-27 16:33:24 +03:00
|
|
|
module Ast
|
|
|
|
class ReturnExpression < Expression
|
2014-06-04 22:03:45 +03:00
|
|
|
# attr_reader :expression
|
2014-06-10 23:57:56 +03:00
|
|
|
def compile context
|
2014-06-11 00:38:46 +03:00
|
|
|
into = context.function
|
2014-06-10 13:29:01 +03:00
|
|
|
puts "compiling return expression #{expression}, now return in return_regsiter"
|
2014-06-10 23:57:56 +03:00
|
|
|
expression_value = expression.compile(context)
|
2014-05-28 20:13:03 +03:00
|
|
|
# copied from function expression: TODO make function
|
|
|
|
|
2014-06-10 13:29:01 +03:00
|
|
|
return_reg = Vm::Integer.new(Vm::RegisterMachine.instance.return_register)
|
2014-06-07 17:59:44 +03:00
|
|
|
if expression_value.is_a?(Vm::IntegerConstant) or expression_value.is_a?(Vm::ObjectConstant)
|
2014-05-31 16:43:03 +03:00
|
|
|
return_reg.load into , expression_value
|
2014-05-28 20:13:03 +03:00
|
|
|
else
|
2014-06-07 17:59:44 +03:00
|
|
|
return_reg.move( into, expression_value ) if expression_value.register_symbol != return_reg.register_symbol
|
2014-05-28 20:13:03 +03:00
|
|
|
end
|
|
|
|
#function.set_return return_reg
|
|
|
|
return return_reg
|
2014-05-27 16:33:24 +03:00
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
|
|
|
|
end
|