This project is a library for generating UML diagrams from Python source code, and it includes a demonstration application.
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.
You can install the project using pip. It is recommended to do this in a virtual environment.
pip install umlextensionsThis 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
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.
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.py
This will open a window titled "Demo UML Extensions".
-
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.
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
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.

