Contributing
Enhancements and fixes are always welcome. Feel free to contribute to any of the Issues not already assigned to another person.
🐛 Bug Fixes
Feel free to dive right in and help fix bugs when you find them. Just make sure you've thoroughly tested the fix and be sure to read about creating a good pull request.
✨ New Features, Refactors, and Enhancements
I really appreciate anyone willing to dive into the deep end to tackle more complex changes in P2G. Here are some steps I ask you take before embarking on this journey.
- If an Issue doesn't already exist, please create one.
- Ensure the Issue describes in detail what the change is and why its needed
- Use the Issue to propose an implementation plan
- See creating a good pull request
Please also keep the following in mind:
- P2G should never introduce any breaking or non-backwards compatible changes unless we are targeting a Major Version Release
- P2G supports many flavors of installl, all enhancements need to be implemented and tested on all flavors, or explicitly documented as not supported.
Creating a good Pull Request
Ensure that your code:
- Compiles
- Follows established conventions of the codebase (check your white spaces)
- Keeps changes focused and minimizes scope creep
- Works for all flavors of P2G
- Unit tests have been added and pass
- Documentation Site has been updated
- Example Config Files and Docker files have been updated (when appropriate)
- Update the Release Notes file
Contribute to this site
This documentation site is maintained from the repository, you can find and edit it here.
👿 What if you never merge my PR?
First, I'm sorry, I really do value that you've taken time to work through the code and give back to the community. Seriously, so few people actually do this, so thank you.
There will be times where I choose not to accept what may otherwise be seen as a perfectly reasonable change in yours or others minds.
I reserve this right as the primary maintainer and first line support for this project. There will be changes that I may feel (subjectively) will make it harder for me to do my job and I will likely not merge these.
Always, my motiviations are:
- The stability of P2G for all users
- Long term maintainability (for me)
- Ease of providing first line support to others
- Ease of future enhancements (for me)
- Ease of rollback, or hotfixing (for me)
- Providing the most functionality while minimizing the barrier of entry