Your contributions are welcome and necessary. Please use GitHub's issue tracker to:
- Report bugs
- Propose or implement features
- Submit code changes / fixes
- Discuss code
Please adhere to the Code of Conduct.
Please do not ask usage questions, installation problems (unless they appear to be bugs) etc. via the GitHub issue tracker. We will set up a dedicated Q&A channel soon.
Please use the project's issue tracker to report bugs. If you have no experience in filing bug reports, see e.g., these recommendations by the Mozilla Developer Network first. Briefly, it is important that bug reports contain enough detail, background and, if applicable, minimal reproducible sample code. Tell us what you expect to happen, and what actually does happen.
Kindly use pull requests to submit changes to the code base. But please note that this project is driven by a community that likes to act on consensus. So in your own best interest, before just firing off a pull request after a lot of work, please open an issue to discuss your proposed changes first. Afterwards, please stick to the following simple rules to make sure your pull request will indeed be merged:
- Fork the repo and create a feature branch from branch
dev
, if present, ormaster
. - If you've added code that should be tested, add tests.
- Ensure that all tests pass.
- Document your code and update all relevant documentation.
- Stick to the code and documentation style (see below).
- Issue the pull request.
Important: Note that all your contributions are understood to be covered by the same license that covers the entire project.
Please use a recent version of Python 3.6 or higher. Python code, docstring and comment style loosely follows the Google Python Style Guide. Please try to conform to the used style to maintain consistency. Include type hints/annotations at least for function/method signatures.
Please use all of the following linters and validation tools with default settings and ensure that no warnings/errors are reported in any files before you commit: