2015-10-23 14:22:55 +03:00
|
|
|
module Soml
|
2015-09-19 18:56:18 +03:00
|
|
|
Compiler.class_eval do
|
2015-09-19 16:28:41 +03:00
|
|
|
|
|
|
|
# attr_reader :name
|
|
|
|
# compiling name needs to check if it's a variable and if so resolve it
|
|
|
|
# otherwise it's a method without args and a send is issued.
|
|
|
|
# whichever way this goes the result is stored in the return slot (as all compiles)
|
2015-10-09 17:51:14 +03:00
|
|
|
def on_name statement
|
|
|
|
name = statement.to_a.first
|
2015-10-18 17:20:19 +03:00
|
|
|
if( name == :self)
|
|
|
|
ret = use_reg @clazz.name
|
2015-10-23 14:08:12 +03:00
|
|
|
add_code Register.get_slot(statement , :message , :receiver , ret )
|
2015-10-18 17:20:19 +03:00
|
|
|
return ret
|
|
|
|
end
|
2015-09-19 16:28:41 +03:00
|
|
|
# either an argument, so it's stored in message
|
2015-10-06 00:27:13 +03:00
|
|
|
if( index = @method.has_arg(name))
|
2015-10-14 21:34:18 +03:00
|
|
|
ret = use_reg @method.arguments[index].type
|
2015-10-23 14:08:12 +03:00
|
|
|
add_code Register.get_slot(statement , :message , index + Parfait::Message.offset , ret )
|
2015-10-14 21:34:18 +03:00
|
|
|
return ret
|
2015-09-19 16:28:41 +03:00
|
|
|
else # or a local so it is in the frame
|
2015-10-06 00:27:13 +03:00
|
|
|
index = @method.has_local( name )
|
2015-09-27 16:06:48 +03:00
|
|
|
if(index)
|
2015-10-18 17:20:19 +03:00
|
|
|
frame = use_reg :Frame
|
2015-10-23 14:08:12 +03:00
|
|
|
add_code Register.get_slot(statement , :message , :frame , frame )
|
2015-10-14 21:34:18 +03:00
|
|
|
ret = use_reg @method.locals[index].type
|
2015-10-23 14:08:12 +03:00
|
|
|
add_code Register.get_slot(statement , frame , index + Parfait::Frame.offset , ret )
|
2015-10-14 21:34:18 +03:00
|
|
|
return ret
|
2015-09-27 16:06:48 +03:00
|
|
|
end
|
2015-09-19 16:28:41 +03:00
|
|
|
end
|
2015-10-06 15:26:57 +03:00
|
|
|
raise "must define variable #{name} before using it"
|
2015-09-19 16:28:41 +03:00
|
|
|
end
|
|
|
|
|
|
|
|
end #module
|
|
|
|
end
|