summary refs log tree commit diff
path: root/pkgs/build-support/fetchgithub/default.nix
diff options
context:
space:
mode:
authorZhong Jianxin <azuwis@gmail.com>2022-01-24 11:31:41 +0800
committerZhong Jianxin <azuwis@gmail.com>2022-01-24 11:31:41 +0800
commit57829cc246ef9d5d39cc6a94c92b7c0a17eba60a (patch)
treeedcba783dd9f20454b6e8c3ba65ae8139e5817c9 /pkgs/build-support/fetchgithub/default.nix
parent36cc03e1516edc4286e7840297de2ccffe536d35 (diff)
downloadnixpkgs-57829cc246ef9d5d39cc6a94c92b7c0a17eba60a.tar
nixpkgs-57829cc246ef9d5d39cc6a94c92b7c0a17eba60a.tar.gz
nixpkgs-57829cc246ef9d5d39cc6a94c92b7c0a17eba60a.tar.bz2
nixpkgs-57829cc246ef9d5d39cc6a94c92b7c0a17eba60a.tar.lz
nixpkgs-57829cc246ef9d5d39cc6a94c92b7c0a17eba60a.tar.xz
nixpkgs-57829cc246ef9d5d39cc6a94c92b7c0a17eba60a.tar.zst
nixpkgs-57829cc246ef9d5d39cc6a94c92b7c0a17eba60a.zip
fetchgithub: Support sparseCheckout
Diffstat (limited to 'pkgs/build-support/fetchgithub/default.nix')
-rw-r--r--pkgs/build-support/fetchgithub/default.nix5
1 files changed, 3 insertions, 2 deletions
diff --git a/pkgs/build-support/fetchgithub/default.nix b/pkgs/build-support/fetchgithub/default.nix
index d40a0478bab..4e4162368b9 100644
--- a/pkgs/build-support/fetchgithub/default.nix
+++ b/pkgs/build-support/fetchgithub/default.nix
@@ -3,6 +3,7 @@
 { owner, repo, rev, name ? "source"
 , fetchSubmodules ? false, leaveDotGit ? null
 , deepClone ? false, private ? false, forceFetchGit ? false
+, sparseCheckout ? ""
 , githubBase ? "github.com", varPrefix ? null
 , ... # For hash agility
 }@args:
@@ -10,7 +11,7 @@ let
   baseUrl = "https://${githubBase}/${owner}/${repo}";
   passthruAttrs = removeAttrs args [ "owner" "repo" "rev" "fetchSubmodules" "forceFetchGit" "private" "githubBase" "varPrefix" ];
   varBase = "NIX${if varPrefix == null then "" else "_${varPrefix}"}_GITHUB_PRIVATE_";
-  useFetchGit = fetchSubmodules || (leaveDotGit == true) || deepClone || forceFetchGit;
+  useFetchGit = fetchSubmodules || (leaveDotGit == true) || deepClone || forceFetchGit || (sparseCheckout != "");
   # We prefer fetchzip in cases we don't need submodules as the hash
   # is more stable in that case.
   fetcher = if useFetchGit then fetchgit else fetchzip;
@@ -30,7 +31,7 @@ let
   };
   fetcherArgs = (if useFetchGit
     then {
-      inherit rev deepClone fetchSubmodules; url = "${baseUrl}.git";
+      inherit rev deepClone fetchSubmodules sparseCheckout; url = "${baseUrl}.git";
     } // lib.optionalAttrs (leaveDotGit != null) { inherit leaveDotGit; }
     else { url = "${baseUrl}/archive/${rev}.tar.gz"; }
   ) // privateAttrs // passthruAttrs // { inherit name; };