nix3-upgrade-nix: allow manually specifying new nix
This allows manually specifying a store path for the new Nix that gets linked into Nix's profile. Change-Id: Ib71711ffb466febf4a6892e3fdbda644e053770d
This commit is contained in:
parent
aae12f5848
commit
ee5a1b5a4c
2 changed files with 23 additions and 0 deletions
6
doc/manual/rl-next/upgrade-nix-override.md
Normal file
6
doc/manual/rl-next/upgrade-nix-override.md
Normal file
|
@ -0,0 +1,6 @@
|
|||
---
|
||||
synopsis: add --store-path argument to `nix upgrade-nix`, to manually specify the Nix to upgrade to
|
||||
cls: 953
|
||||
---
|
||||
|
||||
`nix upgrade-nix` by default downloads a manifest to find the new Nix version to upgrade to, but now you can specify `--store-path` to upgrade Nix to an arbitrary version from the Nix store.
|
|
@ -21,6 +21,8 @@ struct CmdUpgradeNix : MixDryRun, EvalCommand
|
|||
Path profileDir;
|
||||
std::string storePathsUrl = "https://github.com/NixOS/nixpkgs/raw/master/nixos/modules/installer/tools/nix-fallback-paths.nix";
|
||||
|
||||
std::optional<Path> overrideStorePath;
|
||||
|
||||
CmdUpgradeNix()
|
||||
{
|
||||
addFlag({
|
||||
|
@ -31,6 +33,13 @@ struct CmdUpgradeNix : MixDryRun, EvalCommand
|
|||
.handler = {&profileDir}
|
||||
});
|
||||
|
||||
addFlag({
|
||||
.longName = "store-path",
|
||||
.description = "A specific store path to upgrade Nix to",
|
||||
.labels = {"store-path"},
|
||||
.handler = {&overrideStorePath},
|
||||
});
|
||||
|
||||
addFlag({
|
||||
.longName = "nix-store-paths-url",
|
||||
.description = "The URL of the file that contains the store paths of the latest Nix release.",
|
||||
|
@ -246,6 +255,14 @@ struct CmdUpgradeNix : MixDryRun, EvalCommand
|
|||
/* Return the store path of the latest stable Nix. */
|
||||
StorePath getLatestNix(ref<Store> store)
|
||||
{
|
||||
if (this->overrideStorePath) {
|
||||
printTalkative(
|
||||
"skipping Nix version query and using '%s' as latest Nix",
|
||||
*this->overrideStorePath
|
||||
);
|
||||
return store->parseStorePath(*this->overrideStorePath);
|
||||
}
|
||||
|
||||
Activity act(*logger, lvlInfo, actUnknown, "querying latest Nix version");
|
||||
|
||||
// FIXME: use nixos.org?
|
||||
|
|
Loading…
Reference in a new issue