2017-01-14 19:28:44 +02:00
|
|
|
module Vm
|
2016-12-09 12:13:33 +02:00
|
|
|
module NameExpression
|
2015-09-19 16:28:41 +03:00
|
|
|
|
|
|
|
# attr_reader :name
|
2016-03-07 11:55:28 +02:00
|
|
|
# compiling name needs to check if it's a local variable
|
|
|
|
# or an argument
|
2015-09-19 16:28:41 +03:00
|
|
|
# whichever way this goes the result is stored in the return slot (as all compiles)
|
2017-01-16 09:33:49 +02:00
|
|
|
def on_KnownName statement
|
2016-03-07 11:55:28 +02:00
|
|
|
name = statement.name
|
2016-12-09 12:13:33 +02:00
|
|
|
[:self , :space , :message].each do |special|
|
2016-12-28 21:10:14 +02:00
|
|
|
return send(:"load_special_#{special}" , statement ) if name == special
|
2015-11-09 23:29:14 +02:00
|
|
|
end
|
2017-01-16 09:33:49 +02:00
|
|
|
raise "Unknow 'known' expression #{name}"
|
2016-12-09 12:13:33 +02:00
|
|
|
end
|
|
|
|
|
2017-01-16 09:33:49 +02:00
|
|
|
def on_ArgumentName(statement)
|
2016-12-28 21:10:14 +02:00
|
|
|
name = statement.name
|
2017-01-15 12:59:03 +02:00
|
|
|
index = @method.has_argument(name)
|
2017-01-16 09:33:49 +02:00
|
|
|
raise "no arg #{name}" unless index
|
2016-12-28 21:10:14 +02:00
|
|
|
named_list = use_reg :NamedList
|
2017-01-15 12:59:03 +02:00
|
|
|
ret = use_reg @method.arguments_type(index)
|
2016-12-28 21:10:14 +02:00
|
|
|
#puts "For #{name} at #{index} got #{@method.arguments.inspect}"
|
|
|
|
add_slot_to_reg("#{statement} load args" , :message , :arguments, named_list )
|
|
|
|
add_slot_to_reg("#{statement} load #{name}" , named_list , index + 1, ret )
|
|
|
|
return ret
|
|
|
|
end
|
|
|
|
|
2017-01-16 09:33:49 +02:00
|
|
|
def on_LocalName( statement )
|
2016-12-27 20:39:39 +02:00
|
|
|
name = statement.name
|
|
|
|
index = @method.has_local( name )
|
2017-01-16 09:33:49 +02:00
|
|
|
raise "must define local '#{name}' before using it" unless index
|
2016-12-21 18:51:22 +02:00
|
|
|
named_list = use_reg :NamedList
|
2016-12-28 20:37:54 +02:00
|
|
|
add_slot_to_reg("#{name} load locals" , :message , :locals , named_list )
|
2016-12-13 19:18:17 +02:00
|
|
|
ret = use_reg @method.locals_type( index )
|
2016-12-28 20:37:54 +02:00
|
|
|
add_slot_to_reg("#{name} load from locals" , named_list , index + 1, ret )
|
2016-12-09 12:13:33 +02:00
|
|
|
return ret
|
|
|
|
end
|
|
|
|
|
2016-12-28 21:10:14 +02:00
|
|
|
def load_special_self(statement)
|
2016-12-14 13:24:42 +02:00
|
|
|
ret = use_reg @type
|
2016-12-28 20:37:54 +02:00
|
|
|
add_slot_to_reg("#{statement} load self" , :message , :receiver , ret )
|
2016-12-09 12:13:33 +02:00
|
|
|
return ret
|
2015-09-19 16:28:41 +03:00
|
|
|
end
|
|
|
|
|
2016-12-28 21:10:14 +02:00
|
|
|
def load_special_space(statement)
|
2016-12-30 14:10:49 +02:00
|
|
|
space = Parfait.object_space
|
2016-12-09 12:13:33 +02:00
|
|
|
reg = use_reg :Space , space
|
2016-12-28 20:37:54 +02:00
|
|
|
add_load_constant( "#{statement} load space", space , reg )
|
2016-12-09 12:13:33 +02:00
|
|
|
return reg
|
|
|
|
end
|
2016-12-27 20:39:39 +02:00
|
|
|
|
2016-12-28 21:10:14 +02:00
|
|
|
def load_special_message(statement)
|
2016-12-09 12:13:33 +02:00
|
|
|
reg = use_reg :Message
|
2017-01-19 09:02:29 +02:00
|
|
|
add_transfer( "#{statement} load message", Risc.message_reg , reg )
|
2016-12-09 12:13:33 +02:00
|
|
|
return reg
|
|
|
|
end
|
2015-09-19 16:28:41 +03:00
|
|
|
end #module
|
|
|
|
end
|