2018-11-10 11:56:40 +01:00
# Winit Contributing Guidelines
## Scope
2019-04-13 18:57:08 -04:00
[See `FEATURES.md` ](./FEATURES.md ). When requesting or implementing a new Winit feature, you should
consider whether or not it's directly related to window creation or input handling. If it isn't, it
may be worth creating a separate crate that extends Winit's API to add that functionality.
2018-11-10 11:56:40 +01:00
## Reporting an issue
2018-12-24 13:08:33 -05:00
When reporting an issue, in order to help the maintainers understand what the problem is, please make
2018-11-10 11:56:40 +01:00
your description of the issue as detailed as possible:
- if it is a bug, please provide clear explanation of what happens, what should happen, and how to
reproduce the issue, ideally by providing a minimal program exhibiting the problem
- if it is a feature request, please provide a clear argumentation about why you believe this feature
should be supported by winit
## Making a pull request
When making a code contribution to winit, before opening your pull request, please make sure that:
2022-09-02 10:59:05 +02:00
- your patch builds with Winit's minimal supported rust version - Rust 1.60.
2018-11-10 11:56:40 +01:00
- you tested your modifications on all the platforms impacted, or if not possible detail which platforms
were not tested, and what should be tested, so that a maintainer or another contributor can test them
- you updated any relevant documentation in winit
2018-12-24 13:08:33 -05:00
- you left comments in your code explaining any part that is not straightforward, so that the
2018-11-10 11:56:40 +01:00
maintainers and future contributors don't have to try to guess what your code is supposed to do
2022-01-23 13:55:33 +01:00
- your PR adds an entry to the changelog file if the introduced change is relevant to winit users.
You needn't worry about the added entry causing conflicts, the maintainer that merges the PR will
handle those for you when merging (see below).
2019-04-13 18:57:08 -04:00
- if your PR affects the platform compatibility of one or more features or adds another feature, the
2019-04-14 12:05:37 -04:00
relevant sections in [`FEATURES.md` ](https://github.com/rust-windowing/winit/blob/master/FEATURES.md#features )
should be updated.
2018-11-10 11:56:40 +01:00
Once your PR is open, you can ask for review by a maintainer of your platform. Winit's merging policy
is that a PR must be approved by at least two maintainers of winit before being merged, including
at least a maintainer of the platform (a maintainer making a PR themselves counts as approving it).
2022-01-23 13:55:33 +01:00
Once your PR is deemed ready, the merging maintainer will take care of resolving conflicts in
`CHANGELOG.md` (but you must resolve other conflicts yourself). Doing this requires that you check the
"give contributors write access to the branch" checkbox when creating the PR.
2018-11-10 11:56:40 +01:00
## Maintainers & Testers
2022-08-11 16:13:56 +02:00
The current maintainers are listed in the [CODEOWNERS ](.github/CODEOWNERS ) file.
2019-06-19 15:12:27 -04:00
2022-08-11 16:13:56 +02:00
If you are interested in being pinged when testing is needed for a certain platform, please add yourself to the [Testers and Contributors ](https://github.com/rust-windowing/winit/wiki/Testers-and-Contributors ) table!
2022-01-23 13:55:33 +01:00
## Making a new release
If you believe a new release is warranted, you can make a pull-request with:
- An updated version number (remember to change the version everywhere it is used).
- A new section in the changelog (below the `# Unreleased` section).
This gives contributors an opportunity to squeeze in an extra PR or two that they feel is valuable
enough to warrant blocking the release a little.
Once the PR is merged, a maintainer will create a new tag matching the version name (e.g. `v0.26.1` ),
and a CI job will automatically release the new version. Remember that the release date in the
changelog must be kept in check with the actual release date.