Skip to main content

Generate implementations and schemas based on an AAS meta-model.

Project description

Continuous integration Test coverage PyPI - version PyPI - Python Version

Aas-core-codegen:

  • generates code for different programming environments and schemas

  • to handle asset administration shells

  • based on the meta-model in simplified Python.

Motivation

The meta-model is still at the stage where it changes frequently. However, we need SDKs in different languages (C#, C++, C, Java, Golang, Erlang etc.) as well as different schemas (JSON Schema, XSD, RDF etc.). Keeping up with the changes is hard, time-consuming and error-prone as each SDK and schema needs to be reviewed independently.

To make the whole development cycle of the meta-model, SDKs and schemas more maintainable, we wrote a code and schema generator. We write a meta-model in a subset of Python language, parse it and, based on this meta-model, generate the code for different languages and schemas.

Therefore we can easily scale to many languages and schemas.

Here is a diagram to illustrate the whole process:

https://raw.githubusercontent.com/aas-core-works/aas-core-codegen/main/diagram.svg

Installation

Single-File Release

Please download and unzip the latest release from the GitHub release page.

From PyPI

The tool is also available on PyPI.

Create a virtual environment:

python -m venv venv-aas-core-codegen

Activate it (in Windows):

venv-venv-aas-core-codegen\Scripts\activate

or in Linux and OS X:

source venv-aas-core-codegen/bin/activate

Install the tool in the virtual environment:

pip3 install aas-core-codegen

Usage

Write your meta-model somewhere as well as the code snippets for implementation specific classes and functions. For example, take our test meta-model for inspiration how to write the meta-model and the snippets.

Make sure you are within the virtual environment where you installed the generator. Alternatively, if you are using the binary release, make sure the release is on your path.

Call the generator with the appropriate target:

aas-core-codegen \
    --model_path path/to/meta_model.py \
    --snippets_dir path/to/snippets \
    --output_dir path/to/output \
    --target csharp

--help

usage: aas-core-codegen [-h] --model_path MODEL_PATH --snippets_dir
                        SNIPPETS_DIR --output_dir OUTPUT_DIR --target
                        {cpp,csharp,golang,java,jsonschema,python,typescript,xsd}
                        [--cache_model] [--version]

Generate implementations and schemas based on an AAS meta-model.

options:
  -h, --help            show this help message and exit
  --model_path MODEL_PATH
                        path to the meta-model
  --snippets_dir SNIPPETS_DIR
                        path to the directory containing implementation-
                        specific code snippets
  --output_dir OUTPUT_DIR
                        path to the generated code
  --target {cpp,csharp,golang,java,jsonschema,python,typescript,xsd}
                        target language or schema
  --cache_model         If set, cache the parsed meta-model in the temporary
                        directory of your OS. This makes the repeated runs
                        faster as the meta-model does not need to be reparsed.
  --version             show the current version and exit

Versioning

We are still not clear about how to version the generator. For the moment, we use a lax incremental versioning with 0.0 prefix (0.0.1, 0.0.2``) etc.

The changelog is available in CHANGELOG.rst.

Contributing

Feature requests or bug reports are always very, very welcome!

Please see quickly if the issue does not already exist in the issue section and, if not, create a new issue.

Contributions in code are also welcome! Please see CONTRIBUTING.rst for developing guidelines.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

aas_core_codegen-0.0.24.tar.gz (693.8 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

aas_core_codegen-0.0.24-py3-none-any.whl (887.3 kB view details)

Uploaded Python 3

File details

Details for the file aas_core_codegen-0.0.24.tar.gz.

File metadata

  • Download URL: aas_core_codegen-0.0.24.tar.gz
  • Upload date:
  • Size: 693.8 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.14.4

File hashes

Hashes for aas_core_codegen-0.0.24.tar.gz
Algorithm Hash digest
SHA256 a92bc00c35826d9211cdc9365b2703eedd377db098c9b8dc40fa4c9d8c8ef766
MD5 86cca1ec6f4f425812691794f0047476
BLAKE2b-256 7a9793779bc277ba24958d3fcbfc309eeafe686fdfafbe525835bc2d632c030c

See more details on using hashes here.

File details

Details for the file aas_core_codegen-0.0.24-py3-none-any.whl.

File metadata

File hashes

Hashes for aas_core_codegen-0.0.24-py3-none-any.whl
Algorithm Hash digest
SHA256 e3d4f59d7d0f4101fe4cfea37c9f62309b8dc5c9c585d8d3f717ee58737abf51
MD5 71650197791c2d973e61231715bff21d
BLAKE2b-256 98ae68dd5e4729865ff097d479f398242e37d5e227a70f8ab2ca6acb2d4c5098

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page