The MontiArc Architecture Description Language
In MontiArc, architectures are described as component and connector systems in which autonomously acting components perform computations. Communication between components is regulated by connectors between the components’ interfaces, which are stable and built up by typed, directed ports. Components are either atomic or composed of connected subcomponents. Atomic components yield behavior descriptions in the form of embedded time-synchronous port automata or via integration of handcrafted code. For composed components, the behavior emerges from the behavior of their subcomponents.
© https://github.com/MontiCore/monticore
Native installation
Prerequisites
- Git (for checking out the project)
- Gradle 7.5.0 (for building the project)
- Java 11 (for building and executing the project)
Installation
git clone <link to this Git repository>
gradle build
This should build the project. Note, building the project for the first time may take a while. Subsequent builds should be faster.
Once the project is built, you can look at the generated source code.
The languages
folder contains the language components of MontiArc, more
specifically, their frontend implementation. That is parsers to create abstract
syntax trees (ASTs) from textual models, infrastructure to create the symbol
table, context condition checks, transformations, visitors, and a command line
tool that puts everything together.
The generators
folder contains code generators that translate MontiArc component
models to some general-purpose language. Currently, available are the MontiArc to
Java (MA2Java) and the CD to Java (CD2Pojo, Pojo for Plain Old Java) generators.
The applications
folder contains some example applications.
Each of them should contain a build/generated-sources
subdirectory after
building their respective project.
Please note that gradle build
on the topmost folder builds the whole project.
However, each subproject contains an individual build file.
Executing the build command on a subproject builds everything needed for that
project and then builds the project. See the Gradle Website
for more information about the gradle build tool.
Building and Running Your First Application
This section guides you through building and executing your first application.
We will use the example under application/bumperbot
.
It consists of only a few components but should showcase the build process.
We support building an application via an IDE
Building and Running an Application using an IDE
As MontiArc generates Java code, you can use the same IDE to build both MontiArc
and MontiArc applications.
The whole build process can be handled by gradle.
That is, gradle build
not only generates Java code from MontiArc component
models, but also compiles the handwritten and generated
code, and executes tests.
Extending the build process to construct an executable only requires defining the
main class and setting up the build process to generate an executable.
Tool Documentation
The MontiArcTool offers capabilities for processing MontiArc component models. It provides multiple options that can be used as follows:
java -jar MontiArc.jar [-h] -i <fileName> [-path <p>] [-pp [<file>]] [-s [<file>]]
where the arguments are:
Option | Explanation |
---|---|
-h, --help |
Prints the help dialog. |
-v, --version |
Prints version information. |
-i, --input <dirlist> |
Sets the artifact path of the source files, space separated. |
-path <dirlist> |
Sets the artifact path for imported symbols, space separated. |
-pp, --prettyprint <dir> |
Prints the AST of the component models to stdout or the specified directory (optional). |
-s, --symboltable <dir> |
Serializes and prints the symbol table to stdout or the specified output directory (optional). |
Exemplary usage:
java -jar MontiArc.jar -h
java -jar MontiArc.jar -i application/bumperbot/main/resources
The MA2JavaTool extends the MontiArcTool with code generating capabilities. It provides the following options in addition to those defined above:
Option | Explanation |
---|---|
-o, --output <dir> |
Sets the target path for the generated files (optional). |
-hwc <dir> |
Sets the artifact path for handwritten code (optional). |