1
0
Fork 0
mirror of https://github.com/LnL7/nix-darwin.git synced 2024-12-14 11:57:34 +00:00
nix-darwin/modules/system/version.nix
Daiderd Jordan 58aa5bf185
nix: make nix.nixPath merge by default
Since named entries can be overridden now based on ordering now merging
is only a problem for removing one of the default search paths, in which
case a higher priority eg. mkForce can be used.

	{
	  nix.nixPath = [{ darwin-config = "/darwin.nix"; }];
	}

Will result in

	[ "darwin-config=/darwin.nix" "/nix/var/nix/profiles/per-user/root/channels" "$HOME/.nix-defexpr/channels" ]

Fixes #137
2019-05-01 12:42:31 +02:00

88 lines
3 KiB
Nix

{ options, config, lib, pkgs, ... }:
with lib;
let
cfg = config.system;
defaultStateVersion = options.system.stateVersion.default;
gitCommitId = lib.substring 0 7 (commitIdFromGitRepo gitRepo);
gitRepo = "${toString pkgs.path}/.git/";
releaseFile = "${toString pkgs.path}/.version";
revisionFile = "${toString pkgs.path}/.git-revision";
suffixFile = "${toString pkgs.path}/.version-suffix";
revision = if builtins.pathExists gitRepo then gitCommitId
else if builtins.pathExists revisionFile then fileContents revisionFile
else null;
versionSuffix = if builtins.pathExists gitRepo then ".git." + gitCommitId
else if builtins.pathExists suffixFile then fileContents suffixFile
else null;
in
{
options = {
system.stateVersion = mkOption {
type = types.int;
default = 4;
description = ''
Every once in a while, a new NixOS release may change
configuration defaults in a way incompatible with stateful
data. For instance, if the default version of PostgreSQL
changes, the new version will probably be unable to read your
existing databases. To prevent such breakage, you can set the
value of this option to the NixOS release with which you want
to be compatible. The effect is that NixOS will option
defaults corresponding to the specified release (such as using
an older version of PostgreSQL).
'';
};
system.darwinLabel = mkOption {
type = types.str;
default = cfg.nixpkgsVersion;
description = "Label to be used in the names of generated outputs.";
};
system.nixpkgsRelease = mkOption {
readOnly = true;
type = types.str;
default = fileContents releaseFile;
description = "The nixpkgs release (e.g. <literal>16.03</literal>).";
};
system.nixpkgsVersion = mkOption {
internal = true;
type = types.str;
description = "The full nixpkgs version (e.g. <literal>16.03.1160.f2d4ee1</literal>).";
};
system.nixpkgsVersionSuffix = mkOption {
internal = true;
type = types.str;
default = "pre-git";
description = "The nixpkgs version suffix (e.g. <literal>1160.f2d4ee1</literal>).";
};
system.nixpkgsRevision = mkOption {
internal = true;
type = types.str;
default = "master";
description = "The nixpkgs git revision from which this configuration was built.";
};
};
config = {
# These defaults are set here rather than up there so that
# changing them would not rebuild the manual
system.nixpkgsVersion = mkDefault (cfg.nixpkgsRelease + cfg.nixpkgsVersionSuffix);
system.nixpkgsRevision = mkIf (revision != null) (mkDefault revision);
system.nixpkgsVersionSuffix = mkIf (versionSuffix != null) (mkDefault versionSuffix);
assertions = [ { assertion = cfg.stateVersion <= defaultStateVersion; message = "system.stateVersion = ${toString cfg.stateVersion}; is not a valid value"; } ];
};
}