Guide:Execution Model
Execution model
The way an Ioke program works is very simple. Everything executes based on two things. The first is the context, or the ground, and the second is the receiver. The first message sent in each message chain will have the ground as receiver. The default ground in Ioke source files is an object called Ground
. This object is in the mimic chain for most regular objects created in Ioke, which means that things defined at the top level will generally be available in most objects. Inside of methods and blocks, the ground will be different. Exactly in what way is defined by the type of code executing.
Every message in a chain will be sent to the receiver of that message. That receiver is the result of the last message, or the current ground if there was no previous message, or if that previous message was a terminator. So Ioke code like foo bar(flux bar) quux
involves 5 different messages.
- The message
foo
is sent toGround
, which is the current ground and also the default receiver. - The message
bar
is sent to the result of thefoo
message. The value returned will be activated. - The cell
bar
contains a method in this case, and that method expects one argument, so that forces evaluation of the arguments. - The message
flux
is sent toGround
, since it's the ground and there is no prior message inside of an argument list. - The message
bar
is sent to the result of theflux
message. - The result of the
bar
message is used as the argument value given to the outsidebar
method. - The message
quux
is sent to the result of the initialbar
message. - The result of the
quux
message is thrown away, unless this code is part of a larger piece of code.
This description generally describes what happens in the case of this code. The more general control flow is this:
- A message is encountered
- If the message is a symbol message, the corresponding symbol will be returned.
- Otherwise the name of the message will be looked up in the receiver, or in the receivers mimics.
- If the name is found and is not activatable, the value of that name (the cell) is returned.
- If the name is found and is activatable, it will be activated, with the current ground, receiver and message sent to the activatable object.
- If the name is not found, a second search is done for the name
pass
. If a pass is found, use that instead of the name of the original message, and go back to 4. - If a pass is not found, signal a
Condition Error NoSuchCell
condition.
Exactly what happens when an object is activated depends on what kind of code gets activated. It's really up to the method, block or macro to handle evaluation of arguments in any way it likes - including not evaluating them. For a description of the default models available, see the chapter on code.