[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]
[ungar@self: Re: macros / code construction]
Date: Wed, 30 Aug 1995 16:26:55 -0700
To: Mario.Wolczko@Eng (Mario Wolczko)
From: ungar@self (David Ungar)
Subject: Re: macros / code construction
We have had lots of discussions about
assignment, but what it boils down to for me is
that containers are appealingly intuitive notion,
and so I am happy to ground out where it does.
Going deeper does not seem to me to buy so much.
- Dave
>Date: Thu, 31 Aug 1995 00:03:54 +0200
>From: rainer@physik3.gwdg.de (Rainer Blome)
>To: self-interest@self.sunlabs.com
>Subject: macros / code construction
>
>
>yes, i know, macros as in the lisp family are a very unstructured way of
>doing things. i don't actually care for macros, any way to make convenient
>the use of useful but awkward idioms would do.
>
>i have heard about beta's facilities in that direction but have only just
>printed the tutorial out, so i can't comment on that. (as always: no
>library -> no book on beta :-( ) i like the common lisp/loops method
>combination stuff, so i guess i'll like beta, too.
>
>there are more things that i miss in self: local methods and evaluation of
>literals in the dynamic context (dynamic? lexical? what does lexical mean
>anyway, when we don't have source-code anymore?).
>
>
>imagine doing assignment another way. assignment is a hack (from the
>functional point of view). it manipulates its context. one should make
>that explicit by revealing the reflection involved in assignment. first
>get an object that represents the place (the slot). that is the reflective
>part. then send it a normal message with the new value as an argument:
>
>(reflect: self slot: "x") store: 1
>
>(buggy, but you know what i mean. how the slot implements the `store:'
>method? don't you ask! ;-)
>
>of course, this is to be put as a method in the `assignment slot'. now
>this `slot:' (meta-) message will always eval to the same object (the `x'
>slot), so it should not be computed every time the assignment method is
>called.
>
>note that the method now _explicitly_ `knows' the slot it refers to, as
>opposed to knowing that implicitly by reflecting on its (the method's) own
>slot name. randy and dave mentioned a very similar way to implement
>assignment in their ecoop95 paper.
>
>to make this scheme feasible, two things are missing (that means, i
>can't see them, *I* might be missing them, not self, tell me if i do.):
>
> a way to do computation during initialization
>
> a convenient way to construct code. writing this kind of
> assignment methods must be automated.
>
>
>this is long already, i'll stop here. any thoughts? am i making sense?
>
>rainer
-- Dave