Safe Haskell | None |
---|
- externals :: [External]
- alpha :: RewriteH Core
- alphaLam :: Maybe Name -> RewriteH CoreExpr
- alphaCaseBinder :: Maybe Name -> RewriteH CoreExpr
- alphaAltWith :: [Name] -> RewriteH CoreAlt
- alphaAltVars :: [Var] -> RewriteH CoreAlt
- alphaAlt :: RewriteH CoreAlt
- alphaCase :: RewriteH CoreExpr
- alphaLetWith :: [Name] -> RewriteH CoreExpr
- alphaLetVars :: [Var] -> RewriteH CoreExpr
- alphaLet :: RewriteH CoreExpr
- alphaConsWith :: [Name] -> RewriteH CoreProg
- unshadow :: RewriteH Core
- visibleVarsT :: TranslateH CoreExpr [Var]
- freshNameGenT :: Maybe Name -> TranslateH CoreExpr (String -> String)
- freshNameGenAvoiding :: Maybe Name -> [Var] -> String -> String
- replaceVarR :: Injection a Core => Var -> Var -> RewriteH a
Alpha-Renaming and Shadowing
Alpha-Renaming
Alpha rename any bindings at this node. Note: does not rename case alternatives unless invoked on the alternative.
alphaLam :: Maybe Name -> RewriteH CoreExprSource
Alpha rename a lambda binder. Optionally takes a suggested new name.
alphaCaseBinder :: Maybe Name -> RewriteH CoreExprSource
Alpha rename a case binder. Optionally takes a suggested new name.
alphaAltWith :: [Name] -> RewriteH CoreAltSource
Rename the variables bound in a case alternative with the given list of suggested names.
alphaAltVars :: [Var] -> RewriteH CoreAltSource
Rename the specified variables in a case alternative.
alphaLetWith :: [Name] -> RewriteH CoreExprSource
Rename the identifiers bound in a Let with the given list of suggested names.
alphaLetVars :: [Var] -> RewriteH CoreExprSource
Rename the specified variables bound in a let.
alphaConsWith :: [Name] -> RewriteH CoreProgSource
Rename the identifiers bound in the top-level binding at the head of the program with the given list of suggested names.
Shadow Detection and Unshadowing
unshadow :: RewriteH CoreSource
Rename local variables with manifestly unique names (x, x0, x1, ...). Does not rename top-level definitions.
visibleVarsT :: TranslateH CoreExpr [Var]Source
List all visible identifiers (in the expression or the context).
freshNameGenT :: Maybe Name -> TranslateH CoreExpr (String -> String)Source
If a name is provided replace the string with that, otherwise modify the string making sure to not clash with any visible variables.