public final class Es6RewriteModules extends java.lang.Object implements HotSwapCompilerPass, NodeTraversal.Callback
Constructor and Description |
---|
Es6RewriteModules(AbstractCompiler compiler,
ModuleMetadataMap moduleMetadataMap,
ModuleMap moduleMap,
com.google.javascript.jscomp.PreprocessorSymbolTable preprocessorSymbolTable)
Creates a new Es6RewriteModules instance which can be used to rewrite ES6 modules to a
concatenable form.
|
Modifier and Type | Method and Description |
---|---|
void |
hotSwapScript(Node scriptNode,
Node originalRoot)
Process the JS with root node root.
|
static boolean |
isEs6ModuleRoot(Node scriptNode)
Return whether or not the given script node represents an ES6 module file.
|
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 Es6RewriteModules(AbstractCompiler compiler, ModuleMetadataMap moduleMetadataMap, ModuleMap moduleMap, @Nullable com.google.javascript.jscomp.PreprocessorSymbolTable preprocessorSymbolTable)
public static boolean isEs6ModuleRoot(Node scriptNode)
public void process(Node externs, Node root)
CompilerPass
process
in interface CompilerPass
externs
- Top of external JS treeroot
- Top of JS treepublic void hotSwapScript(Node scriptNode, Node originalRoot)
HotSwapCompilerPass
hotSwapScript
in interface HotSwapCompilerPass
scriptNode
- Root node corresponding to the file that is modified,
should be of type Token.SCRIPT
.originalRoot
- Root node corresponding to the original version of the
file that is modified. Should be of type token.SCRIPT
.public 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
Copyright © 2009-2020 Google. All Rights Reserved.