2014-08-05 15:55:24 +03:00
|
|
|
|
2015-04-06 11:38:11 +03:00
|
|
|
# A message is what is sent when you invoke a method. Args and stuff are packed up in to a Message
|
|
|
|
# and the Message is sent to the receiver.
|
2014-09-24 18:25:18 +03:00
|
|
|
|
2015-05-11 18:55:49 +03:00
|
|
|
module Parfait
|
|
|
|
class Message < Object
|
2014-08-06 18:37:19 +03:00
|
|
|
|
2015-06-28 22:02:07 +03:00
|
|
|
def initialize next_m
|
|
|
|
@next_message = next_m
|
|
|
|
super()
|
|
|
|
end
|
|
|
|
|
2015-05-11 18:55:49 +03:00
|
|
|
def get_type_for(name)
|
|
|
|
index = @layout.get_index(name)
|
|
|
|
get_at(index)
|
|
|
|
end
|
2014-08-06 18:37:19 +03:00
|
|
|
|
2015-05-11 18:55:49 +03:00
|
|
|
def __send
|
|
|
|
typ = get_type_for( :receiver )
|
|
|
|
# TODO: this will obviously be recoded as case, once that is done :-)
|
|
|
|
# depending on value type get method
|
|
|
|
if( typ == Integer )
|
|
|
|
method = Integer.get_method @method_name
|
2014-08-06 18:37:19 +03:00
|
|
|
else
|
2015-05-11 18:55:49 +03:00
|
|
|
if( typ != ObjectReference )
|
|
|
|
raise "unimplemented case"
|
|
|
|
else
|
|
|
|
method = @receiver.get_singeton_method @method_name
|
|
|
|
# Find the method for the given object (receiver) according to ruby dispatch rules:
|
|
|
|
# - see if the receiver object has a (singleton) method by the name
|
|
|
|
# - get receivers class and look for instance methods of the name
|
|
|
|
# - go up inheritance tree
|
|
|
|
# - start over with method_missing instead
|
|
|
|
# -> guaranteed to end at object.method_missing
|
|
|
|
unless method
|
|
|
|
cl = @receiver.layout.object_class
|
|
|
|
method = cl.get_instance_or_super_method @method_name
|
|
|
|
end
|
2014-08-06 18:37:19 +03:00
|
|
|
end
|
|
|
|
end
|
2015-05-11 18:55:49 +03:00
|
|
|
unless method
|
|
|
|
message = Message.new( @receiver , :method_missing , [@method_name] + @args)
|
|
|
|
message.send
|
|
|
|
else
|
|
|
|
method.call
|
|
|
|
end
|
2014-08-05 15:55:24 +03:00
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|