public class SourceUnit extends ProcessingUnit
Provides an anchor for a single source unit (usually a script file) as it passes through the compiler system.
Modifiers | Name | Description |
---|---|---|
protected ModuleNode |
ast |
The root of the Abstract Syntax Tree for the source |
protected Reduction |
cst |
A Concrete Syntax Tree of the source |
protected String |
name |
A descriptive name of the source unit. |
protected ReaderSource |
source |
Where we can get Readers for our source unit |
Fields inherited from class | Fields |
---|---|
class ProcessingUnit |
classLoader, configuration, errorCollector, phase, phaseComplete |
Constructor and description |
---|
SourceUnit(String name, ReaderSource source, CompilerConfiguration flags, GroovyClassLoader loader, ErrorCollector er) Initializes the SourceUnit from existing machinery. |
SourceUnit(File source, CompilerConfiguration configuration, GroovyClassLoader loader, ErrorCollector er) Initializes the SourceUnit from the specified file. |
SourceUnit(URL source, CompilerConfiguration configuration, GroovyClassLoader loader, ErrorCollector er) Initializes the SourceUnit from the specified URL. |
SourceUnit(String name, String source, CompilerConfiguration configuration, GroovyClassLoader loader, ErrorCollector er) Initializes the SourceUnit for a string of source. |
Type Params | Return Type | Name and description |
---|---|---|
|
public void |
addError(SyntaxException se) This method adds a SyntaxException to the error collector. |
|
public void |
addErrorAndContinue(SyntaxException se) |
|
public void |
addException(Exception e) This method adds an exception to the error collector. |
|
public void |
addFatalError(String text, ASTNode node) Convenience wrapper for ErrorCollector.addFatalError. |
|
public void |
addWarning(String text, ASTNode node)
|
|
public ModuleNode |
buildAST() Builds the AST. |
|
public void |
convert() Generates an AST from the CST. |
|
public static SourceUnit |
create(String name, String source) A convenience routine to create a standalone SourceUnit on a String with defaults for almost everything that is configurable. |
|
public static SourceUnit |
create(String name, String source, int tolerance) A convenience routine to create a standalone SourceUnit on a String with defaults for almost everything that is configurable. |
|
public boolean |
failedWithUnexpectedEOF() Convenience routine, primarily for use by the InteractiveShell, that returns true if parse() failed with an unexpected EOF. |
|
public ModuleNode |
getAST() Returns the Abstract Syntax Tree produced during convert()ing and expanded during later phases. |
|
public Reduction |
getCST() Returns the Concrete Syntax Tree produced during parse()ing. |
|
public String |
getName() Returns the name for the SourceUnit. |
|
public String |
getSample(int line, int column, Janitor janitor) Returns a sampling of the source at the specified line and column, or null if it is unavailable. |
|
public ReaderSource |
getSource() |
|
public void |
parse() Parses the source to a CST. |
|
public void |
setSource(ReaderSource source) |
Methods inherited from class | Name |
---|---|
class ProcessingUnit |
completePhase, configure, getClassLoader, getConfiguration, getErrorCollector, getPhase, getPhaseDescription, gotoPhase, isPhaseComplete, nextPhase, setClassLoader, setConfiguration |
The root of the Abstract Syntax Tree for the source
A Concrete Syntax Tree of the source
A descriptive name of the source unit. This name shouldn't be used for controlling the SourceUnit, it is only for error messages and to determine the name of the class for a script.
Where we can get Readers for our source unit
Initializes the SourceUnit from existing machinery.
Initializes the SourceUnit from the specified file.
Initializes the SourceUnit from the specified URL.
Initializes the SourceUnit for a string of source.
This method adds a SyntaxException to the error collector. The exception should specify the line and column number of the error. This method should be reserved for real errors in the syntax of the SourceUnit. If your error is not in syntax, and is a semantic error, or more general error, then use addException or use the error collector directly by retrieving it with getErrorCollector().
se
- the exception, which should have line and column informationThis method adds an exception to the error collector. The Exception most likely has no line number attached to it. For this reason you should use this method sparingly. Prefer using addError for syntax errors or add an error to the ErrorCollector directly by retrieving it with getErrorCollector().
e
- the exception that occurredConvenience wrapper for ErrorCollector.addFatalError.
text
- the error messagenode
- for locating the offending codeBuilds the AST.
Generates an AST from the CST. You can retrieve it with getAST().
A convenience routine to create a standalone SourceUnit on a String with defaults for almost everything that is configurable.
A convenience routine to create a standalone SourceUnit on a String with defaults for almost everything that is configurable.
Convenience routine, primarily for use by the InteractiveShell, that returns true if parse() failed with an unexpected EOF.
Returns the Abstract Syntax Tree produced during convert()ing and expanded during later phases.
Returns the Concrete Syntax Tree produced during parse()ing.
Returns the name for the SourceUnit. This name shouldn't be used for controlling the SourceUnit, it is only for error messages
Returns a sampling of the source at the specified line and column, or null if it is unavailable.
Parses the source to a CST. You can retrieve it with getCST().
Copyright © 2003-2022 The Apache Software Foundation. All rights reserved.