Hi

Classes are global variables too. How it related here?
And what about environments to support some kind of namespaces? Do you have
plan for this?

Best regards
Denis


2014-07-03 19:51 GMT+04:00 Marcus Denker <marcus.den...@inria.fr>:

> Hi,
>
> If we have meta-object describing (and thus having the power to change the
> semantics of) instance variables,
> we need the same for Globals.
>
> I think the easiest is to just re-use the object hat is already there: the
> “binding”, that is, the association from
> the dictionary where the global lives (e.g. the classPool for class vars,
> Smalltalk globals for true globals, and so on).
>
>         SystemVersion bindingOf: ‘Current'
>
> The VM just cares that it is an assoiation (actually, it just care that
> there are two fields, but the rest of the image cares
> about value and key…)
>
> -> we can make a subclass of Association
> -> we can have the compiler forward code generation to the object that
> describes the global
> -> we can add a nice MOP API: #read and #write:  (instead of #value and
> #value:)
> -> Programmers can subclass the GlobalVariable and change #read and #write
> like they want (or override
> the code gen methods) as in Slots.
>
> The only drawback is that you can not add an instance variables, I think,
> to check… maybe it even works?
> If not, there are ways around that e.g. using some fancy Slot that does
> not need an ivar but uses a weak dictionary
> in a class variable, for example).
>
> Thus: it would be fairly easy to have the class vars be as flexible as the
> slots… and then e.g. you will be able
> to  put breakpoints and watchers on class vars. You could even define
> globals with special behaviour the same
> way as you do with Slots.
>
>         Marcus
>
>
>

Reply via email to