public final class ControlFlowAnalysis extends Object implements NodeTraversal.Callback, CompilerPass
Modifier and Type | Method and Description |
---|---|
static ControlFlowGraph<Node> |
getCfg(AbstractCompiler compiler,
Node cfgRoot) |
static boolean |
isBreakTarget(Node target,
String label)
Checks if target is actually the break target of labeled continue.
|
static boolean |
mayThrowException(Node n)
Determines if the subtree might throw an exception.
|
void |
process(Node externs,
Node root)
Process the JS with root node root.
|
boolean |
shouldTraverse(NodeTraversal nodeTraversal,
Node n,
Node parent)
Visits a node in pre order (before visiting its children) and decides
whether this node's children should be traversed.
|
void |
visit(NodeTraversal t,
Node n,
Node parent)
Visits a node in postorder (after its children have been visited).
|
public static ControlFlowGraph<Node> getCfg(AbstractCompiler compiler, Node cfgRoot)
public void process(Node externs, Node root)
CompilerPass
process
in interface CompilerPass
externs
- Top of external JS treeroot
- Top of JS treepublic boolean shouldTraverse(NodeTraversal nodeTraversal, Node n, Node parent)
NodeTraversal.Callback
Visits a node in pre order (before visiting its children) and decides
whether this node's children should be traversed. If children are
traversed, they will be visited by
NodeTraversal.Callback.visit(NodeTraversal, Node, Node)
in postorder.
Implementations can have side effects (e.g. modifying the parse tree).
shouldTraverse
in interface NodeTraversal.Callback
public void visit(NodeTraversal t, Node n, Node parent)
NodeTraversal.Callback
Visits a node in postorder (after its children have been visited).
A node is visited only if all its parents should be traversed
(NodeTraversal.Callback.shouldTraverse(NodeTraversal, Node, Node)
).
Implementations can have side effects (e.g. modifying the parse tree).
visit
in interface NodeTraversal.Callback
public static boolean isBreakTarget(Node target, String label)
public static boolean mayThrowException(Node n)
Copyright © 2009-2017 Google. All Rights Reserved.