diff options
author | Graham Christensen <graham@grahamc.com> | 2018-10-05 10:48:42 -0400 |
---|---|---|
committer | Graham Christensen <graham@grahamc.com> | 2018-10-05 11:06:28 -0400 |
commit | 4312cfdbda1855088905a3d9959a4fac362fd051 (patch) | |
tree | fa5fcd7c6d2c18d583057b9ccf0f6f964565af2d | |
parent | 730dac1d7bccd4f4d540c780fc94133807757493 (diff) | |
download | nixlib-4312cfdbda1855088905a3d9959a4fac362fd051.tar nixlib-4312cfdbda1855088905a3d9959a4fac362fd051.tar.gz nixlib-4312cfdbda1855088905a3d9959a4fac362fd051.tar.bz2 nixlib-4312cfdbda1855088905a3d9959a4fac362fd051.tar.lz nixlib-4312cfdbda1855088905a3d9959a4fac362fd051.tar.xz nixlib-4312cfdbda1855088905a3d9959a4fac362fd051.tar.zst nixlib-4312cfdbda1855088905a3d9959a4fac362fd051.zip |
version.nix: extract revision-fetching function
-rw-r--r-- | lib/trivial.nix | 10 | ||||
-rw-r--r-- | nixos/modules/misc/version.nix | 5 |
2 files changed, 11 insertions, 4 deletions
diff --git a/lib/trivial.nix b/lib/trivial.nix index b1eea0bf1247..938df6ced476 100644 --- a/lib/trivial.nix +++ b/lib/trivial.nix @@ -105,6 +105,16 @@ rec { then lib.strings.fileContents suffixFile else "pre-git"; + # Attempt to get the revision nixpkgs is from + revisionWithDefault = default: + let + revisionFile = "${toString ./..}/.git-revision"; + gitRepo = "${toString ./..}/.git"; + in if lib.pathIsDirectory gitRepo + then lib.commitIdFromGitRepo gitRepo + else if lib.pathExists revisionFile then lib.fileContents revisionFile + else default; + nixpkgsVersion = builtins.trace "`lib.nixpkgsVersion` is deprecated, use `lib.version` instead!" version; # Whether we're being called by nix-shell. diff --git a/nixos/modules/misc/version.nix b/nixos/modules/misc/version.nix index c593adcdae6e..6d78b7c593f8 100644 --- a/nixos/modules/misc/version.nix +++ b/nixos/modules/misc/version.nix @@ -5,7 +5,6 @@ with lib; let cfg = config.system.nixos; - revisionFile = "${toString pkgs.path}/.git-revision"; gitRepo = "${toString pkgs.path}/.git"; gitCommitId = lib.substring 0 7 (commitIdFromGitRepo gitRepo); in @@ -37,9 +36,7 @@ in nixos.revision = mkOption { internal = true; type = types.str; - default = if pathIsDirectory gitRepo then commitIdFromGitRepo gitRepo - else if pathExists revisionFile then fileContents revisionFile - else "master"; + default = lib.trivial.revisionWithDefault "master"; description = "The Git revision from which this NixOS configuration was built."; }; |