Skip to content

Latest commit

 

History

History
42 lines (29 loc) · 5.12 KB

CONTRIBUTING.md

File metadata and controls

42 lines (29 loc) · 5.12 KB

Contributing to Jasper

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.

Philosophies

There are a few key philosophies to preserve while designing features for Jasper:

  1. 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.
  2. 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.
  3. 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.

DOs and DON'Ts

While developing, you should:

  1. Ensure that the existing unit tests pass. These are located in jasper-client/client/test.py and can be run with python test.py.
  2. 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).
  3. 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.
  4. Related to the above: Include docstrings that follow our existing format! Good documentation is a good thing.
  5. 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!
  6. Explain why your change is necessary. What does it accomplish? Is this something that others will want as well?
  7. 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:

  1. 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.
  2. Not do any of the DOs!

TODOs

If you're looking for something to do, here are some suggestions:

  1. Improve unit-testing for jasper-client. The Jasper modules and brain.py have ample testing, but other Python modules (conversation.py, mic.py, etc.) do not.
  2. 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.
  3. 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.
  4. Make Jasper platform-independent (this is a big one). For example, allow Jasper to run on OS X.
  5. Decouple Jasper from any specific Linux audio driver implementation.
  6. Modularize the speech-to-text and text-to-speech system so that Jasper developers can swap in their own implementations. This would allow some users to plug in, for example, the AT&T speech-to-text service while avoiding an inherent dependence (for Jasper core) on a third-party web service.