mirror of
https://github.com/nix-community/nix-on-droid.git
synced 2025-11-08 19:46:07 +01:00
Add assertion for needed upgrade to home-manager 20.03
This commit is contained in:
parent
55d33896fd
commit
b4c185c146
1 changed files with 40 additions and 19 deletions
|
|
@ -7,6 +7,9 @@ with lib;
|
||||||
let
|
let
|
||||||
cfg = config.home-manager;
|
cfg = config.home-manager;
|
||||||
|
|
||||||
|
tryEval = builtins.tryEval <home-manager/modules/modules.nix>;
|
||||||
|
assertion = tryEval.success && builtins.functionArgs (import tryEval.value) ? useNixpkgsModule;
|
||||||
|
|
||||||
extendedLib = import <home-manager/modules/lib/stdlib-extended.nix> pkgs.lib;
|
extendedLib = import <home-manager/modules/lib/stdlib-extended.nix> pkgs.lib;
|
||||||
|
|
||||||
hmModule = types.submoduleWith {
|
hmModule = types.submoduleWith {
|
||||||
|
|
@ -49,7 +52,10 @@ in
|
||||||
};
|
};
|
||||||
|
|
||||||
config = mkOption {
|
config = mkOption {
|
||||||
type = types.nullOr hmModule;
|
type =
|
||||||
|
if assertion
|
||||||
|
then types.nullOr hmModule
|
||||||
|
else types.unspecified;
|
||||||
default = null;
|
default = null;
|
||||||
description = "Home Manager configuration.";
|
description = "Home Manager configuration.";
|
||||||
};
|
};
|
||||||
|
|
@ -71,28 +77,43 @@ in
|
||||||
|
|
||||||
###### implementation
|
###### implementation
|
||||||
|
|
||||||
config = mkIf (cfg.config != null) {
|
config = mkIf (cfg.config != null) (mkMerge [
|
||||||
|
|
||||||
inherit (cfg.config) assertions warnings;
|
{
|
||||||
|
assertions = [
|
||||||
|
{
|
||||||
|
inherit assertion;
|
||||||
|
message = "You are currently using release-19.09 branch of home-manager, you need "
|
||||||
|
+ "to update to the release-20.03 channel.";
|
||||||
|
}
|
||||||
|
];
|
||||||
|
}
|
||||||
|
|
||||||
build = {
|
# hack to determine if cfg.config is a valid home-manager config
|
||||||
activationBefore = mkIf cfg.useUserPackages {
|
(mkIf (cfg.config ? home && cfg.config.home ? activationPackage) {
|
||||||
setPriorityHomeManagerPath = ''
|
|
||||||
if nix-env -q | grep '^home-manager-path$'; then
|
inherit (cfg.config) assertions warnings;
|
||||||
$DRY_RUN_CMD nix-env $VERBOSE_ARG --set-flag priority 120 home-manager-path
|
|
||||||
fi
|
build = {
|
||||||
'';
|
activationBefore = mkIf cfg.useUserPackages {
|
||||||
|
setPriorityHomeManagerPath = ''
|
||||||
|
if nix-env -q | grep '^home-manager-path$'; then
|
||||||
|
$DRY_RUN_CMD nix-env $VERBOSE_ARG --set-flag priority 120 home-manager-path
|
||||||
|
fi
|
||||||
|
'';
|
||||||
|
};
|
||||||
|
|
||||||
|
activationAfter.homeManager = concatStringsSep " " (
|
||||||
|
optional
|
||||||
|
(cfg.backupFileExtension != null)
|
||||||
|
"HOME_MANAGER_BACKUP_EXT='${cfg.backupFileExtension}'"
|
||||||
|
++ [ "${cfg.config.home.activationPackage}/activate" ]
|
||||||
|
);
|
||||||
};
|
};
|
||||||
|
|
||||||
activationAfter.homeManager = concatStringsSep " " (
|
environment.packages = mkIf cfg.useUserPackages cfg.config.home.packages;
|
||||||
optional
|
|
||||||
(cfg.backupFileExtension != null)
|
|
||||||
"HOME_MANAGER_BACKUP_EXT='${cfg.backupFileExtension}'"
|
|
||||||
++ [ "${cfg.config.home.activationPackage}/activate" ]
|
|
||||||
);
|
|
||||||
};
|
|
||||||
|
|
||||||
environment.packages = mkIf cfg.useUserPackages cfg.config.home.packages;
|
})
|
||||||
|
|
||||||
};
|
]);
|
||||||
}
|
}
|
||||||
|
|
|
||||||
Loading…
Add table
Add a link
Reference in a new issue