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.25.tar.gz (697.3 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.25-py3-none-any.whl (894.7 kB view details)

Uploaded Python 3

File details

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

File metadata

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

File hashes

Hashes for aas_core_codegen-0.0.25.tar.gz
Algorithm Hash digest
SHA256 ab75209f6334e89d6399e581f6d545aa273d1f07b39fbb0e1006665a80ab4b01
MD5 fe4a294b3534323a6cde9db3eaf87166
BLAKE2b-256 afef2004e4b01fb0b1775ca3b2e57a09d80cb4d6f592ad68e16f6b669847b744

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for aas_core_codegen-0.0.25-py3-none-any.whl
Algorithm Hash digest
SHA256 c49a66e2dcb9c1476dbfb0284ddfe78565632b089c08d427676ff5afcd0c37da
MD5 e056a9d5c5b39b236bd79cbdfe660e44
BLAKE2b-256 5a1951eb04d6f017cbb970508f133db5e5f20414f40a28bfe30bcca028389600

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