Contributions are always welcome and greatly appreciated!
We love pull requests from everyone! Here's a quick guide to improve the code:
- Fork the repository and clone the fork.
- Create a virtual environment using your tool of choice (e.g.
virtualenv
,conda
, etc). - Install development dependencies:
pip install -r requirements-dev.txt
- Make sure all tests pass:
invoke test
- Start making your changes to the master branch (or branch off of it).
- Make sure all tests still pass:
invoke test
- Add yourself to
AUTHORS.rst
. - Commit your changes and push your branch to GitHub.
- Create a pull request through the GitHub website.
During development, use pyinvoke tasks on the command line to ease recurring operations:
invoke clean
: Clean all generated artifacts.invoke check
: Run various code and documentation style checks.invoke docs
: Generate documentation.invoke test
: Run all tests and checks in one swift command.invoke
: Show available tasks.
Ready to release a new version of pybullet_planning? Here's how to do it:
- We use semver, i.e. we bump versions as follows:
patch
: bugfixes.minor
: backwards-compatible features added.major
: backwards-incompatible changes.
- Update the
CHANGELOG.rst
with all novelty! - Ready? Release everything in one command:
invoke release [patch|minor|major] # with -b to bump version
- Celebrate! 💃
We could always use more documentation, whether as part of the introduction/examples/usage documentation or API documentation in docstrings.
Documentation is written in reStructuredText and use Sphinx to generate the HTML output.
Once you made the documentation changes locally, run the documentation generation:
invoke docs
When reporting a bug please include:
- Operating system name and version.
- Python version.
- Any details about your local setup that might be helpful in troubleshooting.
- Detailed steps to reproduce the bug.
The best way to send feedback is to file an issue on Github. If you are proposing a feature:
- Explain in detail how it would work.
- Keep the scope as narrow as possible, to make it easier to implement.