Create a virtual environment activate it and install needed dependencies with the following commands:
python create_qgis_venv.py
.venv\Scripts\activate # On Linux and macOS run `source .venv\bin\activate`
pip install -r requirements-dev.txt
A symbolic link / directory junction should be made to the directory containing the installed plugins pointing to the dev plugin package.
On Windows Command promt
mklink /J %AppData%\QGIS\QGIS3\profiles\default\python\plugins\wntrqgis .\wntrqgis
On Windows PowerShell
New-Item -ItemType SymbolicLink -Path ${env:APPDATA}\QGIS\QGIS3\profiles\default\python\plugins\wntrqgis -Value ${pwd}\wntrqgis
On Linux
ln -s wntrqgis/ ~/.local/share/QGIS/QGIS3/profiles/default/python/plugins/wntrqgis
After that you should be able to enable the plugin in the QGIS Plugin Manager.
On VS Code use the workspace wntr-qgis.code-workspace. The workspace contains all the settings and extensions needed for development.
Select the Python interpreter with Command Palette (Ctrl+Shift+P). Select Python: Select Interpreter
and choose
the one with the path .venv\Scripts\python.exe
.
This project uses qgis_plugin_tools submodule,
so set git setting value: git config --global submodule.recurse true
.
When cloning use --recurse-submodules
like so:
git clone --recurse-submodules https://github.com/angusmcb/wntr-qgis.git
When pulling from existing repo:
git submodule init
git submodule update
The code for the plugin is in the wntrqgis folder. Make sure you have required tools, such as Qt with Qt Editor and Qt Linquist installed by following this tutorial.
For building the plugin use platform independent build.py script.
To get started with the development, follow these steps:
- Go to the wntrqgis directory with a terminal
- Create a new Python virtual environment with pre-commit using Python aware of QGIS libraries:
In Windows it would be best to use python-qgis.bat or python-qgis-ltr.bat:
python build.py venv
C:\OSGeo4W64\bin\python-qgis.bat build.py venv
- Note: This part is only for developers that are using QGIS < 3.16.8. If you want to use IDE for development, it is best to start it with the
following way on Windows:
:: Check out the arguments with python build.py start_ide -h set QGIS_DEV_IDE=<path-to-your-ide.exe> set QGIS_DEV_OSGEO4W_ROOT=C:\OSGeo4W64 set QGIS_DEV_PREFIX_PATH=C:\OSGeo4W64\apps\qgis-ltr C:\OSGeo4W64\bin\python-qgis.bat build.py start_ide :: If you want to create a bat script for starting the ide, you can do it with: C:\OSGeo4W64\bin\python-qgis.bat build.py start_ide --save_to_disk
Now the development environment should be all-set.
If you want to edit or disable some quite strict pre-commit scripts, edit .pre-commit-config.yaml. For example to disable typing, remove mypy hook and flake8-annotations from the file.
- Activate the virtual environment.
pip install pip-tools
pip-compile --upgrade requirements-dev.in
pip install -r requirements-dev.txt
orpip-sync requirements-dev.txt
If you create or edit source files make sure that:
-
they contain absolute imports:
from wntrqgis.utils.exceptions import TestException # Good from ..utils.exceptions import TestException # Bad
-
they will be found by build.py script (
py_files
andui_files
values) -
you consider adding test files for the new functionality
Edit build.py to contain working values for profile, lrelease and pyrcc. If you are running on Windows, make sure the value QGIS_INSTALLATION_DIR points to right folder
Run the deployment with:
python build.py deploy
After deploying and restarting QGIS you should see the plugin in the QGIS installed plugins where you have to activate it.
Install python packages listed in requirements-dev.txt to the virtual environment and run tests with:
pytest
Fill in transifex_coordinator
(Transifex username) and transifex_organization
in .qgis-plugin-ci to use Transifex translation.
If you want to see the translations during development, add i18n
to the extra_dirs
in build.py
:
extra_dirs = ["resources", "i18n"]
For step-by-step instructions, read the translation tutorial.
- First, install Transifex CLI and qgis-plugin-ci
- Make sure command
pylupdate5
works. Otherwise install it withpip install pyqt5
- Run
qgis-plugin-ci push-translation <your-transifex-token>
- Go to your Transifex site, add some languages and start translating
- Copy push_translations.yml file to workflows folder to enable automatic pushing after commits to master
- Add this badge to the README
There is no need to pull if you configure --transifex-token
into your
release workflow (remember to use Github Secrets). Remember to uncomment the
lrelease section as well. You can however pull manually to test the process.
- Run
qgis-plugin-ci pull-translation --compile <your-transifex-token>
#### Translating with QT Linguistic (if Transifex not available)
The translation files are in i18n folder. Translatable content in python files is
code such as tr(u"Hello World")
.
To update language .ts files to contain newest lines to translate, run
python build.py transup
You can then open the .ts files you wish to translate with Qt Linguist and make the changes.
Compile the translations to .qm files with:
python build.py transcompile
Follow these steps to create a release
- Add changelog information to CHANGELOG.md using this format
- Make a new commit. (
git add -A && git commit -m "Release 0.1.0"
) - Create new tag for it (
git tag -a 0.1.0 -m "Version 0.1.0"
) - Push tag to Github using
git push --follow-tags
- Create Github release
- qgis-plugin-ci adds release zip automatically as an asset
Modify release workflow according to its comments if you want to upload the plugin to QGIS plugin repository.
For local release install qgis-plugin-ci (possibly to different venv to avoid Qt related problems on some environments) and follow these steps:
cd wntr-qgis
qgis-plugin-ci package --disable-submodule-update 0.1.0