rubyx/lib/parfait/message.rb

59 lines
1.7 KiB
Ruby
Raw Normal View History

2014-08-05 14:55:24 +02:00
# A message is what is created when a message is sent. Args and stuff are packed up in to a
# Message and the Message is activated (by swapping it into the machine).
# Part of the housekeeping (see attributes) makes messages a double linked list (next_message and
2018-03-14 15:59:51 +01:00
# caller) , and maybe surprisingly this means that we can create all messages at compile-time
# and link them up and never have to touch that list again.
2018-03-14 15:59:51 +01:00
# All the args and receiver data changes, but the list of messages stays constant
# (a pleasant stupor while we ignore closures and longer extended frames ).
module Parfait
class Message < Object
# :next_message => :Message, :receiver => :Object, :frame => :NamedList ,
# :return_address => :Integer, :return_value => :Integer,
# :caller => :Message , :name => :Word , :arguments => :NamedList
attr :type, :next_message
attr :receiver , :frame
attr :return_address, :return_value
attr :caller , :method
attr :arguments_given
attr :arg1 , :arg2, :arg3, :arg4, :arg5, :arg6
def self.type_length
16
end
def self.memory_size
32
end
def self.args_start_at
Parfait.object_space.get_type_by_class_name(:Message).variable_index(:arguments_given)
end
def initialize( )
2015-06-28 21:02:07 +02:00
super()
self.frame = NamedList.new()
self.arguments_given = Parfait::Integer.new(0)
2015-06-28 21:02:07 +02:00
end
public :initialize
2015-06-28 21:02:07 +02:00
def set_receiver(rec)
self.receiver = rec
end
def set_caller(caller)
caller = caller
end
def get_type_for(name)
index = type.get_index(name)
get_at(index)
end
2018-07-04 07:28:29 +02:00
def to_s
"Message:#{method&.name}(#{arguments_given})"
2018-07-04 07:28:29 +02:00
end
2014-08-05 14:55:24 +02:00
end
end