public class AlphaRenamer extends NodeVisitor
AlphaRenamer
runs over the AST and alpha-renames any local
variable declarations that it encounters.Modifier and Type | Field and Description |
---|---|
protected boolean |
createNewLocalInstances
Should we create new local instances? (If not, we will imperatively update the old ones).
|
protected java.util.Set<java.lang.String> |
freshVars |
protected java.util.Map<java.lang.String,LocalInstance> |
localInstanceMemo
Memoization holding
LocalInstance s for renamed locals |
protected NodeFactory |
nf |
protected boolean |
renameCatchFormals
Should we also alpha-rename catch formals?
|
protected java.util.Map<java.lang.String,java.lang.String> |
renamingMap |
protected java.util.Stack<java.util.Set<java.lang.String>> |
setStack |
Constructor and Description |
---|
AlphaRenamer(NodeFactory nf)
Creates a visitor for alpha-renaming locals.
|
AlphaRenamer(NodeFactory nf,
boolean renameCatchFormals) |
AlphaRenamer(NodeFactory nf,
boolean renameCatchFormals,
boolean createNewLocalInstances) |
Modifier and Type | Method and Description |
---|---|
protected void |
addToRenamingMap(java.lang.String name) |
NodeVisitor |
enter(Node n)
Begin normal traversal of a subtree rooted at
n . |
Node |
leave(Node old,
Node n,
NodeVisitor v)
This method is called after all of the children of
n
have been visited. |
protected NodeFactory nf
protected java.util.Stack<java.util.Set<java.lang.String>> setStack
protected java.util.Map<java.lang.String,java.lang.String> renamingMap
protected java.util.Map<java.lang.String,LocalInstance> localInstanceMemo
LocalInstance
s for renamed localsprotected java.util.Set<java.lang.String> freshVars
protected boolean renameCatchFormals
protected boolean createNewLocalInstances
public AlphaRenamer(NodeFactory nf)
nf
- The node factory to be used when generating new nodes.public AlphaRenamer(NodeFactory nf, boolean renameCatchFormals)
public AlphaRenamer(NodeFactory nf, boolean renameCatchFormals, boolean createNewLocalInstances)
public NodeVisitor enter(Node n)
NodeVisitor
n
. This gives
the visitor the option of changing internal state or returning a new
visitor which will be used to visit the children of n
.
This method is typically called by the method
enter(parent, n)
. If a subclass overrides the
method enter(parent, n)
then this method
may not be called.
enter
in class NodeVisitor
n
- The root of the subtree to be traversed.NodeVisitor
which should be used to visit the
children of n
.protected void addToRenamingMap(java.lang.String name)
public Node leave(Node old, Node n, NodeVisitor v)
NodeVisitor
n
have been visited. In this case, these children were visited by the
visitor v
. This is the last chance for the visitor to
modify the tree rooted at n
. This method will be called
exactly the same number of times as entry
is called.
That is, for each node that is not overridden, enter
and
leave
are each called exactly once.
Note that if old == n
then the visitor should make a copy
of n
before modifying it. It should then return the
modified copy.
This method is typically called by the method
leave(parent, old, n v)
.
If a subclass overrides the method
leave(parent, old, n v)
then this method may not be called.
leave
in class NodeVisitor
old
- The original state of root of the current subtree.n
- The current state of the root of the current subtree.v
- The NodeVisitor
object used to visit the children.n
.