Package com.google.javascript.jscomp
Class JSModule
java.lang.Object
com.google.javascript.jscomp.JSModule
- All Implemented Interfaces:
DependencyInfo
,Serializable
A JavaScript module has a unique name, consists of a list of compiler inputs,
and can depend on other modules.
- See Also:
-
Constructor Summary
Constructors -
Method Summary
Modifier and TypeMethodDescriptionvoid
add
(CompilerInput input) Adds a source code input to this module.void
add
(SourceFile file) Adds a source file input to this module.void
addAfter
(CompilerInput input, CompilerInput other) Adds a source code input to this module directly after other.void
addDependency
(JSModule dep) Adds a dependency on another module.void
addFirst
(CompilerInput input) Adds a source code input to this module.void
addFirst
(SourceFile file) Adds a source file input to this module.void
Removes any references to nodes of the AST.Returns the transitive closure of dependencies starting from the dependencies of this module.Returns the input with the given name or null if none.Gets the list of modules that this module depends on.int
getDepth()
Gets this module's list of source code inputs.getName()
Gets the module name.Gets the path of this file relative to Closure's base.js file.Gets the symbols provided by this file.Gets the symbols required by this file.Returns this module and all of its dependencies in one list.void
remove
(CompilerInput input) Removes an input from this module.void
Removes all of the inputs from this module.boolean
removeByName
(String name) Removes any input with the given name.void
setDepth
(int dep) void
sortInputsByDeps
(Compiler compiler) Puts the JS files into a topologically sorted order by their dependencies.static JSModule[]
sortJsModules
(Collection<JSModule> modules) Returns the given collection of modules in topological order.toString()
Returns the module name (primarily for debugging).
-
Constructor Details
-
JSModule
Creates an instance.- Parameters:
name
- A unique name for the module
-
-
Method Details
-
getName
Gets the module name.- Specified by:
getName
in interfaceDependencyInfo
-
getProvides
Description copied from interface:DependencyInfo
Gets the symbols provided by this file.- Specified by:
getProvides
in interfaceDependencyInfo
-
getRequires
Description copied from interface:DependencyInfo
Gets the symbols required by this file.- Specified by:
getRequires
in interfaceDependencyInfo
-
getPathRelativeToClosureBase
Description copied from interface:DependencyInfo
Gets the path of this file relative to Closure's base.js file.- Specified by:
getPathRelativeToClosureBase
in interfaceDependencyInfo
-
add
Adds a source file input to this module. -
addFirst
Adds a source file input to this module. -
add
Adds a source code input to this module. -
addFirst
Adds a source code input to this module. -
addAfter
Adds a source code input to this module directly after other. -
addDependency
Adds a dependency on another module. -
remove
Removes an input from this module. -
removeAll
public void removeAll()Removes all of the inputs from this module. -
getDependencies
Gets the list of modules that this module depends on.- Returns:
- A list that may be empty but not null
-
getAllDependencies
Returns the transitive closure of dependencies starting from the dependencies of this module. -
getThisAndAllDependencies
Returns this module and all of its dependencies in one list. -
getInputs
Gets this module's list of source code inputs.- Returns:
- A list that may be empty but not null
-
getByName
Returns the input with the given name or null if none. -
removeByName
Removes any input with the given name. Returns whether any were removed. -
toString
Returns the module name (primarily for debugging). -
clearAsts
public void clearAsts()Removes any references to nodes of the AST. This method is needed to allow the ASTs to be garbage collected if the modules are kept around. -
sortInputsByDeps
Puts the JS files into a topologically sorted order by their dependencies. -
sortJsModules
public static JSModule[] sortJsModules(Collection<JSModule> modules) throws SortedDependencies.CircularDependencyException Returns the given collection of modules in topological order. Note that this will return the modules in the same order if they are already sorted, and in general, will only change the order as necessary to satisfy the ordering dependencies. This can be important for cases where the modules do not properly specify all dependencies. -
setDepth
public void setDepth(int dep) - Parameters:
dep
- the depth to set
-
getDepth
public int getDepth()- Returns:
- the depth
-