We love that you are interested in joining the HeliOS Project community as a contributor. We want to make contributing to the project as easy and seamless as possible, whether it is:
- Reporting a bug
- Submitting a bug fix
- Asking a question
- Proposing new features
- Submitting a new feature
- Improving documentation
- Becoming a maintainer
The HeliOS Project uses GitHub exclusively to maintain and develop HeliOS. The best methods for engaging with the HeliOS Project is through GitHub Issues and Pull Requests.
Submit a:
- Issue: If you are reporting a bug, asking a question or proposing a new feature, then submit an issue. Please do not submit source code or other file changes through an issue. If you do, you will be asked to submit a pull request and your issue will be closed. See the Submitting an Issue section below for more details on submitting an issue.
- Pull Request: If you are submitting a bug fix or a new feature, then submit a pull request. See the Submitting a Pull Request section below for more details.
If you are reporting a bug then submit a Bug Report issue. If you are in need of help or seeking support then submit a Support Request. Anything else should be submitted as an Other Request. To open a new issue, go here. We kindly ask for your patience as it may take several days before we are able to respond to your issue. If it is a bug report or support request, it may take longer.
First and foremost, it may take a week or more before your pull request is merged (if at all). All pull requests are reviewed multiple times and we may request you make changes before your pull request is merged. Once your pull request is merged, it will not appear in the mainline HeliOS source code until the next release which may be months away. To submit a pull request, the following steps must be followed:
- Fork the repository (you must uncheck [x] Copy the
main
branch only. option before forking the repository) into your personal GitHub account. If you do not perform this step correctly, only themaster
branch will be forked and you will have to start over. - Create a new branch named
develop-<account_name>
from thedevelop
branch. Do not make your changes to the sources in themaster
branch (this branch contains the latest release). If you do, your pull request will be rejected. - Make your source code changes.
- If you have added a new feature, you must add unit tests for the new feature. The unit tests are in
/test
. Pull requests for new features not accompanied by unit tests will be rejected. - Changes to source code must include code comments (where appropriate) and be accompanied by documentation updates (again, where appropriate). Most documentation changes are made to the doxygen documentation in
/src/HeliOS.h
which is used to auto-generate the HeliOS Developer's Guide. - Run Uncrustify against the source code files. The HeliOS Uncrustify config is available in
/extras/uncrustify/helios.cfg
. - Ensure your code compiles without warnings and all unit tests pass.
- Create a commit and push to the remote.
- Last, but most importantly. Create and submit your pull request. Then go have a 🍺.
In short, when you contribute source code, documentation or other file changes to the HeliOS project, those contributions will become part of the HeliOS Project license and copyright.
Thank you for your contributions to HeliOS. 🙏