CONTRIBUTING.rst
Welcome to the DeepSpeech project! We are excited to see your interest, and appreciate your support!
This repository is governed by Mozilla's code of conduct and etiquette guidelines. For more details, please read the Mozilla Community Participation Guidelines <https://www.mozilla.org/about/governance/policies/participation/>_.
Here's some guidelines on how to make a good PR to DeepSpeech.
Bug-fix PR ^^^^^^^^^^
You've found a bug and you were able to squash it! Great job! Please write a short but clear commit message describing the bug, and how you fixed it. This makes review much easier. Also, please name your branch something related to the bug-fix.
Documentation PR ^^^^^^^^^^^^^^^^
If you're just making updates or changes to the documentation, there's no need to run all of DeepSpeech's tests for Continuous Integration (i.e. Taskcluster tests). In this case, at the end of your short but clear commit message, you should add X-DeepSpeech: NOBUILD. This will trigger the CI tests to skip your PR, saving both time and compute.
New Feature PR ^^^^^^^^^^^^^^
You've made some core changes to DeepSpeech, and you would like to share them back with the community -- great! First things first: if you're planning to add a feature (not just fix a bug or docs) let the DeepSpeech team know ahead of time and get some feedback early. A quick check-in with the team can save time during code-review, and also ensure that your new feature fits into the project.
The DeepSpeech codebase is made of many connected parts. There is Python code for training DeepSpeech, core C++ code for running inference on trained models, and multiple language bindings to the C++ core so you can use DeepSpeech in your favorite language.
Whenever you add a new feature to DeepSpeech and what to contribute that feature back to the project, here are some things to keep in mind:
DeepSpeech/data/ directory.Generally, a code owner will be notified of your pull request and will either review it or ask some other code owner for their review. If you'd like to proactively request review as you open the PR, see the the CODE_OWNERS.rst file which describes who's an appropriate reviewer depending on which parts of the code you're changing.
Before making a Pull Request for Python code changes, check your changes for basic mistakes and style problems by using a linter. We have cardboardlinter setup in this repository, so for example, if you've made some changes and would like to run the linter on just the changed code, you can use the follow command:
.. code-block:: bash
pip install pylint cardboardlint cardboardlinter --refspec master
This will compare the code against master and run the linter on all the changes. We plan to introduce more linter checks (e.g. for C++) in the future. To run it automatically as a git pre-commit hook, do the following:
.. code-block:: bash
cat <<\EOF > .git/hooks/pre-commit #!/bin/bash if [ ! -x "$(command -v cardboardlinter)" ]; then exit 0 fi
echo "Stashing working tree changes..." 1>&2 old_stash=$(git rev-parse -q --verify refs/stash) git stash save -q --keep-index new_stash=$(git rev-parse -q --verify refs/stash)
--amend or --allow-empty)if [ "$old_stash" = "$new_stash" ]; then echo "No changes, skipping lint." 1>&2 exit 0 fi
cardboardlinter --refspec HEAD -n auto status=$?
echo "Restoring working tree changes..." 1>&2 git reset --hard -q && git stash apply --index -q && git stash drop -q
exit $status EOF chmod +x .git/hooks/pre-commit
This will run the linters on just the changes made in your commit.