diff options
author | Sandro Jäckel <sandro.jaeckel@gmail.com> | 2021-07-22 11:29:02 +0200 |
---|---|---|
committer | Sandro Jäckel <sandro.jaeckel@gmail.com> | 2021-07-22 13:09:14 +0200 |
commit | 94848bd430750f523706a42371bb0b268e75c695 (patch) | |
tree | 3b6dc6ddc6e394515b3031042da966b06e3da8f9 /pkgs/build-support/fetchgitlab/default.nix | |
parent | 94675cc77a57461bb9b25934e3cf9a574d799382 (diff) | |
download | nixpkgs-94848bd430750f523706a42371bb0b268e75c695.tar nixpkgs-94848bd430750f523706a42371bb0b268e75c695.tar.gz nixpkgs-94848bd430750f523706a42371bb0b268e75c695.tar.bz2 nixpkgs-94848bd430750f523706a42371bb0b268e75c695.tar.lz nixpkgs-94848bd430750f523706a42371bb0b268e75c695.tar.xz nixpkgs-94848bd430750f523706a42371bb0b268e75c695.tar.zst nixpkgs-94848bd430750f523706a42371bb0b268e75c695.zip |
fetchgitlab: add deepClone, fetchSubmodules, leaveDotGit arguments
Diffstat (limited to 'pkgs/build-support/fetchgitlab/default.nix')
-rw-r--r-- | pkgs/build-support/fetchgitlab/default.nix | 28 |
1 files changed, 16 insertions, 12 deletions
diff --git a/pkgs/build-support/fetchgitlab/default.nix b/pkgs/build-support/fetchgitlab/default.nix index 77512510a7c..5b9dbd71c59 100644 --- a/pkgs/build-support/fetchgitlab/default.nix +++ b/pkgs/build-support/fetchgitlab/default.nix @@ -1,22 +1,26 @@ -{ fetchzip, lib }: +{ fetchgit, fetchzip, lib }: # gitlab example { owner, repo, rev, domain ? "gitlab.com", name ? "source", group ? null +, fetchSubmodules ? false, leaveDotGit ? false, deepClone ? false , ... # For hash agility } @ args: -with lib; - let - slug = concatStringsSep "/" - ((optional (group != null) group) ++ [ owner repo ]); + slug = lib.concatStringsSep "/" ((lib.optional (group != null) group) ++ [ owner repo ]); + escapedSlug = lib.replaceStrings [ "." "/" ] [ "%2E" "%2F" ] slug; + escapedRev = lib.replaceStrings [ "+" "%" "/" ] [ "%2B" "%25" "%2F" ] rev; + passthruAttrs = removeAttrs args [ "domain" "owner" "group" "repo" "rev" ]; + + useFetchGit = deepClone || fetchSubmodules || leaveDotGit; + fetcher = if useFetchGit then fetchgit else fetchzip; - escapedSlug = replaceStrings ["." "/"] ["%2E" "%2F"] slug; - escapedRev = replaceStrings ["+" "%" "/"] ["%2B" "%25" "%2F"] rev; + fetcherArgs = (if useFetchGit then { + inherit rev deepClone fetchSubmodules leaveDotGit; + url = "https://${domain}/${slug}.git"; + } else { + url = "https://${domain}/api/v4/projects/${escapedSlug}/repository/archive.tar.gz?sha=${escapedRev}"; + }) // passthruAttrs // { inherit name; }; in -fetchzip ({ - inherit name; - url = "https://${domain}/api/v4/projects/${escapedSlug}/repository/archive.tar.gz?sha=${escapedRev}"; - meta.homepage = "https://${domain}/${slug}/"; -} // removeAttrs args [ "domain" "owner" "group" "repo" "rev" ]) // { inherit rev; } +fetcher fetcherArgs // { meta.homepage = "https://${domain}/${slug}/"; inherit rev; } |