module Substitute where import Recursive
The intention with class Subst is that subst s e applies the subsitution s to all variables occuring in e.
It is assumed that name capture will not happen, i.e., s does not affect variables that are bound in (parts of) e, and if x is free in e, s x does not contain variables that become bound when substituted into e.
class Subst i e | e->i where subst :: (i->e) -> e->e
The intention with class MapExp is that mapExp f e applies the function f to every expression occuring in a larger structure (e.g., a list of declarations). Instances of Subst will typically make use of instances of MapExp.
class MapExp e s | s->e where mapExp :: (e->e) -> s->s instance MapExp e s => MapExp e [s] where mapExp = map . mapExp esubst = mapExp . subst esubst1 var e x = esubst s where s y = if y==x then e else var y mapExpRec = mapRec . mapExp {- class Subst i e s1 s2 | e->i,s1->i, where subst :: (i->e)->s1->s2 -}