On 13 Apr 2011, at 16:19, Andy Wingo wrote:

>> What method is Guile using to avoid substitution variable clashes (de
>> Bruijn numbers, combinators, etc.)?
> 
> Each lexical variable is given a fresh name (a gensym) when it is
> introduced.  The expander keeps an environment as to what name maps to
> what gensym, and residualizes the gensym in the lexical reference or
> assignment.
> 
> See "The Scheme Compiler" in the manual, for more.

I am thinking about it in the context of other types of binders, that satisfies 
the alpha-rule, but not the beta, useful in math (like theorem provers). Has 
that been discussed?

Hans



Reply via email to