44 KiB
Contributing to Nixpkgs
This document is for people wanting to contribute to Nixpkgs. This involves changes that are proposed using GitHub pull requests to the Nixpkgs repository.
A GitHub account is recommended, which you can sign up for here. See here for how to contribute without a GitHub account.
This document assumes that you already know how to use GitHub and Git. If that's not the case, we recommend learning about it here.
Overview
This file contains general contributing information. More specific information about individual parts of Nixpkgs can be found here:
doc
: Sources and infrastructure for the Nixpkgs manuallib
: Sources and documentation of the library functionsmaintainers
: Nixpkgs maintainer and team listings, maintainer scriptsnixos
: Implementation of NixOSpkgs
: Package and builder definitions
How to's
How to create pull requests
This section describes how changes can be proposed with a pull request (PR).
Note
Be aware that contributing implies licensing those contributions under the terms of COPYING, an MIT-like license.
-
Set up a local version of Nixpkgs to work with:
- Fork the Nixpkgs repository.
- Clone the forked repository into a local
nixpkgs
directory. - Configure the upstream Nixpkgs repository.
-
Select the appropriate base branch for the change, as described here. If in doubt, use
master
. This can be changed later by rebasing. -
Create a new Git branch, ideally such that:
- The name of the branch hints at your change, e.g.
update-hello
. - The branch contains the most recent base branch.
We'll assume the base branch
master
here.# Make sure you have the latest changes from upstream Nixpkgs git fetch upstream # Create and switch to a new branch, based on the base branch in Nixpkgs git switch --create update-hello upstream/master
To avoid potentially having to download and build many derivations, you can base on a specific Git commit instead:
- The commit of the latest
nixpkgs-unstable
channel, available here. - The commit of a local Nixpkgs downloaded using nix-channel, available using
nix-instantiate --eval --expr '(import <nixpkgs/lib>).trivial.revisionWithDefault null'
- If you're using NixOS, the commit of your NixOS installation, available with
nixos-version --revision
.
You can use this commit instead of
upstream/master
in the above command:# Here, b9c03fbb is an example commit from nixpkgs-unstable git switch --create update-hello b9c03fbb
- The name of the branch hints at your change, e.g.
-
Make your changes in the local Nixpkgs repository and:
- Adhere to both the general code conventions, and the relevant specific code conventions.
- Test the changes.
- If necessary, document the changes.
See the overview section for more specific information.
-
Commit your changes using
git commit
. Make sure to adhere to the commit conventions.Repeat the steps 3-4 as many times as necessary. Advance to the next step once all the commits make sense together. You can view your commits with
git log
. -
Push your commits to your fork of Nixpkgs:
git push --set-upstream origin HEAD
The above command will output a link to directly do the next step:
remote: Create a pull request for 'update-hello' on GitHub by visiting: remote: https://github.com/myUser/nixpkgs/pull/new/update-hello
-
Create a pull request from the new branch in your Nixpkgs fork to the upstream Nixpkgs repository. Use the branch from step 1 as the PR's base branch. Go through the pull request template.
-
Respond to review comments and potentially to CI failures and merge conflicts by updating the PR. Always keep it in a mergeable state.
The non-technical side of this process is covered in I opened a PR, how do I get it merged?.
The ofborg CI system will perform checks to ensure code quality. You can see the results at the bottom of the PR. See the ofborg Readme for more details.
-
To add new commits, repeat steps 3-4 and push the result:
git push
-
To change existing commits, rewrite the Git history. Useful Git commands for this are
git commit --patch --amend
andgit rebase --interactive
. With a rewritten history you need to force-push the commits:git push --force-with-lease
-
If there are merge conflicts, you will have to rebase the branch onto the current base branch. Sometimes this can be done on GitHub directly. To rebase locally:
git fetch upstream git rebase upstream/master git push --force-with-lease
Use the base branch from step 1 instead of
upstream/master
. -
If you need to change the base branch, rebase.
-
-
If your PR is merged and acceptable for releases, you may backport it.
Pull request template
The pull request template helps to determine which steps have been taken so far. Details not covered by the title and links to existing related issues should go at the top.
When a PR is created, it will be pre-populated with some checkboxes.
Tested using sandboxing
When sandbox builds are enabled, Nix will set up an isolated environment for each build process.
It is used to remove further hidden dependencies set by the build environment, to improve reproducibility.
This includes access to the network during the build outside of fetch*
functions and files outside the Nix store.
Depending on the operating system, access to other resources is blocked as well; see sandbox in the Nix manual for details.
Please test builds with sandboxing enabled, because it is also used in Hydra.
If you are on Linux, sandboxing is enabled by default. On other platforms, sandboxing is disabled by default due to a small performance hit on each build.
Please enable sandboxing before building the package by adding the following to /etc/nix/nix.conf
:
sandbox = true
Built on platform(s)
Many Nix packages are designed to run on multiple platforms. As such, it’s important to let the maintainer know which platforms you have tested on. It’s not always practical to test all platforms, and it’s not required for a pull request to be merged. Only check the platforms you tested the build on in this section.
Tested via one or more NixOS test(s) if existing and applicable for the change (look inside nixos/tests)
Packages with automated tests are likely merged quicker, because they don’t require as much manual testing. If there are existing tests for the package, they should be run. NixOS tests can only be run on linux. For more details on writing and running tests, see the section in the NixOS manual.
Tested compilation of all pkgs that depend on this change using nixpkgs-review
If you are modifying a package, you can use nixpkgs-review
to make sure all packages that depend on the updated package still build.
It can work on uncommitted changes with the wip
option or on a specific pull request.
Review changes from pull request number 12345:
nix-shell -p nixpkgs-review --run "nixpkgs-review pr 12345"
Alternatively, with flakes (and analogously for the other commands below):
nix run nixpkgs#nixpkgs-review -- pr 12345
Review uncommitted changes:
nix-shell -p nixpkgs-review --run "nixpkgs-review wip"
Review changes from the last commit:
nix-shell -p nixpkgs-review --run "nixpkgs-review rev HEAD"
Tested execution of all binary files (usually in ./result/bin/
)
It's important to test a modified package's executables.
Look into ./result/bin
and run all files in there, or at a minimum, the main executable.
For example, if you make a change to texlive
, you probably would only check the binaries associated with the change you made, rather than testing all of them.
Meets Nixpkgs contribution standards
The last checkbox is about whether it fits the guidelines in this CONTRIBUTING.md
file.
This document details our standards for commit messages, reviews, licensing of contributions, etc...
Everyone should read and understand these standards before submitting a pull request.
Rebasing between branches (i.e. from master to staging)
Sometimes, changes must be rebased between branches. One example is, if the number of rebuilds caused is too large for the original target branch.
In the following example, the current feature
branch is based on master
, and we rebase it to have the PR target staging
.
We rebase on the merge base between master
and staging
to avoid too many local rebuilds.
# Rebase your commits onto the common merge base
git rebase --onto upstream/staging... upstream/master
# Force push your changes
git push origin feature --force-with-lease
The syntax upstream/staging...
is equivalent to upstream/staging...HEAD
and stands for the merge base between upstream/staging
and HEAD
(hence between upstream/staging
and upstream/master
).
Then use the Edit button in the upper right corner of the GitHub PR, and switch the base branch from master
to staging
.
After the PR has been retargeted, a final rebase onto the target branch might be needed to resolve merge conflicts.
# Rebase onto target branch
git rebase upstream/staging
# Review and fixup possible conflicts
git status
# Force push your changes
git push origin feature --force-with-lease
How to backport pull requests
Once a PR has been merged, a backport to the corresponding release-YY.MM
branch can be created.
Automatically backporting changes
Note
You have to be a Nixpkgs maintainer to automatically create a backport pull request.
Add the backport release-YY.MM
label to the PR on the master
branch.
This will cause a GitHub Action to open a new PR to the release-YY.MM
branch a few minutes later.
This can be done on both open or already merged pull requests.
Manually backporting changes
To manually create a backport, follow the standard pull request process, but:
- Use
release-YY.MM
for the base branch, both for the local branch and the pull request.
Warning
Do not use the
nixos-YY.MM
branch. It points to the latest tested release channel commit.
- Instead of manually making and committing the changes, use
git cherry-pick -x
for each commit. Usegit cherry-pick -x <commit>
when the reason is obvious, for example for minor version bumps and fixes. Otherwise, usegit cherry-pick -xe <commit>
to add a reason for the backport. Here is an example.
Warning
Ensure the commits exist on the master branch. In the case of squashed or rebased merges, the commit hash will change and the new commits can be found in the merge message at the bottom of the master pull request.
- In the pull request description, link to the original pull request to
master
. The pull request title should include[YY.MM]
matching the release you're backporting to.
How to review pull requests
The Nixpkgs project receives a high number of pull requests. Anyone may review and approve PRs and it is an important contribution to the project.
The high change rate makes any PR that remains open for too long subject to merge conflicts. To avoid extra work, reviewing PRs timely and being responsive is key. GitHub provides sort filters to see the most recently updated pull requests. We highly encourage looking at this list of ready to merge, unreviewed pull requests.
Controversial changes can lead to controversial opinions, but it is important to respect every community member and their work. Always be nice and polite.
GitHub provides reactions for quick feedback to pull requests or comments. The thumb-down reaction should be used with care and, if possible, accompanied with explanation for the submitter to improve their contribution.
When doing a review:
- Aim to drive the proposal to a timely conclusion.
- Focus on the proposed changes and keep the scope narrow.
- Help the contributor prioritise their efforts towards getting their change merged.
If you find anything related that could be improved but is not immediately required for acceptance, consider:
- Implementing the changes yourself in a follow-up pull request,
- Tracking your idea in an issue,
- Offering to review a follow-up pull request,
- Making concrete suggestions in the same pull request.
For example, follow-up changes could involve refactoring code in the affected files.
But please remember not to make such additional considerations a blocker, and communicate that to the contributor, for example by following the conventional comments pattern. If the related change is essential for the contribution at hand, make clear why you think it is important to address that first.
Pull request reviews should include a list of what has been reviewed in a comment, so other reviewers and mergers can know the state of the review.
All the review templates provided are generic examples. Their usage is optional and the reviewer is free to adapt them.
To get more information about how to review specific parts of Nixpkgs, refer to the documents linked to in the overview section.
If a pull request contains documentation changes that might require feedback from the documentation team, ping @NixOS/documentation-team on the pull request.
If you have enough knowledge and experience in a topic and would like to be a long-term reviewer for related submissions, please contact the current reviewers for that topic. The main reviewers for a topic can be hard to find as there is no list, but checking past pull requests or git-blaming the code can give some hints.
How to merge pull requests yourself
You can invoke the nixpkgs-merge-bot by commenting @NixOS/nixpkgs-merge-bot merge
.
The bot will verify the following conditions, refusing to merge otherwise:
- the PR author should be @r-ryantm or a Nixpkgs committer;
- the invoker should be among the package maintainers;
- the package should reside in
pkgs/by-name
.
Further, nixpkgs-merge-bot will ensure all CI checks and the ofborg builds for Linux have successfully completed before merging the pull request. Should the checks still be underway, the bot will wait for them to finish before attempting the merge again.
For other pull requests, please see I opened a PR, how do I get it merged?.
In case the PR is stuck waiting for the author to apply a trivial change and the author allowed members to modify the PR, consider applying it yourself. You should pay extra attention to make sure the addition doesn't go against the idea of the original PR and would not be opposed by the author.
Please see the discussion in GitHub nixpkgs issue #321665 for information on how to proceed to be granted this level of access.
As a maintainer, when you leave the Nix community, please create an issue or post on Discourse with references to the packages and modules you maintained, so they can be taken over by other contributors.
Flow of merged pull requests
After a pull request is merged, it eventually makes it to Hydra. Hydra regularly evaluates and builds Nixpkgs, updating the official channels when their jobs succeed. See Nix Channel Status for the current channel states.
Our primary development branches and their related channels are:
master
: The main branch, used for the unstable channelsnixos-unstable
,nixos-unstable-small
andnixpkgs-unstable
.release-YY.MM
: The release branches, used for the stable channelsnixos-YY.MM
,nixos-YY.MM-small
andnixpkgs-YY.MM-darwin
.
When a channel is updated, its corresponding branch is also updated to the same commit.
Example: The nixpkgs-unstable
branch corresponds to the commit from the nixpkgs-unstable
channel.
Nixpkgs is tied to the NixOS release process, which is documented in the NixOS Release Wiki.
See this section to know when to use the release branches.
Staging
The staging workflow exists to batch Hydra builds of many packages together. It is coordinated in the Staging room on Matrix.
It works by directing commits that cause mass rebuilds to a separate staging
branch that isn't directly built by Hydra.
Regularly, the staging
branch is manually merged into a staging-next
branch to be built by Hydra using the nixpkgs:staging-next
jobset.
The staging-next
branch should then only receive changes that fix Hydra builds; for anything else, ask the Staging room first.
Once it is verified that there are no major regressions, staging-next
is merged into master
using a pull request.
This is done manually to ensure it's a good use of Hydra's computing resources.
Since staging-next
is separate from staging
, you may merge changes into staging
at any time.
In order for the staging
and staging-next
branches to be up-to-date with the latest commits on master
, there are regular automated merges from master
into staging-next
, and from staging-next
into staging
.
This is implemented using GitHub workflows here and here.
Note
Changes must be well tested before being merged into any branch. Hydra builds should not be used as a testing platform.
Here is a Git history diagram showing the flow of commits between the three branches:
%%{init: {
'theme': 'base',
'themeVariables': {
'gitInv0': '#ff0000',
'gitInv1': '#ff0000',
'git2': '#ff4444',
'commitLabelFontSize': '15px'
},
'gitGraph': {
'showCommitLabel':true,
'mainBranchName': 'master',
'rotateCommitLabel': true
}
} }%%
gitGraph
commit id:" "
branch staging
commit id:" "
branch staging-next
merge master id:"automatic"
checkout staging
merge staging-next id:"automatic "
checkout staging-next
merge staging type:HIGHLIGHT id:"manual"
commit id:"fixup"
checkout master
checkout staging
checkout master
commit id:" "
checkout staging-next
merge master id:"automatic "
checkout staging
merge staging-next id:"automatic "
checkout staging-next
commit id:"fixup "
checkout master
merge staging-next type:HIGHLIGHT id:"manual (PR)"
Here's an overview of the different branches:
branch | master |
staging-next |
staging |
---|---|---|---|
Used for development | ✔️ | ❌ | ✔️ |
Built by Hydra | ✔️ | ✔️ | ❌ |
Mass rebuilds | ❌ | ⚠️ Only to fix Hydra builds | ✔️ |
Critical security fixes | ✔️ for non-mass-rebuilds | ✔️ for mass-rebuilds | ❌ |
Automatically merged into | staging-next |
staging |
- |
Manually merged into | - | master |
staging-next |
The staging workflow is used for all stable branches with corresponding names:
master
/release-YY.MM
staging
/staging-YY.MM
staging-next
/staging-next-YY.MM
Conventions
Branch conventions
Most changes should go to master
, but sometimes other branches should be used instead.
Use the following decision process to figure out the right branch:
Is the change acceptable for releases and do you wish to have the change in the release?
- No: Use the
master
branch, do not backport the pull request. - Yes: Can the change be implemented the same way on the
master
and release branches? For example, a package's major version might differ between themaster
and release branches, such that separate security patches are required.- Yes: Use the
master
branch and backport the pull request. - No: Create separate pull requests to the
master
andrelease-YY.MM
branches.
- Yes: Use the
If the change causes a mass rebuild, use the staging branch instead:
- Mass rebuilds to
master
should go tostaging
instead. - Mass rebuilds to
release-YY.MM
should go tostaging-YY.MM
instead.
See this section for how such changes propagate between the branches.
Changes acceptable for releases
Only changes to supported releases may be accepted.
The oldest supported release (YYMM
) can be found using
nix-instantiate --eval -A lib.trivial.oldestSupportedRelease
The release branches should generally only receive backwards-compatible changes, both for the Nix expressions and derivations. Here are some examples of changes that are okay to backport:
- ✔️ New packages, modules and functions
- ✔️ Security fixes
- ✔️ Package version updates
- ✔️ Patch versions with fixes
- ✔️ Minor versions with new functionality, but no breaking changes
In addition, major package version updates with breaking changes are also acceptable for:
- ✔️ Services that would fail without up-to-date client software, such as
spotify
,steam
, anddiscord
- ✔️ Security critical applications, such as
firefox
andchromium
Changes causing mass rebuilds
Which changes cause mass rebuilds is not formally defined.
In order to help the decision, CI automatically assigns rebuild
labels to pull requests based on the number of packages they cause rebuilds for.
As a rule of thumb, if the number of rebuilds is over 500, it can be considered a mass rebuild.
To get a sense for what changes are considered mass rebuilds, see previously merged pull requests to the staging branches.
Commit conventions
-
Create one commit for each logical unit.
-
If you have commits
pkg-name: oh, forgot to insert whitespace
: squash commits in this case. Usegit rebase -i
. See Squashing Commits for additional information. -
For consistency, there should not be a period at the end of the commit message's summary line (the first line of the commit message).
-
When adding yourself to
maintainer-list.nix
, make a separate commit with the messagemaintainers: add <handle>
. Add the commit before those making changes to the package or module. See Nixpkgs Maintainers for details. -
Make sure you read about any commit conventions specific to the area you're touching. See:
- Commit conventions for changes to
doc
, the Nixpkgs manual. - Commit conventions for changes to
lib
. - Commit conventions for changes to
nixos
. - Commit conventions for changes to
pkgs
.
- Commit conventions for changes to
Writing good commit messages
It's important to include relevant information in the commit message, so others can later understand why a change was made. While this potentially can be understood by reading code, PR discussion or upstream changes, doing so often requires a lot of work.
Simple package version updates need to include the attribute name, old and new versions, as well as a reference to the release notes or changelog. Package upgrades with more extensive changes require more verbose commit messages.
Pull requests should not be squash-merged, as this discards information including detail from commit messages, GPG signatures, and authorship. Many pull requests don't make sense as a single commit anyway.
Code conventions
Release notes
If you removed packages or made some major NixOS changes, write about it in the next release notes in nixos/doc/manual/release-notes
.
File naming and organisation
Names of files and directories should be in lowercase, with dashes between words — kebab case, not camel case.
For instance, it should be all-packages.nix
, not allPackages.nix
or AllPackages.nix
.
Formatting
CI enforces all Nix files to be formatted using the official Nix formatter.
You can ensure this locally using either of these commands:
nix-shell --run treefmt
nix develop --command treefmt
nix fmt
If you're starting your editor in nix-shell
or nix develop
, you can also set it up to automatically run treefmt
on save.
If you have any problems with formatting, please ping the formatting team via @NixOS/nix-formatting.
Syntax
-
Set up editorconfig for your editor, such that the settings are automatically applied.
-
Use
lowerCamelCase
for variable names, notUpperCamelCase
. Note, this rule does not apply to package attribute names, which instead follow the rules in package naming. -
Functions should list their expected arguments as precisely as possible. That is, write
{ stdenv, fetchurl, perl, }: <...>
instead of
args: with args; <...>
or
{ stdenv, fetchurl, perl, ... }: <...>
For functions that are truly generic in the number of arguments, but have some required arguments, you should write them using an
@
-pattern:{ stdenv, doCoverageAnalysis ? false, ... }@args: stdenv.mkDerivation (args // { foo = if doCoverageAnalysis then "bla" else ""; })
instead of
args: args.stdenv.mkDerivation ( args // { foo = if args ? doCoverageAnalysis && args.doCoverageAnalysis then "bla" else ""; } )
-
Unnecessary string conversions should be avoided. Do
{ rev = version; }
instead of
{ rev = "${version}"; }
-
Building lists conditionally should be done with
lib.optional(s)
instead of usingif cond then [ ... ] else null
orif cond then [ ... ] else [ ]
.{ buildInputs = lib.optional stdenv.hostPlatform.isDarwin iconv; }
instead of
{ buildInputs = if stdenv.hostPlatform.isDarwin then [ iconv ] else null; }
As an exception, an explicit conditional expression with null can be used when fixing a important bug without triggering a mass rebuild. If this is done a follow up pull request should be created to change the code to
lib.optional(s)
.
Practical contributing advice
To contribute effectively and efficiently, you need to be aware of how the process generally works. This section aims to document the process as we live it in Nixpkgs to set the right expectations and give practical tips on how to work with it.
I opened a PR, how do I get it merged?
In order for your PR to be merged, a committer needs to review and merge it. Because committers are mostly independent, unpaid volunteers, this can take time. It is entirely normal for your PR to sit around without any feedback for days, weeks or sometimes even months. We strive to avoid this, but the reality is that it happens frequently. Even when you get feedback, follow-ups may take just as long. Don't be intimidated and kindly ask for feedback again every so often. If your change is good, it will eventually be merged.
You can often speed up the process by understanding the committer's perspective and preparing your PR with reviewing in mind.
The committer's perspective
PRs have varying quality and even the best people make mistakes. Committers need to assess whether a PR's changes are good or not. To merge, at least one committer has to be confident about its quality.
Committers typically assess three aspects:
- Whether the change's intention is necessary and desirable.
- Whether the code quality of your changes is good.
- Whether the produced artifacts are good.
To get your PR merged quickly and smoothly, you should help convince committers in these aspects.
How to help committers assess your PR
It's best to explain why you've made your change, because guessing the intention is not always possible. This does not apply to trivial changes like version updates, because the intention is obvious. For more nuanced changes or even major version upgrades, it helps if you explain the background behind your change. For example, if you're adding a package, explain what it is and why it should be in Nixpkgs. This goes hand in hand with Writing good commit messages.
To show the quality of your code, you should focus on making it reviewable. First, take a look at your code changes yourself and try to put yourself into the shoes of someone who didn't just write that code. Would you immediately know what the code does or why it is needed by glancing at it? If not, reviewers will notice this and will ask you to clarify the code by refactoring it and/or adding code comments. Doing this preemptively can save a lot of time. Doing multiple unrelated changes in a single commit can become hard to review quickly. Thus, consider multiple atomic commits to tell the story of your change. There is a balance to strike however: over-fragmentation causes friction.
The artifacts are the hardest to assess because PRs touch all sorts of components: applications, libraries, NixOS modules, editor plugins and many other things. Any individual committer can only really assess components that they themselves know how to use. Yet, they must still be convinced somehow. There isn't a good generic solution to this but there are some ways to ease it:
-
Provide smoke tests that can be run without much research or setup.
Committers usually don't have the time or interest to learn how your component works and how they could test its functionality. Try to provide a quick guide on how to use it in a meaningful way or a ready-made command that demonstrates that it works as expected. The committer can use this to convince themselves that your change is good. If it can be automated, you could even turn this into an automated NixOS test which reviewers could simply run.
-
Invite other users of the component to try it out and report their findings.
Seeing other users testing the changes and having it work for them can convince committers, too.
-
Describe what you have done to test your PR.
It also helps, if you can additionally show that you have done sufficient quality assurance on your changes.
-
Become a maintainer of the component.
Listed maintainers generally receive more trust when it comes to changes to their maintained components.
Even if you adhere to all of these recommendations, it is still quite possible for your PR to be forgotten or abandoned by any given committer. Please remain mindful of them doing this work on their own volition and unpaid in their free time and therefore owing you nothing. Causing a stink in such a situation is a surefire way to get any other potential committer to not want to look at your PR either. Ask them nicely whether they still intend to review your PR and find yourself another committer to look at your PR if not.
How can I get a committer to look at my PR?
- Improve skimmability: use a simple descriptive PR title outlining what is done and why. Details go in commit messages.
- Improve discoverability: apply all relevant labels, tick all relevant PR body checkboxes.
- Wait. Reviewers frequently browse open PRs and may happen to run across yours and take a look.
- Get non-committers to review/approve. Many committers filter open PRs for low-hanging fruit that have already been reviewed.
- @-mention someone and ask them nicely.
- Post in one of the channels made for this purpose if there has been no activity for at least one week:
- The current "PRs ready for review" or "PRs already reviewed" threads in the NixOS Discourse.
- The Nixpkgs Review Requests Matrix room.
- Similar threads/rooms in unofficial NixOS spaces, such as Discord.
CI failed or got stuck on my PR, what do I do?
First, ensure that the failure is actually related to your change. Sometimes, the CI system simply has a hiccup or the check was broken by someone else before. Read through the error message; it's usually quite easy to tell whether it is caused by changes to the component you touched. If it is indeed caused by your change, try to fix it. Don't be afraid of asking for advice if you're uncertain how to do that, others might have fixed such issues already and can help you out. Your PR will not be merged while CI is still failing.
ofborg builds can often get stuck, particularly in PRs targeting staging
and in builders for the Darwin platform.
Reviewers will know how to handle them or when to ignore them.
Don't worry about it.
However, if there is a build failure and it was caused by your change, you need to investigate it.
If ofborg reveals the build to be broken on a platform that you don't have access to, consider setting your package's meta.broken
, meta.badPlatforms
or meta.platforms
accordingly.
When in any doubt, please ask via comments or through one of the help channels.
I received a review, how do I get it over the finish line?
Most likely, a reviewer wants you to change a few things or requires further input.
A reviewer may have taken a look at the code and it looked good to them ("Diff LGTM"), but they still need to be convinced of the artifact's quality. They might also be waiting on input from other users or maintainers on whether the intention and direction of your PR makes sense. If you know of people who could help clarify any of this, please bring the PR to their attention. The current state of the PR is frequently not clearly communicated, so please don't hesitate to ask about it if it's unclear to you.
It's also possible for the reviewer to not be convinced that your PR is necessary or that the method you've chosen is the right one.
Please explain your intentions and reasoning to the committer in such a case. There may be constraints you had to work with which they're not aware of or qualities of your approach that they didn't immediately notice. If these weren't clear to the reviewer, that's a good sign you should explain them in your commit message or code comments!
There are some further pitfalls and realities to be aware of:
Aim to reduce cycles
Be prepared for it to take a while for the reviewer to get back to you after you respond. This is simply the reality of projects at the scale of Nixpkgs. As such, make sure to respond to all feedback at once. It wastes everyone's time to wait for a couple of days just to have the reviewer need to remind you to address something they asked for.
A reviewer requested a bunch of insubstantial changes
The people involved in Nixpkgs care about code quality. Once in Nixpkgs, the code needs to be maintained for many years to come. Therefore, you will likely be asked to do something different or adhere to a standard.
Sometimes however, they also care a bit too much and may ask you to adhere to a personal preference of theirs. It's not always easy to tell whether or not the requested changes must be addressed. Sometimes, another reviewer may even have a conflicting opinion on some points.
It is convention to mark review comments that are not required to merge as nitpicks, but this is not always followed. As the author, you should still take a look at these, as they will often reveal best practices and unwritten rules. Those usually have good reasons behind them and you may want to pick them up as well.
Please keep in mind that reviewers always mean well. Their intent is not to denounce your code, they want your code to be as good as it can be. Through their experience, they may also take notice of a seemingly insignificant issue that has caused problems before.
Sometimes however, they can also get a bit carried away and become too perfectionistic. If you feel some of the requests are unreasonable, out of scope, or merely a matter of personal preference, try to nicely ask the reviewers whether these requests are critical to the PR's success.
While we do have a set of official standards for the Nix community, we don't have standards for everything and there are often multiple valid ways to achieve the same goal. Unless there are standards forbidding the patterns used in your code or there are serious technical, maintainability or readability issues with your code, you can disregard these requests. Please communicate this clearly though; a simple "I prefer it this way and see no major issue maintaining it" can save a lot of arguing.
If you are unsure about some change requests, please ask reviewers why they requested them. This will usually reveal how important they deem it to be and will help educate you about standards, best practices, unwritten rules as well as preferences people have and why.
Some committers have stronger opinions on some things and may not want to merge your PR if you don't follow their requests. It is totally fine to get yourself a second or third opinion in such a case.
Committers work on a push-basis
It's possible for you to get a review but nothing happens afterwards, even if you respond to review comments. A committer not following up on your PR does not necessarily mean they're disinterested, they may have simply had other circumstances preventing them from doing so.
Committers typically handle many PRs at the same time and it is not realistic for them to keep up with all of them immediately. If someone approved and didn't merge a few days later, they most likely just forgot.
Please see it as your responsibility to actively remind reviewers of your open PRs.
The easiest way to do so is to notify them via GitHub. Github notifies people involved, whenever you add a comment or push to your PR or re-request their review. Doing any of that will get their attention again. Everyone deserves proper attention, and yes, that includes you! However, please be mindful that committers can sadly not always give everyone the attention they deserve.
It may very well be the case that you have to do this every time you need the committer to follow up upon your PR. Again, this is a community project so please be mindful of people's circumstances here; be nice when requesting reviews again.
It may also be the case that the committer has lost interest or isn't familiar enough with the component you're touching to be comfortable to merge. They will likely not immediately state that fact, so please ask for clarification and don't hesitate to find yourself another committer to take a look.
Nothing helped
If you followed these guidelines but still got no results or if you feel that you have been wronged, please explicitly reach out to the greater community.
The NixOS Discourse is a great place to do this, as it has historically been the asynchronous medium with the greatest concentration of committers and other people who are involved in Nixpkgs. There is a dedicated discourse thread PRs in distress where you can link your PR, if everything else fails. The Nixpkgs / NixOS contributions Matrix channel is the best synchronous channel with the same qualities.
Please reserve these for cases where you've made a serious effort in trying to get the attention of multiple active committers and provided realistic means for them to assess your PR's quality. As mentioned previously, it is unfortunately perfectly normal for a PR to sit around for weeks.
Please don't blow up situations where progress is happening but is merely not going fast enough for your tastes. Honking in a traffic jam will not make you go any faster.