Parser and tools to perform model driven generation of artifacts (code, schema, documentation etc) from UML models. Current version supports Sparx EA Generated XMI 2.1, Sparx DB (including sqlite which is the '.qea' native file format for Sparx v16+) or diagrams.net XML. Coming soon is ERWIN XMI 1.0
Used to parse model files to native classes (see metamodel below) which are passed to jinja2 templates for generation of code (POJO, POCO, Django etc), JSON data and HTML documentation.
Quickstart and docs can be found here: readthedocs
Testing (powershell):
.\test.ps1
Testing (unittest):
python -m unittest
To generate code call the generate script and pass in the recipe folder. A sample recipe folder is provided in the github repo:
python mdg-tool.py generate ./sample_recipe/drawio/config-drawio-django.yaml
Or once installed into site-packages execute:
mdg-tool generate <my/config.yaml>
See the sample_recipe configs for examples
The UML parser expects a specific package hierarchy, please see the sample EA file.
- In Sparx select the domain root node (e.g. Model/Sample )
- Select the publish tab at the top
- Select Publish As... from top menu
- Set export type as XMI 2.1
- Optionally select 'Export Diagrams', 'Generate Diagram Images' and PNG format
- Export to folder where you want to generate from
Note: Sparx V16+ does not need to be export. Parser uses native SQLite file format which is the same schema as database repositories.
The UML parser expects a specific package layout which mimics the Sparx hierarchy, please see the sample files.
- In the web editor select Export As -> XML
- Uncheck 'Compressed'
If your generation recipe has created a file for your wiki (Confluence) then an uploader utilitity can be used. This assumes that you have done the XMI export from Sparx EA with export diagrams and generate diagram images. To generate a confluence token please see: https://confluence.atlassian.com/cloud/api-tokens-938839638.html
python mdg/confluence.py {your email} {your confluence token} {confluence page id} {path to images} {doc filename}
This diagram shows all the features and how to model in UML
This diagram shows the internal classes which are passed to the templates during generation.
Install sphinx
> cd pyMDG
> sphinx-apidoc -o docs\source mdg
> cd docs
> make html