A comprehensive GUI package manager for Houdini. Manage all your plugins and create new packages with ease.
- Download the application: https://houpm.com
- Github repository: https://github.com/ariffjeff/houdini-package-manager
- PyPI repository: https://pypi.org/project/houdini-package-manager
HPM is a Python application that basically grabs your plugins' package config files and converts them into a nice UI with a bunch of useful functionality.
- Gets Houdini's environment variable key value pairs.
- Gets the raw json package config data (some values might contain variables), typically found in
/packages
. - Uses the Houdini environment variables to resolve the package config variables. The data as a whole is also simplified.
- Creates arbitrary objects from this resolved package config/plugin data.
- Converts this package/plugin data into a Pyside6 UI with accompanying functionality.
- This is all then built into an executable with
Pyinstaller
.
- You can create new package configs for plugins you have downloaded to quickly get them into Houdini hassle free.
- HPM takes the plugin folder path, HDA, or script you provide it and simply creates a new package config from a template, and puts it in
/packages
.
- Download the latest version from https://houpm.com
- Unzip and store the folder anywhere you want.
- Create a shortcut of the Houdini_Package_Manager-x.y.z.exe file from the folder.
- Now you can run HPM from the shortcut, that's all there is to it!
Note: This project was primarily tested with Python 3.9.10.
- Install the Poetry dependency manager.
- Clone HPM
- Open a terminal, and
cd
to it.
- Open a terminal, and
- Do
poetry install
- Make your code changes and commit them
- If you're adding other files/images/vectors/etc., put them somewhere appropriate in
houdini_package_manager/resources/
- If you're adding other files/images/vectors/etc., put them somewhere appropriate in
- Version bump (optional)
- Automatic version bump:
- Do
poetry version minor
. Usemajor
orpatch
in place ofminor
if appropriate. These will automatically be updated:pyproject.toml
__version__
in__init__.py
. (if the Poetry poetry-bumpversion plugin is installed)- The relevant HTML in
houpm.com
. (auto updated later bymake prepare
) - The final executable and .zip file/folder names. (auto updated later by
make prepare
)
- Do
- Manual version bump:
- Do
poetry version 1.2.3
- Do
- Commit the version bump later along with a new build (keep reading next steps).
- Automatic version bump:
- Do
make prepare
- This does all the final build management automatically by running a bunch of other commands.
- Review these make commands only if you need to use them individually...
make test
runs the project pytests. Skip them withmake prepare TEST=0
make build-exe
builds the project. It will appear indist/
resources/
is copied to the build folder automatically so you don't have to worry about it.- The build folder and .exe name is determined by the version number set by the result of
poetry version ...
(referenced in the Makefile)
make zip
zips the build indist/
make dist-move
creates a copy of the dist build in the HouPM website dist_hpm folder.make update-houpm
updates HPM version html in houpm website.
- Run/test the build (sanity check)
- Run the build
- Different methods:
- Go to
dist/
, find the .exe and run it. - Or do
make run-exe
.- Be aware this doesn't run it directly in the folder its in, which can lead to the issue of relative file paths not being able to find the files they're targetting if the paths have been set improperly... i.e. images failing to load. Make sure you set file paths with
utils.epath()
which automatically handles relative paths correctly for both the dev and build environment.
- Be aware this doesn't run it directly in the folder its in, which can lead to the issue of relative file paths not being able to find the files they're targetting if the paths have been set improperly... i.e. images failing to load. Make sure you set file paths with
- Go to
- Different methods:
- If you get unexpected behavior or a crash:
- Check the app folder for a .log crash file.
- Crash log files currently are timestamped/created immediately upon exe run. If HPM is closed (not from a crash and not via the debug console) then the log file will be deleted.
- Do
make build-exe-log
to make an exe that displays a debug console on run which you can inspect. If any errors occur you'll be able to see them there.
- Check the app folder for a .log crash file.
- Run the build
- Commit
- Commit both the version bump (mentioned before) and the new build .zip together.
- The commit message should just be the version number (e.g.
1.3.2
) for convention. - Try not to commit anything else with these for simplicity.
- Tag the commit
- The tag name should be the version number (e.g.
1.3.2
) for convention. - You can do this by right clicking the commit if you're using a GUI like GitHub Desktop.
- The tag name should be the version number (e.g.
- Push and pull request
- Name the pull request the version number (e.g.
1.3.2
). - Merge to the relevant branch.
- Hopefully you haven't pushed directly to main.
- Name the pull request the version number (e.g.
- Create a new release
- On GitHub, go to Releases.
- Select the tag version number (e.g.
1.3.2
) from the dropdown. - Name the title the same version number.
- Click
Generate release notes
. - Add any extra descriptive changes for this release.
- Click publish.
- PyPI will automatically be updated with the new HPM version via a GitHub action.