Want to contribute to Jasper? Great! We're always happy to have more contributors. Before you start developing, though, we ask that you read through this document in-full. It's full of tips and guidelines--if you skip it, you'll likely miss something important (and your pull request will probably be rejected as a result).
Throughout the process of contributing, there's one thing we'd like you to remember: Jasper was developed (and is maintained) by what might be described as "volunteers". They earn no money for their work on Jasper and give their time solely for the advancement of the software and the enjoyment of its users. While they will do their best to get back to you regarding issues and pull requests, your patience is appreciated.
The bug tracker at Github is for reporting bugs in Jasper. If you encounter problems during installation or compilation of one of Jasper's dependencies for example, do not create a new issue here. Please open a new thread in the support forum instead. Also, make sure that it's not a usage issue.
If you think that you found a bug and that you're using the most recent version of Jasper, please include a detailed description what you did and how to reproduce the bug. If Jasper crashes, run it with --debug
as command line argument and also include the full stacktrace (not just the last line). If you post output, put it into a fenced code block. Last but not least: have a look at Simon Tatham's "How to Report Bugs Effectively" to learn how to write a good bug report.
There are a few key philosophies to preserve while designing features for Jasper:
- The core Jasper software (
jasper-client
) must remain decoupled from any third-party web services. For example, the Jasper core should never depend on Google Translate in any way. This is to avoid unnecessary dependences on web services that might change or become paid over time. - The core Jasper software (
jasper-client
) must remain decoupled from any paid software or services. Of course, you're free to use whatever you'd like when running Jasper locally or in a fork, but the main branch needs to remain free and open-source. - Jasper should be usable by both beginner and expert programmers. If you make a radical change, in particular one that requires some sort of setup, try to offer an easy-to-run alternative or tutorial. See, for example, the profile populator (
jasper-client/client/populate.py
), which abstracts away the difficulty of correctly formatting and populating the user profile.
While developing, you should:
- Ensure that the existing unit tests pass. They can be run via
python2 -m unittest discover
for Jasper's main folder. - Test every commit on a Raspberry Pi. Testing locally (i.e., on OS X or Windows or whatnot) is insufficient, as you'll often run into semi-unpredictable issues when you port over to the Pi. You should both run the unit tests described above and do some anecdotal testing (i.e., run Jasper, trigger at least one module).
- Ensure that your code conforms to PEP8 and our existing code standards. For example, we used camel case in a few places (this could be changed--send in a pull request!). In general, however, defer to PEP8. We also really like Jeff Knupp's Writing Idiomatic Python. We use
flake8
to check this, so run it from Jasper's main folder before committing. - Related to the above: Include docstrings that follow our existing format! Good documentation is a good thing.
- Add any new Python dependencies to requirements.txt. Make sure that your additional dependencies are dependencies of
jasper-client
and not existing packages on your disk image! - Explain why your change is necessary. What does it accomplish? Is this something that others will want as well?
- Once your pull request has received some positive feedback: Submit a parallel pull request to the documentation repository to keep the docs in sync.
On the other hand, you should not:
- Commit any modules to the jasper-client repository. The modules included in jasper-client are meant as illustrative examples. Any new modules that you'd like to share should be done so through other means. If you'd like us to list your module on the web site, submit a pull request here.
- Not do any of the DOs!
If you're looking for something to do, here are some suggestions:
- Improve unit-testing for
jasper-client
. The Jasper modules andbrain.py
have ample testing, but other Python modules (conversation.py
,mic.py
, etc.) do not. - Come up with a better way to automate testing on the Pi. This might include spinning up some sort of VM with Docker, or take a completely different approach.
- Buff up the text-refinement functions in
alteration.py
. These are meant to convert text to a form that will sound more human-friendly when spoken by your TTS software, but are quite minimal at the moment. - Make Jasper more platform-independent. Currently, Jasper is only supported on Raspberry Pi and OS X.
- Decouple Jasper from any specific Linux audio driver implementation.