Protected
Readonly
astProtected
Readonly
descriptionsProtected
Readonly
nameCreates descriptions of all AST nodes that shall be exported into the global scope from the given
document. These descriptions are gathered by the IndexManager
and stored in the global index so
they can be referenced from other documents.
Note: You should not resolve any cross-references in this service method. Cross-reference resolution
depends on the scope computation phase to be completed (computeScope
method), which runs after the
initial indexing where this method is used.
The document from which to gather exported AST nodes.
Indicates when to cancel the current operation.
Creates AstNodeDescriptions for the given parentNode and its children. The list of children to be considered is determined by the function parameter children. By default only the direct children of parentNode are visited, nested nodes are not exported.
AST node to be exported, i.e., of which an AstNodeDescription shall be added to the returned list.
The document containing the AST node to be exported.
A function called with parentNode as single argument and returning an Iterable supplying the children to be visited, which must be directly or transitively contained in parentNode.
Indicates when to cancel the current operation.
A list of AstNodeDescriptions to be published to index.
Precomputes the local scopes for a document, which are necessary for the default way of
resolving references to symbols in the same document. The result is a multimap assigning a
set of AST node descriptions to every level of the AST. These data are used by the ScopeProvider
service to determine which target nodes are visible in the context of a specific cross-reference.
Note: You should not resolve any cross-references in this service method. Cross-reference resolution depends on the scope computation phase to be completed.
The document in which to compute scopes.
Indicates when to cancel the current operation.
Protected
createProtected
exportAdd a single node to the list of exports if it has a name. Override this method to change how symbols are exported, e.g. by modifying their exported name.
Protected
processAdd synthetic type into the scope in case of explicitly inferred type:
case: {infer Action}
Protected
processProcess a single node during scopes computation. The default implementation makes the node visible in the subtree of its container (if the node has a name). Override this method to change this, e.g. by increasing the visibility to a higher level in the AST.
Protected
processAdd synthetic type into the scope in case of explicitly or implicitly inferred type:
cases: ParserRule: ...;
or ParserRule infers Type: ...;
The default scope computation creates and collectes descriptions of the AST nodes to be exported into the global scope from the given document. By default those are the document's root AST node and its directly contained child nodes.
Besides, it gathers all AST nodes that have a name (according to the
NameProvider
service) and includes them in the local scope of their particular container nodes. As a result, for every cross-reference in the AST, target elements from the same level (siblings) and further up towards the root (parents and siblings of parents) are visible. Elements being nested inside lower levels (children, children of siblings and parents' siblings) are invisible by default, but that can be changed by customizing this service.