Hello! Thank you for taking your time to contribute!
Please note we have a Code of Conduct , please follow it in all your interactions with the project. Please report unacceptable behavior to [email protected].
-
Check if the question has been asked by searching on GitHub under Issues: Question.
-
If you're unable to find a similar question, open a new one under Question.
-
Please note that questions may take a long time until they get answered, if at all.
-
Ensure that the bug was not already reported by searching on GitHub under Issues: Bugs.
-
If you're unable to find an open issue addressing the problem, open a new one under Bug Report. Be sure to include a title and clear description, as much relevant information as possible, and a code sample or an executable test case demonstrating the expected behavior that is not occurring.
-
Ensure that the feature is not already requested by searching on GitHub under Issues: Features.
-
If you're unable to find an open issue for the feature, open a new one under Feature Request. Be sure to include a title and clear description, as much relevant information as possible, and describe the desired behaviour.
-
Open a new GitHub pull request.
-
Ensure the PR description clearly describes the problem and solution. Include the relevant issue number if applicable.
-
Before submitting, please read the Pull Request Guideline.
Feel free to make a pull request (see Pull Request Guideline) with a title that starts with [COSMETIC]. Please note that cosmetic pull requests may be rejected with little explanation. Reasoning behind these decisions can be explained here.
-
Try to keep your commits clean. This involves squashing commits together that do basically the same thing (e.g. fix problem, fix problem1, ...) or are cosmetic (e.g. fix typo), dividing a large commit into multiple smaller commits, and dropping commits that are not relevant to the PR. It is easier to squash commits together than it is to divide them, so it's normally good practice to keep your commits small.
-
Rebase your changes to the latest master.
-
Ensure that all of the contributed code is unit tested (code is tested in bite size pieces rather than at the end), passes coverage (every part of the code is tested), and follows the styleguide. To check, install tox (
pip install --user tox
) and runtox -e qa
from the project home directory. -
Update the README.md if necessary (e.g. new feature is added).
-
Increase the version numbers in
setup.py
and__version__.py
to the new version that this Pull Request would represent. The versioning scheme we use is SemVer. -
The Pull Request will be merged in once you have the sign-off of two other developers, or the project maintainer.