Plugins for umldiagrammer
Project description
Introduction
This project is a library for generating UML diagrams from Python source code, and it includes a demonstration application.
Overview
The umlextensions module provides a flexible way to add capabilities to the core UML Diagrammer. There are extensions that read external data and convert it to a UML class diagram. An example, is the InputPython extension that reads Python source code and generates an appropriate UML Diagram. There are extensions that take an existing UML diagram and convert it to a different structure format. For example, the OutputGML extension produced GML files.
Finally, there are tool extensions that manipulate a UML diagram. Examples of this are:
- ToolOrthogonalLayout - Lays out shapes in a manner to minimize link crossings and link bends
- ToolOrthgonalRouting - Lays out link such that link bends are orthogonal
- ToolSugiyama - Lays out shapes and links in a pleasing manner.
Installation
You can install the project using pip. It is recommended to do this in a virtual environment.
pip install umlextensions
Dependencies
This project relies on several other packages. pip will handle the installation of these dependencies. They are listed here for your reference:
- wxPython
- codeallybasic
- codeallyadvanced
- umlmodel
- umlshapes
- umlio
- antlr4-python3-runtime
- PyPubSub
Usage
The primary way to use this project is as a library within a larger application. However, a demonstration application is included to showcase the functionality.
Running the Demo Application
To run the demo application, follow these steps:
-
Clone the repository (if you haven't already):
git clone https://github.com/hasii2011/umlextensions.git cd umlextensions
-
Install dependencies (it is recommended to use a virtual environment):
pip install -e .
-
Run the demo application:
python tests/extensiondemo/ExtensionDemoApp.pyThis will open a window titled "Demo UML Extensions".
Generating a UML Diagram
-
In the "Demo UML Extensions" window, navigate to the menu bar and click Extensions -> Input -> Python File(s).
-
A file dialog will appear, allowing you to select one or more Python files. Select the files you want to include in your UML diagram and click Open.
-
After parsing the files, a dialog titled "Shape Layout Parameters" may appear, allowing you to adjust the layout of the UML shapes. You can accept the defaults or modify them as needed and click OK.
-
The application will then generate and display the UML class diagram based on the Python code in the selected files.
As a Library
The project is designed to be used as a library. The umlextensions package can be imported into your own wxPython application. The ExtensionsManager class is the main entry point for discovering and running extensions. You can integrate it into your application by providing an implementation of the IExtensionsFacade.
Written by Humberto A. Sanchez II <mailto@Humberto.A.Sanchez.II@gmail.com>, (C) 2025
Note
For all kind of problems, requests, enhancements, bug reports, etc., please drop me an e-mail.
I am concerned about GitHub's Copilot project
I urge you to read about the Give up GitHub campaign fromthe Software Freedom Conservancy.
While I do not advocate for all the issues listed there I do not like that a company like Microsoft may profit from open source projects.
I continue to use GitHub because it offers the services I need for free. But, I continue to monitor their terms of service.
Any use of this project's code by GitHub Copilot, past or present, is done without my permission. I do not consent to GitHub's use of this project's code in Copilot.
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
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file umlextensions-0.9.0.tar.gz.
File metadata
- Download URL: umlextensions-0.9.0.tar.gz
- Upload date:
- Size: 451.0 kB
- Tags: Source
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.12
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
8eccdef485f1b11539c9a8aba2f170a2e77f7c36522ce50e282544fdb5d79832
|
|
| MD5 |
f4297690ada8fecf4fb47d6a84327468
|
|
| BLAKE2b-256 |
39129e3d858585d63c5e6611fd87b2722a13ec4986bdf07a14e34059b37e35b2
|
Provenance
The following attestation bundles were made for umlextensions-0.9.0.tar.gz:
Publisher:
python-publish.yml on hasii2011/umlextensions
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
umlextensions-0.9.0.tar.gz -
Subject digest:
8eccdef485f1b11539c9a8aba2f170a2e77f7c36522ce50e282544fdb5d79832 - Sigstore transparency entry: 1513317169
- Sigstore integration time:
-
Permalink:
hasii2011/umlextensions@041f77cc79db53c706d8ac5153914df3bb2dfede -
Branch / Tag:
refs/tags/0.9.0 - Owner: https://github.com/hasii2011
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
python-publish.yml@041f77cc79db53c706d8ac5153914df3bb2dfede -
Trigger Event:
release
-
Statement type:
File details
Details for the file umlextensions-0.9.0-py3-none-any.whl.
File metadata
- Download URL: umlextensions-0.9.0-py3-none-any.whl
- Upload date:
- Size: 487.2 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.12
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
086a1725434e8785fb005a31b2f4f2f62bac5235bd7c3b0015c20683168ed234
|
|
| MD5 |
b31e65c7871d07155ae1f86c96c10416
|
|
| BLAKE2b-256 |
3cc5773725380d053004b294eded177af61d4cf68ff0075d56955abbf79ffb20
|
Provenance
The following attestation bundles were made for umlextensions-0.9.0-py3-none-any.whl:
Publisher:
python-publish.yml on hasii2011/umlextensions
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
umlextensions-0.9.0-py3-none-any.whl -
Subject digest:
086a1725434e8785fb005a31b2f4f2f62bac5235bd7c3b0015c20683168ed234 - Sigstore transparency entry: 1513317294
- Sigstore integration time:
-
Permalink:
hasii2011/umlextensions@041f77cc79db53c706d8ac5153914df3bb2dfede -
Branch / Tag:
refs/tags/0.9.0 - Owner: https://github.com/hasii2011
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
python-publish.yml@041f77cc79db53c706d8ac5153914df3bb2dfede -
Trigger Event:
release
-
Statement type: