direnv: update to 2.35.0.
[void-pkg.git] / CONTRIBUTING.md
blob471b0ed2ddc886b22d38a801bb84c71ffe3393c9
1 # Contributing to void-packages
3 void-packages is the backbone of the Void Linux distribution. It contains all the definitions to build packages from source.
5 This document describes how you, as a contributor, can help with adding packages, correcting bugs and adding features to void-packages.
7 ## Package Requirements
9 To be included in the Void repository, software must meet at least one of the following requirements.
10 Exceptions to the list are possible, and might be accepted, but are extremely unlikely.
11 If you believe you have an exception, start a PR and make an argument for why that particular piece of software,
12 while not meeting any of the following requirements, is a good candidate for the Void packages system.
14 1. **System**: The software should be installed system-wide, not per-user.
16 1. **Compiled**: The software needs to be compiled before being used, even if it is software that is not needed by the whole system.
18 1. **Required**: Another package either within the repository or pending inclusion requires the package.
20 In particular, new themes are highly unlikely to be accepted.
21 Simple shell scripts are unlikely to be accepted unless they provide considerable value to a broad user base.
22 New fonts may be accepted if they provide value beyond aesthetics (e.g. they contain glyphs for a script missing in already packaged fonts).
23 Packages related to cryptocurrencies (wallets, miners, nodes, etc) are not accepted.
25 Browser forks, including those based on Chromium and Firefox, are generally not accepted.
26 Such forks require heavy patching, maintenance and hours of build time.
28 Software need to be used in version announced by authors as ready to use by the general public - usually called releases.
29 Betas, arbitrary VCS revisions, templates using tip of development branch taken at build time and releases created by the package maintainer won't be accepted.
31 ## Creating, updating, and modifying packages in Void by yourself
33 If you really want to get a new package or package update into Void Linux, we recommend you contribute it yourself.
35 We provide a [comprehensive Manual](./Manual.md) on how to create new packages.
36 There's also a [manual for xbps-src](./README.md), which is used to build package files from templates.
38 For this guide, we assume you have basic knowledge about [git](http://git-scm.org), as well as a [GitHub Account](http://github.com) with [SSH set up](https://docs.github.com/en/authentication/connecting-to-github-with-ssh).
40 You should also [set the email](https://docs.github.com/en/account-and-profile/setting-up-and-managing-your-personal-account-on-github/managing-email-preferences/setting-your-commit-email-address) on your GitHub account and in git so your commits are associated with your GitHub account properly.
42 To get started, [fork](https://help.github.com/articles/fork-a-repo) the void-linux `void-packages` git repository on GitHub and clone it:
44     $ git clone git@github.com:<user>/void-packages.git
46 To keep your forked repository up to date, setup the `upstream` remote to pull in new changes:
48     $ git remote add upstream https://github.com/void-linux/void-packages.git
49     $ git pull --rebase upstream master
51 This can also be done with the `github-cli` tool:
53     $ gh repo fork void-linux/void-packages
54     $ gh repo clone <user>/void-packages
56 This automatically sets up the `upstream` remote, so `git pull --rebase upstream master` can still be used to keep your fork up-to-date.
58 Using the GitHub web editor for making changes is strongly discouraged, because you will need to clone the repo anyways to edit and test your changes.
60 Using the `master` branch of your fork for contributing is also strongly discouraged.
61 It can cause many issues with updating your pull request (also called a PR), and having multiple PRs open at once.
62 To create a new branch:
64     $ git checkout master -b <a-descriptive-name>
66 ### Creating a new template
68 You can use the helper tool `xnew`, from the [xtools](https://github.com/leahneukirchen/xtools) package, to create new templates:
70     $ xnew pkgname subpkg1 subpkg2 ...
72 Templates must have the name `void-packages/srcpkgs/<pkgname>/template`, where `pkgname` is the same as the `pkgname` variable in the template.
74 For deeper insights on the contents of template files, please read the [manual](./Manual.md), and be sure to browse the existing template files in the `srcpkgs` directory of this repository for concrete examples.
76 ### Updating a template
78 At minimum, a template update will consist of changing `version` and `checksum`, if there was an upstream version change, and/or `revision`, if a template-specific change (e.g. patch, correction, etc.) is needed.
79 Other changes to the template may be needed depending on what changes the upstream has made.
81 The checksum can be updated automatically with the `xgensum` helper from the [xtools](https://github.com/leahneukirchen/xtools) package:
83     $ xgensum -i <pkgname>
85 ### Adopting a template
87 If a template is orphaned (maintained by `orphan@voidlinux.org`) or the current `maintainer` has not contributed to
88 Void in over a year, template maintainership can be adopted by someone else. To ensure a template gets the care it needs,
89 template adopters should be familiar with the package and have an established history of contributions to Void.
90 Those who have contributed several updates, especially for the template in question, are good candidates for template
91 maintainership.
93 It is best to adopt a template when making another change to it. When adopting the template, add your name or username
94 and email to the `maintainer` field in the template, and mention the adoption in your commit message, for example:
96     libfoo: update to 1.2.3, adopt.
98 ### Orphaning a template
100 If you no longer wish to maintain a template, you can remove yourself as maintainer by setting the `maintainer` field in
101 the template to `Orphaned <orphan@voidlinux.org>`. The commit message should mention this, for example:
103     libfoo: orphan.
105 It is not necessary to make other changes to the template when orphaning, and incrementing the revision (triggering a
106 rebuild) is not necessary either.
108 ### Committing your changes
110 After making your changes, please check that the package builds successfully. From the top level directory of your local copy of the `void-packages` repository, run:
112     $ ./xbps-src pkg <pkgname>
114 Your package must build successfully for at least x86, but we recommend also trying a cross-build for armv6l* as well, e.g.:
116     $ ./xbps-src -a armv6l pkg <pkgname>
118 When building for `x86_64*` or `i686`, building with the `-Q` flag or with `XBPS_CHECK_PKGS=yes` set in `etc/conf` (to run the check phase) is strongly encouraged.
119 Also, new packages and updates will not be accepted unless they have been runtime tested by installing and running the package.
121 When you've finished working on the template file, please check it with `xlint` helper from the [xtools](https://github.com/leahneukirchen/xtools) package:
123     $ xlint template
125 If `xlint` reports any issues, resolve them before committing.
127 Once you have made and verified your changes to the package template and/or other files, make one commit per package (including all changes to its sub-packages). Each commit message should have one of the following formats:
129 * for new packages, use `New package: <pkgname>-<version>` ([example](https://github.com/void-linux/void-packages/commit/8ed8d41c40bf6a82cf006c7e207e05942c15bff8)).
131 * for package updates, use `<pkgname>: update to <version>.` ([example](https://github.com/void-linux/void-packages/commit/c92203f1d6f33026ae89f3e4c1012fb6450bbac1)).
133 * for template modifications without a version change, use `<pkgname>: <reason>` ([example](https://github.com/void-linux/void-packages/commit/ff39c912d412717d17232de9564f659b037e95b5)).
135 * for package removals, use `<pkgname>: remove package` and include the removal reason in the commit body ([example](https://github.com/void-linux/void-packages/commit/4322f923bdf5d4e0eb36738d4f4717d72d0a0ca4)).
137 * for changes to any other file, use `<filename>: <reason>` ([example](https://github.com/void-linux/void-packages/commit/e00bea014c36a70d60acfa1758514b0c7cb0627d),
138   [example](https://github.com/void-linux/void-packages/commit/93bf159ce10d8e474da5296e5bc98350d00c6c82), [example](https://github.com/void-linux/void-packages/commit/dc62938c67b66a7ff295eab541dc37b92fb9fb78), [example](https://github.com/void-linux/void-packages/commit/e52317e939d41090562cf8f8131a68772245bdde))
140 If you want to describe your changes in more detail, explain in the commit body (separated from the first line with a blank line) ([example](https://github.com/void-linux/void-packages/commit/f1c45a502086ba1952f23ace9084a870ce437bc6)).
142 `xbump`, available in the [xtools](https://github.com/leahneukirchen/xtools) package, can be used to commit a new or updated package:
144     $ xbump <pkgname> <git commit options>
146 `xrevbump`, also available in the [xtools](https://github.com/leahneukirchen/xtools) package, can be used to commit a template modification for a package:
148     $ xrevbump '<message>' <pkgnames...>
150 `xbump` and `xrevbump` will use `git commit` to commit the changes with the appropriate commit message. For more fine-grained control over the commit, specific options can be passed to `git commit` by adding them after the package name.
152 ### Starting a pull request
154 Once you have successfully built the package, you can [create a pull request](https://docs.github.com/en/github/collaborating-with-issues-and-pull-requests/creating-a-pull-request). Pull requests are also known as PRs.
156 Most pull requests should only contain a single package and dependencies which are not part of void-packages yet.
158 If you make updates to packages containing a soname bump, you also need to update `common/shlibs` and revbump all packages that are dependant.
159 There should be a commit for each package revbump, and those commits should be part of the same pull request.
161 When you make changes to your pull request, please *do not close and reopen your pull request*. Instead, just [forcibly git push](#review), overwriting any old commits. Closing and opening your pull requests repeatedly spams the Void maintainers.
163 #### Continuous Integration
165 Pull requests are automatically submitted for Continuous Integration (CI) testing to ensure packages build and pass their tests (on native builds) on various combinations of C library and architecture.
166 Packages that take longer than 120 minutes or need more than 14G of storage to complete their build (for example, Firefox or the Linux kernel) will fail CI and should include `[ci skip]` in the PR title or body (the comment field when the PR is being opened) to avoid wasting CI builder time.
167 Use your best judgment on build times based on your local building experience. If you skip CI when submitting a PR, please build and cross-build for a variety of architectures locally, with both glibc and musl, and note your local results in PR comments.
168 Make sure to cover 64-bit and 32-bit architectures.
170 If you notice a failure in CI that didn't happen locally, that is likely because you didn't run tests locally.
171 Use `./xbps-src -Q pkg <package>` to do so.
172 Some tests won't work in the CI environment or at all, and their templates should encode this information using the `make_check` variable.
174 Continuous Integration will also check if the templates you have changed
175 comply with the our guidelines. At the moment not all packages comply with the rules, so if you update a package, it may report errors about places you haven't touched. Please feel free to fix those errors too.
177 #### Review
179 It's possible (and common) that a pull request will contain mistakes or reviewers will ask for additional tweaks.
180 Reviewers will comment on your pull request and point out which changes are needed before the pull request can be merged.
182 Most PRs will have a single commit, as seen [above](#committing-your-changes), so if you need to make changes to the commit and already have a pull request open, you can use the following commands:
184     $ git add <file>
185     $ git commit --amend
186     $ git push -f
188 A more powerful way of modifying commits than using `git commit --amend` is with [git-rebase](https://git-scm.com/docs/git-rebase#_interactive_mode), which allows you to join, reorder, change description of past commits and more.
190 Alternatively, if there are issues with your git history, you can make another branch and push it to the existing PR:
192     $ git checkout master -b <attempt2>
193     $ # do changes anew
194     $ git push -f <fork> <attempt2>:<branch-of-pr>
196 #### Closing the pull request
198 Once you have applied all requested changes, the reviewers will merge your request.
200 If the pull request becomes inactive for some days, the reviewers may or may not warn you when they are about to close it.
201 If it stays inactive further, it will be closed.
203 Please abstain from temporarily closing a pull request while revising the templates. Instead, leave a comment on the PR describing what still needs work, [mark it as a draft](https://docs.github.com/en/pull-requests/collaborating-with-pull-requests/proposing-changes-to-your-work-with-pull-requests/changing-the-stage-of-a-pull-request#converting-a-pull-request-to-a-draft), or add "[WIP]" to the PR title. Only close your pull request if you're sure you don't want your changes to be included.
205 #### Publishing the package
207 Once the reviewers have merged the pull request, our [build server](http://build.voidlinux.org) is automatically triggered and builds
208 all packages in the pull request for all supported platforms. Upon completion, the packages are available to all Void Linux users.
210 ## Testing Pull Requests
212 While it is the responsibility of the PR creator to test changes before sending it, one person can't test all configuration options, usecases, hardware, etc.
213 Testing new package submissions and updates is always helpful, and is a great way to get started with contributing.
214 First, [clone the repository](https://github.com/void-linux/void-packages#quick-start) if you haven't done so already.
215 Then check out the pull request, either with `github-cli`:
217     $ gh pr checkout <number>
219 Or with `git`:
221 If your local void-packages repository is cloned from your fork, you may need to add the main repository as a remote first:
223     $ git remote add upstream https://github.com/void-linux/void-packages.git
225 Then fetch and check out the PR (replacing `<remote>` with either `origin` or `upstream`):
227     $ git fetch <remote> pull/<number>/head:<branch-name>
228     $ git checkout <branch-name>
230 Then [build and install](https://github.com/void-linux/void-packages#building-packages) the package and test its functionality.