[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]
Re: The variables +, -, *, and /
- To: TIM@MIT-MC.ARPA, common-lisp@SU-AI.ARPA
- Subject: Re: The variables +, -, *, and /
- From: Steven Haflich <smh@mit-ems.ARPA>
- Date: Wed, 4 Dec 85 07:43:55 est
> From: Tim McNerney <TIM@MIT-MC.ARPA>
> Subject: The variables +, -, *, and /
>
> It seems unfortunate that the variables +, -, *, and / were reserved
> for use by the Top-Level Loop. This choice of names makes it difficult
> to build the run-time environment for Scheme-like language that
> compiles into Common Lisp and that supports the illusion that there are
> no separate function and value cells. If these variables had not been
> reserved, one could
>
> (DEFCONSTANT + #'+)
> (DEFCONSTANT * #'*)
> etc...
>
> so that
>
> ((IF SUM? + *) X Y)
>
> could be simply compiled into
>
> (FUNCALL (IF SUM? + *) X Y)
Perhaps these symbols aren't the real problem: CL compilers tend to
have built-in knowledge about certain special forms that a user can't
easily modify. So if you're really scheming up a language with
different semantics for the functional position of a form, you'll
probably have to write new top-level loops for both compiler and
interpreter which preprocess all top-level forms appropriately. Your
top-level interpreter loop would probably have a reentrant top-level
unwind-protect so the user doesn't ever fall out into the CL one, even
during error recovery. Thus, the CLtL top-level loop won't be around
to mess with +, ++, etc.