Thank you for taking an interest in contributing to Gourmand! We appreciate that you're thinking about offering your time to improving the project, and it's our goal to respect your contribution accordingly.
Although this document focuses on code contributions, you can contribute in several ways:
- File a bug report.
- Add or improve documentation.
- Promote the project to others.
In general, the process for contributing code is:
- Pick or open an issue to work on
- Post a comment expressing your intent to make sure nobody else is already working on it
- Set up a development environment, as described below
- Do your changes, and when ready
- Push your changes to your forked repo and create a pull request.
Fork and clone Gourmand.
Ensure your system has the necessary prerequisites installed:
- Python, which is what Gourmand is written in.
- PyGObject for GTK+ 3 and
other GNOME libraries. You may either install your system's
pygobject
package(s) or install the necessary system requirements to installpygobject
from PyPI withpip
. The latter method is recommended if you plan on doing development within a Python virtual environment. - intltool for internationalization.
- (optional) Enchant for spell-checking. At least one of the backends must be installed as well.
- (optional) GStreamer for sound. The GStreamer library itself and gst-plugins-base are required. Python bindings are provided through PyGObject, so GObject introspection data is also needed.
- (optional) poppler for exporting PDFs. Python bindings are provided through PyGObject, so install the GLIB bindings and associated GObject introspection data.
Note: Although some prerequisites are optional, the development install of Gourmand enables all plugins and features, so you probably want to install all prerequisites to avoid any issues.
You may want to set up a Python virtual environment. This is optional but highly recommended:
$ python -m venv --prompt gourmand venv
$ source venv/bin/activate
(gourmand) $ pip install -U pip setuptools wheel
Then install Gourmand itself:
(gourmand) $ pip install -r development.in
This installs the remaining Python dependencies and Gourmand itself in editable mode, which allows you to run Gourmand and see your changes without having to reinstall it.
Note: If you encounter an error during the installation of
pygtkspellcheck
, first install pyenchant
and pygobject
on their own:
(gourmand) $ pip install pyenchant pygobject
(gourmand) $ pip install -r development.in
You should now be able to launch and run Gourmand:
(gourmand) $ gourmand
Gourmand is an old code base, consequently its style is not always consistent or
conformant to contemporary tastes.
Please follow PEP 8 when writing new
code, and when working on old code, please tidy up as you go.
We welcome feedback and issue reporting. You can do so by browsing existing issues and commenting on them, or creating a new one.
When reporting an issue, please fill in the provided template.
For feedback or requests of features, please explain with details, and screenshots if possible, what you would like.
The following describes how to contribute translation.
Update the translation template:
cd po/
intltool-update -p -g gourmand
A file gourmand.pot
should have been modified. Add it to git.
If modifying an already existing translation, update the translation file:
msgmerge --update --no-fuzzy-matching --backup=off fr.po gourmand.pot
If adding translation for a new language, copy the file for your target
language, such as fr.po
or de_AT.po
, if translating for a specific region,
and add it to git.
Once the translation is done, update the translations:
python setup.py build_i18n
Launch Gourmand and check the changes.
Once satisfied, open a pull request with your work.
Gourmand have a test suite in the tests
directory. Patches that expands it are welcome.
It is run with pytest:
pytest
Most modern python IDEs have support for running the tests usin pytest.