-
-
Notifications
You must be signed in to change notification settings - Fork 14.8k
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
[RFC 140 2b] pkgs/by-name
: Automated migration
#211832
base: master
Are you sure you want to change the base?
Conversation
cfc6b31
to
550c1db
Compare
550c1db
to
fef9e79
Compare
|
|
NixOS#211832 broke the workflows for all PR's temporarily because it runs into GitHub API limits. This change to the workflow files just makes sure that the problematic workflows don't run for that specific PR.
a06330e
to
35c73e4
Compare
Makes the build independency of the default.nix and update.sh file by explicitly specifying the files that are needed in the result This allows changing those files without causing a rebuild
This way, changing the Nix file won't change the derivation
Tested with nix-env -qaf . The res -> super changes are necessary because res points to the result of the current overlay, but some of the packages were moved to the previous overlay, which can be accessed with super. This is a fundamental problem to be fixed, see NixOS#55061 and related issues The schleuder change is necessary because the ./default.nix file referenced ./., but there's also another package in ./bin. The tool couldn't move the gemfiles in ./. because The schleuder change is necessary because the tool isn't smart enough and this is a special case of the default.nix reading gemfiles from a ./. reference and there being both schleuder in pkgs/tools/security/schleuder and schleuder-cli in pkgs/tools/security/schleuder/cli
35c73e4
to
5727203
Compare
This pull request has been mentioned on NixOS Discourse. There might be relevant details there: https://discourse.nixos.org/t/2022-01-23-nixpkgs-architecture-team-meeting-26/24892/1 |
This pull request has been mentioned on NixOS Discourse. There might be relevant details there: https://discourse.nixos.org/t/2023-09-05-nixpkgs-architecture-team-meeting-43/32635/1 |
I'm planning to implement this in a series of steps: #258650 |
@@ -17,7 +17,7 @@ jobs: | |||
contents: write # for korthout/backport-action to create branch | |||
pull-requests: write # for korthout/backport-action to create PR to backport | |||
name: Backport Pull Request | |||
if: github.repository_owner == 'NixOS' && github.event.pull_request.merged == true && (github.event_name != 'labeled' || startsWith('backport', github.event.label.name)) |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I think this should be changed back after this PR has been merged, otherwise this workflow might run in every contributors repo as well, right?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Oh yeah I only used this for testing. I'll have to completely update this PR once everything is ready.
pkgs/by-name
: Automated migration
This pull request has been mentioned on NixOS Discourse. There might be relevant details there: https://discourse.nixos.org/t/ci-will-soon-enforce-pkgs-by-name-for-new-packages/38098/1 |
FYI the Nixpkgs Architecture Team link is incorrect or dead. |
Note that @Aleksanaa did a large part of the automated migration in #354531, thank you! There's still more that can be migrated manually, so I'll leave this PR open for now until I or somebody else can do it |
Context
This is the second part of the implementation of the accepted RFC 140, the automated migration. The first part is already done and can be found here: #237439.
The plan for the second part can be found here: #258650
This is hopefully only the first of many quality-of-life improvements to Nixpkgs by the Nixpkgs Architecture Team.
This PR is currently an old draft of the implementation, using a slightly hacky tool to do it. Will be updated after part 1 is done.
TODO