Model text file + layout text file -> beautiful diagram
Project description
Flatland Model Diagram (non) Editor
I built this tool because I want beautiful, human readable model diagram layouts. PlantUML (and its ilk), especially for large, detailed non-hierarchical diagrams do not deliver. Also, I have wasted way too many hours of my career pushing pixels around in both proprietary and open source diagram editors and I am sick of it! No mas!!! I need to be able to quickly edit and change complex model diagrams, keep them under configuration management, and integrate them into our open source code/documentation generation pipeline.
Flatland is a model diagram non-editor written by myself Leon Starr that generates beautiful PDFs (and other output formats) based on two very human-readable input text files. The model file specifies model semantics (state transitions, generalizations, classes etc) while the layout file specifies (node placement and alignment, connector anchors) and lightly refers to some elements in the model file. You can think of the layout file as a "style sheet" for your models. Some benefits:
- You can now put your models under configuration management since the source is all text.
- Complex model layouts are easily edited without the need for tedious pixel pushing in a graphical editor
- Executable UML (xUML) in particular is supported, but any similar kind of model diagrams can be supported with minor extensions
In fact, you edit the models and layout in your favorite text editor and then a diagram is generated. So, technically, this is not an editor at all, but a diagram generator. That said, the generator and associated model and layout grammar/parsers effectively set you up with a powerful open source model editor.
WARNING: I am in the process of figuring out PyPI for the first time, so it's going to be a few weeks before this tool is ready to use. I don't recommend wasting your time downloading just yet. Follow me on twitter or LinkedIn for updates. I do have a nice alpha version working that makes awesome class diagrams in my cozy PyCharm environment, but it turns out that multi-platform deployment is a pain in the ass. Who knew? ;)
Shameless plug
In the meantime, if you are curious about the whole MBSE thing that this tool supports, take a look at our book. Also, various resources at the Model Integration website.
Installation
You can install the Flatland Model Diagram Editor from PyPI:
pip install flatland-model-diagram-editor
Flatland is supported on Python 3.7 and above
How to use
Assuming you have two files, my_model.xmm (xmm = Executable Model Markdown) and my_layout.xss (xss = Executable model Style Sheet),
$ flatland -m my_model.xmm -l my_layout.xss -d my_beautiful_diagram.pdf
Or the model can be standard input and the diagram can go to standard output:
$ my_model.xmm > flatland -l my_layout.xss > my_beautiful_diagram.pdf
Model and layout files
Initially I will be supplying a grammar/parser for specifying model layouts. It knows all about nodes, connectors of various types and uses a system for placement of nodes and connector anchors that doesn't require you to know anything about pixels or points. We use an agile system of relative placement that is extremely awesome!
The grammar is a PEG grammar defined using the arpeggio python package.
The model grammar/parser, also provided, is specifically for xUML model semantics. If you have some other modeling language that you want to draw, no worries. You can use the template to create your own grammar. You will need to get comfortable with arpeggio and PEG grammars, but you're a smart engineer and I know you can do it!
Schedule
I will be futzing around with PyPI, manifests, documentation, relative imports and so forth into early February 2021, so a version you can actually use to do something useful probably won't be available until then.
Expect this to be in serious beta by late spring 2021. I would like it to be sooner, but I have a day job.
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
File details
Details for the file flatland-model-diagram-editor-0.5.2.tar.gz
.
File metadata
- Download URL: flatland-model-diagram-editor-0.5.2.tar.gz
- Upload date:
- Size: 33.6 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/3.3.0 pkginfo/1.6.1 requests/2.25.1 setuptools/51.1.0 requests-toolbelt/0.9.1 tqdm/4.55.0 CPython/3.9.0
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 3f7f5b92f35a919f3e9a496de4b31af0286c8a28ac413e2b4348c5590662fddd |
|
MD5 | 49178cbf288520736a815b76fa7853bc |
|
BLAKE2b-256 | 891803f220787f663d91a52ade6b2564c8e9dcc183015c66f85b9689aa5886b3 |
File details
Details for the file flatland_model_diagram_editor-0.5.2-py3-none-any.whl
.
File metadata
- Download URL: flatland_model_diagram_editor-0.5.2-py3-none-any.whl
- Upload date:
- Size: 48.8 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/3.3.0 pkginfo/1.6.1 requests/2.25.1 setuptools/51.1.0 requests-toolbelt/0.9.1 tqdm/4.55.0 CPython/3.9.0
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 3d286cb4af3b3fa5ad364a6605f9eebab136699d469c7574c720df4490b3c47c |
|
MD5 | c363f6888ce25fdefcbe02d91d9b3796 |
|
BLAKE2b-256 | a8855c7c289ac0c527abaffa0413eda724e291eda15f41ba51b1720d023e7909 |