|
| 1 | +# Contributing |
| 2 | + |
| 3 | +Welcome to Trie-Hard! Before you make a contribution, be it a bug report, documentation improvement, |
| 4 | +pull request (PR), etc., please read and follow these guidelines. |
| 5 | + |
| 6 | +## Start with filing an issue |
| 7 | + |
| 8 | +More often than not, **start by filing an issue on GitHub**. If you have a bug report or feature |
| 9 | +request, open a GitHub issue. Non-trivial PRs will also require a GitHub issue. The issue provides |
| 10 | +us with a space to discuss proposed changes with you and the community. |
| 11 | + |
| 12 | +Having a discussion via GitHub issue upfront is the best way to ensure your contribution lands in |
| 13 | +Trie-Hard. We don't want you to spend your time making a PR, only to find that we won't accept it on |
| 14 | +a design basis. For example, we may find that your proposed feature works better as a third-party |
| 15 | +module built on top of or for use with Trie-Hard and encourage you to pursue that direction instead. |
| 16 | + |
| 17 | +**You do not need to file an issue for small fixes.** What counts as a "small" or trivial fix is a |
| 18 | +judgment call, so here's a few examples to clarify: |
| 19 | +- fixing a typo |
| 20 | +- refactoring a bit of code |
| 21 | +- most documentation or comment edits |
| 22 | + |
| 23 | +Still, _sometimes_ we may review your PR and ask you to file an issue if we expect there are larger |
| 24 | +design decisions to be made. |
| 25 | + |
| 26 | +## Making a PR |
| 27 | + |
| 28 | +After you've filed an issue, you can make your PR referencing that issue number. Once you open your |
| 29 | +PR, it will be labelled _Needs Review_. A maintainer will review your PR as soon as they can. The |
| 30 | +reviewer may ask for changes - they will mark the PR as _Changes Requested_ and will give you |
| 31 | +details about the requested changes. Feel free to ask lots of questions! The maintainers are there |
| 32 | +to help you. |
| 33 | + |
| 34 | +Once we (the maintainers) decide to accept your change, we will label your PR as _Accepted_. |
| 35 | +Later (usually within a week or two), we will rebase your commits onto the `main` branch in a |
| 36 | +separate PR, batched alongside other _Accepted_ commits and any internal changes. (This process |
| 37 | +allows us to sync the state of our internal repository with the public repository.) Once your |
| 38 | +change lands in `main`, we will close your PR. |
| 39 | + |
| 40 | +### Caveats |
| 41 | + |
| 42 | +Currently, internal contributions will take priority. Today Trie-Hard is being maintained by |
| 43 | +Cloudflare's Content Delivery team, and internal Cloudflare proxy services are a primary user of |
| 44 | +Trie-Hard. We value the community's work on Trie-Hard, but the reality is that our team has a limited |
| 45 | +amount of resources and time. We can't promise we will review or address all PRs or issues in a |
| 46 | +timely manner. |
| 47 | + |
| 48 | +## Conduct |
| 49 | + |
| 50 | +Trie-Hard and Cloudflare OpenSource generally follows the [Contributor Covenant Code of Conduct]. |
| 51 | +Violating the CoC could result in a warning or a ban to Trie-Hard or any and all repositories in the Cloudflare organization. |
| 52 | + |
| 53 | +[Contributor Covenant Code of Conduct]: https://github.com/cloudflare/.github/blob/26b37ca2ba7ab3d91050ead9f2c0e30674d3b91e/CODE_OF_CONDUCT.md |
| 54 | + |
| 55 | +## Contact |
| 56 | + |
| 57 | +If you have any questions, please reach out to [[email protected]](mailto:[email protected]). |
0 commit comments