rubyx/lib/typed/parfait
Torsten Ruger 7f06e00ccd making types private in space
turned out to be unnecessary, but still better
2016-12-30 20:47:28 +02:00
..
behaviour.rb changing to ruby instance variables 2016-12-29 18:47:45 +02:00
binary_code.rb add little bit docs 2016-12-13 11:02:53 +02:00
class.rb Move the space instance to the parfait module 2016-12-30 14:10:49 +02:00
dictionary.rb fixed silly dictionary bug 2016-12-30 20:46:18 +02:00
indexed.rb removing the fake memory form object 2016-12-29 18:49:03 +02:00
integer.rb minor whitespace and renaming 2016-12-30 18:39:49 +02:00
list.rb fixed silly dictionary bug 2016-12-30 20:46:18 +02:00
message.rb changing to ruby instance variables 2016-12-29 18:47:45 +02:00
named_list.rb cleaner way to generate argument types 2016-12-30 19:17:59 +02:00
object.rb minor whitespace and renaming 2016-12-30 18:39:49 +02:00
page.rb add little bit docs 2016-12-13 11:02:53 +02:00
README.md add little bit docs 2016-12-13 11:02:53 +02:00
space.rb making types private in space 2016-12-30 20:47:28 +02:00
symbol_adapter.rb Move the space instance to the parfait module 2016-12-30 14:10:49 +02:00
type.rb making types private in space 2016-12-30 20:47:28 +02:00
typed_method.rb no default arg on init 2016-12-30 18:41:36 +02:00
word.rb whitespace and code style 2016-12-30 19:17:15 +02:00

Parfait: a thin layer

Parfait is the run-time of the object system. To be more precise, it is that part of the run-time needed to boot.

The run-time needs to contain quite a lot of functionality for a dynamic system. And a large part of that functionality must actually be used at compile time too.

We reuse the Parfait code at compile-time, to create the data for the compiled vm. To do this the vm (re) defines the object memory (in parfait_adapter).

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

A step back: the code (program) we compile runs at run - time. 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.

Parfait has a brother, the Builtin module. Builtin contains everything that can not be coded in ruby, but we still need (things like List access).

Vm vs language- core

Parfait is not the language core library. Core library functionality differs between languages and so the language core lib must be on top of the vm parfait.

To make this point clear, i have started using different names for the core classes. Hopefully more sensible ones, ie List instead of Array, Dictionary instead of Hash.

Also Parfait is meant to be as thin as humanly possibly, so extra (nice to have) functionality will be in future modules.