2024-01-18 16:21:00 +00:00
|
|
|
{ callPackage
|
2024-03-30 18:55:47 +00:00
|
|
|
, substitute
|
2021-01-16 12:17:21 +00:00
|
|
|
, runtimeShell
|
|
|
|
, coreutils
|
|
|
|
, gnused
|
|
|
|
, gnugrep
|
2023-02-12 16:31:09 +00:00
|
|
|
, jq
|
|
|
|
, util-linux
|
2021-01-16 12:17:21 +00:00
|
|
|
, nix
|
|
|
|
, lib
|
2022-03-08 17:01:40 +00:00
|
|
|
, nixosTests
|
2023-08-12 09:52:46 +00:00
|
|
|
, installShellFiles
|
2021-01-16 12:17:21 +00:00
|
|
|
}:
|
2021-01-15 19:03:07 +00:00
|
|
|
let
|
|
|
|
fallback = import ./../../../../nixos/modules/installer/tools/nix-fallback-paths.nix;
|
2021-01-16 12:17:21 +00:00
|
|
|
in
|
2024-03-30 18:55:47 +00:00
|
|
|
substitute {
|
2021-01-15 19:03:07 +00:00
|
|
|
name = "nixos-rebuild";
|
|
|
|
src = ./nixos-rebuild.sh;
|
|
|
|
dir = "bin";
|
|
|
|
isExecutable = true;
|
2024-03-30 18:55:47 +00:00
|
|
|
|
|
|
|
substitutions = [
|
|
|
|
"--subst-var-by" "runtimeShell" runtimeShell
|
|
|
|
"--subst-var-by" "nix" nix
|
|
|
|
"--subst-var-by" "nix_x86_64_linux" fallback.x86_64-linux
|
|
|
|
"--subst-var-by" "nix_i686_linux" fallback.i686-linux
|
|
|
|
"--subst-var-by" "nix_aarch64_linux" fallback.aarch64-linux
|
|
|
|
"--subst-var-by" "path" (lib.makeBinPath [ coreutils gnused gnugrep jq util-linux ])
|
|
|
|
];
|
|
|
|
|
2023-08-12 09:52:46 +00:00
|
|
|
nativeBuildInputs = [
|
|
|
|
installShellFiles
|
|
|
|
];
|
2024-03-30 18:55:47 +00:00
|
|
|
|
2023-08-12 09:52:46 +00:00
|
|
|
postInstall = ''
|
|
|
|
installManPage ${./nixos-rebuild.8}
|
2023-10-22 06:42:18 +00:00
|
|
|
|
|
|
|
installShellCompletion \
|
|
|
|
--bash ${./_nixos-rebuild}
|
2023-08-12 09:52:46 +00:00
|
|
|
'';
|
2022-03-08 17:01:40 +00:00
|
|
|
|
|
|
|
# run some a simple installer tests to make sure nixos-rebuild still works for them
|
|
|
|
passthru.tests = {
|
2023-10-22 19:46:47 +00:00
|
|
|
install-bootloader = nixosTests.nixos-rebuild-install-bootloader;
|
2024-01-18 16:21:00 +00:00
|
|
|
repl = callPackage ./test/repl.nix {};
|
nixos: add --specialisation to nixos-rebuild
This commit fixes a papercut in nixos-rebuild where people wanting to
switch to a specialisation (or test one) were forced to manually figure
out the specialisation's path and run its activation script - since now,
there's a dedicated option to do just that.
This is a backwards-compatible change which doesn't affect the existing
behavior, which - to be fair - might still be considered sus by some
people, the painful scenario here being:
- you boot into specialisation `foo`,
- you run `nixos-rebuild switch`,
- whoops, you're no longer at specialisation `foo`, but you're rather
brought back to the base system.
(it's especially painful for cases where specialisation is used to load
extra drivers, e.g. Nvidia, since then launching `nixos-rebuild switch`,
while forgetting that you're inside a specialisation, can cause some
parts of your system to get accidentally unloaded.)
I've tried to mitigate that by improving specialisations so that they
create a dedicated file somewhere in `/run/current-system` containing
the specialisation's name (which `nixos-rebuild` could then use as the
default value for `--specialisation`), but I haven't been able to come
up with anything working (plus it would be a breaking change then).
Closes https://github.com/NixOS/nixpkgs/issues/174065
2022-12-23 20:23:36 +00:00
|
|
|
simple-installer = nixosTests.installer.simple;
|
|
|
|
specialisations = nixosTests.nixos-rebuild-specialisations;
|
2024-01-03 10:51:08 +00:00
|
|
|
target-host = nixosTests.nixos-rebuild-target-host;
|
2022-03-08 17:01:40 +00:00
|
|
|
};
|
2022-03-22 17:35:33 +00:00
|
|
|
|
|
|
|
meta = {
|
|
|
|
description = "Rebuild your NixOS configuration and switch to it, on local hosts and remote.";
|
|
|
|
homepage = "https://github.com/NixOS/nixpkgs/tree/master/pkgs/os-specific/linux/nixos-rebuild";
|
|
|
|
license = lib.licenses.mit;
|
|
|
|
maintainers = [ lib.maintainers.Profpatsch ];
|
|
|
|
mainProgram = "nixos-rebuild";
|
|
|
|
};
|
2021-01-15 19:03:07 +00:00
|
|
|
}
|