diff options
author | Zhong Jianxin <azuwis@gmail.com> | 2022-01-24 11:31:41 +0800 |
---|---|---|
committer | Zhong Jianxin <azuwis@gmail.com> | 2022-01-24 11:31:41 +0800 |
commit | 57829cc246ef9d5d39cc6a94c92b7c0a17eba60a (patch) | |
tree | edcba783dd9f20454b6e8c3ba65ae8139e5817c9 /pkgs/build-support/fetchgithub/default.nix | |
parent | 36cc03e1516edc4286e7840297de2ccffe536d35 (diff) | |
download | nixpkgs-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.nix | 5 |
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; }; |