# this is not a "normal" ruby file, ie it is not required by salama # instead it is parsed by salama to define part of the program that runs class Message def get_type_for name index = @layout.get_index name get_at index end 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 else 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 end end unless method message = Message.new( @receiver , :method_missing , [@method_name] + @args) message.send else method.call end end end