A template project for Python with Gtk applications.
Go to file Use this template
itdominator fa46c39a7b Adding stronger type enforcement for settings; css transparency changes 2024-10-20 15:06:20 -05:00
plugins extending plugins to load pre or post app start 2024-06-29 21:24:57 -05:00
src Adding stronger type enforcement for settings; css transparency changes 2024-10-20 15:06:20 -05:00
user_config extending plugins to load pre or post app start 2024-06-29 21:24:57 -05:00
.gitignore Converted to using SqlModel as wrapper around SqlAlchemy 2023-09-23 00:12:36 -05:00
LICENSE Initial commit 2020-05-07 19:04:09 -05:00
README.md update readme 2024-07-26 19:53:04 -05:00
pyrightconfig.json update readme 2024-07-26 19:53:04 -05:00
requirements.txt extending plugins to load pre or post app start 2024-06-29 21:24:57 -05:00

README.md

Python-With-Gtk-Template

A template project for Python with Gtk applications.

Requirements

  • PyGObject (Gtk introspection library)
  • pygobject-stubs (For actually getting pylsp or python-language-server to auto complete in LSPs. Do if GTK3 --no-cache-dir --config-settings=config=Gtk3,Gdk3,Soup2)
  • pyxdg (Desktop ".desktop" file parser)
  • setproctitle (Define process title to search and kill more easily)
  • sqlmodel (SQL databases and is powered by Pydantic and SQLAlchemy)

Note

  • pyrightconfig.json can prompt IDEs that use pyright lsp on where imports are located- look at venvPath and venv. "venvPath" is parent path of "venv" where "venv" is just the name of the folder under the parent path that is the python created venv.
  • Move respetive sub folder content under user_config to the same places in Linux. Though, user/share/ can go to ~/.config folder if prefered.
  • In additiion, place the plugins folder in the same app folder you moved to /usr/share/ or ~/.config/ . There are a "<change_me>" strings and files that need to be set according to your app's name located at:
  • __builtins__.py
  • user_config/bin/app_name
  • user_config/usr/share/app_name
  • user_config/usr/share/app_name/icons/app_name.png
  • user_config/usr/share/app_name/icons/app_name-64x64.png
  • user_config/usr/share/applications/app_name.desktop

For the user_config, after changing names and files, copy all content to their respective destinations. The logic follows Debian Dpkg packaging and its placement logic.