2014-08-28 22:32:53 +03:00
|
|
|
### Parfait: a thin layer
|
|
|
|
|
2015-05-11 18:55:49 +03:00
|
|
|
Parfait is the run-time of the **vm**.
|
2015-03-25 17:16:20 +02:00
|
|
|
To be more precise, it is that part of the run-time that can be expressed in ruby.
|
2014-06-14 00:19:12 +03:00
|
|
|
|
2015-03-25 17:16:20 +02:00
|
|
|
The run-time needs to contain quite a lot of functionality for a dynamic system.
|
2015-05-11 18:55:49 +03:00
|
|
|
And a large part of that functionality must actually be used at compile time too.
|
2014-06-14 00:19:12 +03:00
|
|
|
|
2015-03-25 17:16:20 +02:00
|
|
|
We reuse the Parfait code at compile-time, by inlining it.
|
2014-06-14 00:19:12 +03:00
|
|
|
|
2014-08-05 15:55:24 +03:00
|
|
|
A work in progress that started from here : http://salama.github.io/2014/06/10/more-clarity.html went on here
|
|
|
|
http://salama.github.io/2014/07/05/layers-vs-passes.html
|
|
|
|
|
2015-05-11 18:55:49 +03:00
|
|
|
A step back: the code (program) we compile runs at run - time.
|
2014-08-05 15:55:24 +03:00
|
|
|
And so does parfait. So all we have to do is compile it with the program.
|
|
|
|
|
|
|
|
And thus parfait can be used at run-time.
|
|
|
|
|
|
|
|
It's too simple: just slips off the mind like a fish into water.
|
|
|
|
|
2015-03-25 17:29:39 +02:00
|
|
|
Parfait has a brother, the Builtin module. Builtin contains everything that can not be coded in ruby,
|
2015-05-12 19:10:45 +03:00
|
|
|
but we still need (things like List access).
|
2014-08-28 19:12:46 +03:00
|
|
|
|
2014-08-05 15:55:24 +03:00
|
|
|
#### Example: Message send
|
|
|
|
|
2014-08-28 19:12:46 +03:00
|
|
|
It felt a little stupid that it took me so long to notice that sending a message is very closely related to the
|
2014-08-05 15:55:24 +03:00
|
|
|
existing ruby method Object.send
|
|
|
|
|
2015-03-25 17:29:39 +02:00
|
|
|
Off course Object.send takes symbol and the arguments and has the receiver, so all the elements of our
|
2015-05-11 18:55:49 +03:00
|
|
|
Messaage are there. And the process that Object.send needs to do is exactly that:
|
2015-03-25 17:29:39 +02:00
|
|
|
send that message, ie find the correct method according to the old walk up the inheritance tree rules and dispatch it.
|
2014-08-05 15:55:24 +03:00
|
|
|
|
2015-05-11 18:55:49 +03:00
|
|
|
And as all this happens at runtime, "all" we have to do is code this logic. And since it is at runtime,
|
2014-08-28 19:12:46 +03:00
|
|
|
we can do it in ruby (as i said, this get's compiled and run, just like the program).
|
2014-08-05 15:55:24 +03:00
|
|
|
|
|
|
|
But what about the infinite loop problem:
|
|
|
|
|
2015-03-25 17:29:39 +02:00
|
|
|
There was a little step left out: Off course the method gets compiled at compile-time and so
|
|
|
|
we don't just blindly dispatch: we catch the simple cases that we know about:
|
|
|
|
layout, type instance variables and compile time known functions.
|
|
|
|
Part of those are some that we just don't allow to be overridden.
|
2014-08-05 15:55:24 +03:00
|
|
|
|
2015-03-25 17:29:39 +02:00
|
|
|
Also what in ruby is object.send is Message.send in salama, as it is the message we are sending and
|
|
|
|
which defines all the data we need (not the object). The object receives, it does not send.
|
2015-05-11 18:55:49 +03:00
|
|
|
|
|
|
|
### Vm vs language- core
|
|
|
|
|
|
|
|
Parfait is not the language (ie ruby) core library. Core library functionality differs between
|
|
|
|
languages and so the language core lib must be on top of the vm parfait.
|
|
|
|
|
|
|
|
Also Parfait is meant to be as thin as humanly possibly, so extra (nice to have) functionality
|
|
|
|
will be in future modules.
|
|
|
|
|
|
|
|
So the Namespace of the Runtime is actually Parfait (not nothing as in ruby).
|
|
|
|
Only in the require does one later have to be clever and see which vm one is running in and either
|
|
|
|
require or not. Maybe one doesn't even have to be so celver, we'll see (as requiring an existing
|
|
|
|
module should result in noop)
|