Class AssignmentExpressionsMill
java.lang.Object
de.monticore.expressions.assignmentexpressions.AssignmentExpressionsMill
- Direct Known Subclasses:
AssignmentExpressionsMillForGrammar_WithConcepts,AssignmentExpressionsMillForJavaLight,AssignmentExpressionsMillForODRules,AssignmentExpressionsMillForTFBasisExts,AssignmentExpressionsMillForTFCommons
The mill is a factory for builders and other commonly used functions, such as parsers or visitors.
The mill was introduced to ensure compositionality of languages, while retaining reusability of functions developed for sublanguages.
Only one mill instance exists, even though in composed languages it is available under several static signatures.
-
Field Summary
FieldsModifier and TypeFieldDescriptionprotected IAssignmentExpressionsGlobalScopeprotected AssignmentExpressionsFullPrettyPrinterprotected static AssignmentExpressionsMillprotected IAssignmentExpressionsTypeDispatcher -
Constructor Summary
Constructors -
Method Summary
Modifier and TypeMethodDescriptionprotected IAssignmentExpressionsArtifactScopeprotected ASTAssignmentExpressionBuilderprotected ASTDecPrefixExpressionBuilderprotected ASTDecSuffixExpressionBuilderprotected IAssignmentExpressionsGlobalScopeprotected ASTIncPrefixExpressionBuilderprotected ASTIncSuffixExpressionBuilderprotected AssignmentExpressionsTraverserprotected String_prettyPrint(de.monticore.ast.ASTNode node, boolean printComments) protected IAssignmentExpressionsScope_scope()protected AssignmentExpressionsScopesGenitorprotected AssignmentExpressionsTraverserprotected IAssignmentExpressionsTypeDispatcherstatic ASTArgumentsBuilderstatic AssignmentExpressionsMillgetMill()A traverser is the conceptual entry point for every action within the visitor infrastructure.static voidinit()Initializes a languages Mill.static voidstatic ASTLiteralExpressionBuilderstatic ASTNameExpressionBuilderstatic StringprettyPrint(de.monticore.ast.ASTNode node, boolean printComments) Uses the composed pretty printer to print an ASTNode of this languagestatic voidreset()static IAssignmentExpressionsScopescope()Returns a new ScopeGenitor.Returns a new ScopeGenitorDelegator.A traverser is the conceptual entry point for every action within the visitor infrastructure.
-
Field Details
-
mill
-
fullPrettyPrinter
-
typeDispatcher
-
assignmentExpressionsGlobalScope
-
-
Constructor Details
-
AssignmentExpressionsMill
protected AssignmentExpressionsMill()
-
-
Method Details
-
getMill
-
init
public static void init()Initializes a languages Mill. This will also initialize the Mills of all languages it depends on. This ensures that all objects of this mill, such as builders, traversers, scopes, ..., deliver the element of the correct language. -
incSuffixExpressionBuilder
-
_incSuffixExpressionBuilder
-
decSuffixExpressionBuilder
-
_decSuffixExpressionBuilder
-
incPrefixExpressionBuilder
-
_incPrefixExpressionBuilder
-
decPrefixExpressionBuilder
-
_decPrefixExpressionBuilder
-
assignmentExpressionBuilder
-
_assignmentExpressionBuilder
-
prettyPrint
Uses the composed pretty printer to print an ASTNode of this language- Parameters:
node- The ASTNode to be printedprintComments- Whether comments should be printed- Returns:
- The pretty printer output
-
_prettyPrint
-
typeDispatcher
-
_typeDispatcher
-
traverser
A traverser is the conceptual entry point for every action within the visitor infrastructure. Visitors may be added, which contain the implementations for the visit and endVisit methods. Handlers may be added to modify the default traversal strategy. Each traverser retains their traversed elements to avoid duplicate traversal, possibly requiringITraverser.clearTraversedElements()to be called in case of re-useinheritanceTraverser()should be preferred over normal traverser, as they further enable language composition.- Returns:
- a new instance of this language's traverser
-
_traverser
-
inheritanceTraverser
A traverser is the conceptual entry point for every action within the visitor infrastructure. Visitors may be added, which contain the implementations for the visit and endVisit methods. Handlers may be added to modify the default traversal strategy. Each traverser retains their traversed elements to avoid duplicate traversal, possibly requiringITraverser.clearTraversedElements()to be called in case of re-use Inheritance Traverser should be preferred over default ones, as they further enable language composition.- Returns:
- a new instance of this language's inheritance traverser
-
_inheritanceTraverser
-
globalScope
-
_globalScope
-
artifactScope
-
_artifactScope
-
scope
-
_scope
-
scopesGenitor
Returns a new ScopeGenitor. ScopeGenitors are responsible for creating the scope structure of artifacts of only this language and linking it with the AST nodes. Note: ScopeGenitors do NOT delegate to elements of composed languages which is why you are most likely looking forscopesGenitorDelegator().- Returns:
- a new instance of this language's scope genitor
-
_scopesGenitor
-
scopesGenitorDelegator
Returns a new ScopeGenitorDelegator. Delegates to the ScopeGenitors of composed languages, used for instantiating symbol tables in the context of language composition See the delegators #createFromAST method.- Returns:
- a new instance of this language's scope genitor delegator
-
_scopesGenitorDelegator
-
nameExpressionBuilder
-
literalExpressionBuilder
-
argumentsBuilder
-
initMe
-
reset
public static void reset()
-