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.
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. These are located in
jasper-client/client/test.py
and can be run withpython test.py
. - 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.
- 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.