mycroft-core/.github/CONTRIBUTING.md

4.9 KiB

How to contribute

So you want to contribute to Mycroft? This should be as easy as possible for you but there are a few things to consider when contributing. The following guidelines for contribution should be followed if you want to submit a pull request.

How to Prepare

  • You need a GitHub account
  • Submit an issue ticket for your issue if one does not already exist.
    • Describe the issue and include steps to reproduce if it's a bug.
    • Ensure to mention the earliest version that you know is affected.
  • If you are able and want to fix this, fork the repository on GitHub and follow the instructions below.

Make Changes

  1. Fork the Project
  2. Clone onto your local machine and set MycroftAI/mycroft-core as your upstream branch
git clone https://github.com/<your-username>/<repo-name>
cd <repo-name>
git remote add upstream https://github.com/MycroftAI/mycroft-core
  1. If one does not already exist, create a new issue on the MycroftAI/mycroft-core Issues Tracker
  2. Create a feature or bugfix branch in your forked repo, based on dev with your issue identifier. For example, if your issue identifier is: issue-123 then you will create either: feature/issue-123 or bugfix/issue-123. Use feature prefix for issues related to new functionalities or enhancements and bugfix in case of bugs found on the dev branch
  3. Make sure you stick to the coding style and OO patterns that are used already.
  4. Document code using Google-style docstrings. Our automated documentation tools expect that format. All functions and class methods that are expected to be called externally should include a docstring. (And those that aren't should be prefixed with a single underscore).
  5. Make commits in logical units and describe them properly. Use your issue identifier at the very beginning of each commit. For instance: git commit -m "Issue-123 - Fixing 'A' sound on Spelling Skill"
  6. Before committing, format your code following the PEP8 rules and organize your imports removing unused libs. To check whether you are following these rules, install pep8 and run pep8 mycroft test while in the mycroft-core folder. This will check for formatting issues in the mycroft and test folders.
  7. Once you have committed everything and are done with your branch, you have to rebase your code with dev. Do the following steps:
    1. Make sure you do not have any changes left on your branch
    2. Checkout on dev branch and make sure it is up-to-date
    3. Checkout your branch and rebase it with dev
    4. Resolve any conflicts you have
    5. You will have to force your push since the historical base has changed
    6. Suggested steps are:
git checkout dev
git fetch
git reset --hard origin/dev
git checkout <your_branch_name>
git rebase dev
git push -f
  1. If possible, create unit tests for your changes
  2. Once everything is okay, you can create a Pull Request (PR) on MycroftAi/mycroft-core to have your code reviewed and merged.

Note: Do not work directly on the Master branch. All changes must be merged into dev, and will be automatically pushed to Master in the next release.

Submit Changes

  • Push your changes to a topic branch in your fork of the repository.
  • Open a pull request to the original repository and choose the right original branch you want to patch. Advanced users may install the hub gem and use the hub pull-request command.
  • If not done in commit messages (which you really should do) please reference and update your issue with the code changes. But please do not close the issue yourself.
  • Even if you have write access to the repository, do not directly push or merge pull-requests. Let another team member review your pull request and approve.

Additional Resources