-
Notifications
You must be signed in to change notification settings - Fork 139
ECJ AST
< JDT Core Programmer Guide | ECJ
AST and bindings are the two main data structures of the compiler.
AST nodes directly capture all semantically relevant aspects of the
source code. In many regards the type hierarchy below
org.eclipse.jdt.internal.compiler.ast.ASTNode
corresponds to the
standard approach in compiler construction.
- Three main compiler phases are implemented with explicit traversals
below these methods of class CompilationUnitDeclaration:
- resolve()
- analyseCode()
- generateCode()
- For various smaller tasks the visitor pattern is used, see
- class
org.eclipse.jdt.internal.compiler.ASTVisitor
- method ASTNode.traverse(ASTVisitor, BlockScope), plus variants for other scope types
- class
Throughout all AST classes, source positions are recorded as linear text indices.
- Fields sourceStart and sourceEnd typically hold the start and end of that region that should be highlighted if an error(/warning/info) has been detected concerning a given AST node.
- Complex nodes have more locations, like bodyStart, bodyEnd etc.
- In some cases, a pair of start & end position is encoded in a single
long variable. This is used specifically where a list of positions
is needed, like QualifiedTypeReference.sourcePositions (encoding the
position of each text segment).
- To create the long value, use
(((long) start) << 32) + end
- To extract the start position use
(int) (position>>>32)
- To extract the end position use
(int) position
- To create the long value, use
The field ASTNode.bits is used as a bitset. Unfortunately the use of
bits in this vector is quite crowded, some bits are used with different
semantics in different kinds of nodes. See class ASTNode
for constants
and their terse documentation.
- Some flags are set right during parsing, like
IsDiamond
- Other flags store information gathered throughout compilation.
- Bits in
ParenthesizedMASK
encode the number of enclosing pairs of parentheses, so that no AST node ParenthesizedExpression is needed. - Flags
HasAllMethodBodies
,HasBeenResolved
andHasBeenGenerated
remember whether a given compilation step has already been performed for this node.
Similar bitsets are TypeBinding.tagBits
and
ReferenceBinding.typeBits
, see
Bindings.
The AST structure very sparingly uses interfaces for additional classification:
- IJavadocTypeReference: subsumes JavaSingleTypeReference and JavaQualifiedTypeReference
- InvocationSite: holds some context for resolving a reference to a member
- Invocation: subsumes AllocationExpression, ExplicitConstructorCall and MessageSend (used during type inference)
- IPolyExpression: expressions that can be poly expressions according to JLS §15.2.
The special node class FakedTrackingVariable
does not correspond
to any source element, but is used to map resource leak analysis to the
existing infrastructure of null analysis. See
Analyse.
Class NullAnnotationMatching provides static methods for 'type-checking' null annotations. Some of these methods use instances of NullAnnotationMatching to communicate the exact result of the analysis.
Class UnlikelyArgumentCheck provides static methods for advanced
'type-checking' of arguments of well-known methods like contains
and
remove
of interface Collection<T>
, see bug 410218 and 4.7M6
N&N.
Both check methods return an instance of UnlikelyArgumentCheck to
communicate the exact result of the analysis.