fetchFromGitHub: fix fetchSubmodules=true when revision is not hexadecimal

This commit is contained in:
Volth 2017-06-26 12:56:00 +00:00
parent c73f0caea5
commit 535a6c3520
4 changed files with 25 additions and 21 deletions

View File

@ -1,21 +1,9 @@
{stdenv, git, cacert}: let {stdenv, git, cacert, gitRepoToName}:
urlToName = url: rev: let
inherit (stdenv.lib) removeSuffix splitString last;
base = last (splitString ":" (baseNameOf (removeSuffix "/" url)));
matched = builtins.match "(.*).git" base;
short = builtins.substring 0 7 rev;
appendShort = if (builtins.match "[a-f0-9]*" rev) != null
then "-${short}"
else "";
in "${if matched == null then base else builtins.head matched}${appendShort}";
in
{ url, rev ? "HEAD", md5 ? "", sha256 ? "", leaveDotGit ? deepClone { url, rev ? "HEAD", md5 ? "", sha256 ? "", leaveDotGit ? deepClone
, fetchSubmodules ? true, deepClone ? false , fetchSubmodules ? true, deepClone ? false
, branchName ? null , branchName ? null
, name ? urlToName url rev , name ? gitRepoToName url rev
, # Shell code executed after the file has been fetched , # Shell code executed after the file has been fetched
# successfully. This can do things like check or transform the file. # successfully. This can do things like check or transform the file.
postFetch ? "" postFetch ? ""

View File

@ -0,0 +1,14 @@
{ lib }:
urlOrRepo: rev: let
inherit (lib) removeSuffix splitString last;
base = last (splitString ":" (baseNameOf (removeSuffix "/" urlOrRepo)));
matched = builtins.match "(.*).git" base;
short = builtins.substring 0 7 rev;
appendShort = if (builtins.match "[a-f0-9]*" rev) != null
then "-${short}"
else "";
in "${if matched == null then base else builtins.head matched}${appendShort}"

View File

@ -282,8 +282,8 @@ _clone_user_rev() {
if test -z "$(echo "$rev" | tr -d 0123456789abcdef)"; then if test -z "$(echo "$rev" | tr -d 0123456789abcdef)"; then
clone "$dir" "$url" "$rev" "" 1>&2 clone "$dir" "$url" "$rev" "" 1>&2
else else
echo 1>&2 "Bad commit hash or bad reference." # if revision is not hexadecimal it might be a tag
exit 1 clone "$dir" "$url" "" "refs/tags/$rev" 1>&2
fi;; fi;;
esac esac

View File

@ -185,8 +185,10 @@ with pkgs;
fetchzip = callPackage ../build-support/fetchzip { }; fetchzip = callPackage ../build-support/fetchzip { };
gitRepoToName = callPackage ../build-support/fetchgit/gitrepotoname.nix { };
fetchFromGitHub = { fetchFromGitHub = {
owner, repo, rev, name ? "${repo}-${rev}-src", owner, repo, rev, name ? gitRepoToName repo rev,
fetchSubmodules ? false, private ? false, fetchSubmodules ? false, private ? false,
githubBase ? "github.com", varPrefix ? null, githubBase ? "github.com", varPrefix ? null,
... # For hash agility ... # For hash agility
@ -223,7 +225,7 @@ with pkgs;
} // passthruAttrs) // { inherit rev; }; } // passthruAttrs) // { inherit rev; };
fetchFromBitbucket = { fetchFromBitbucket = {
owner, repo, rev, name ? "${repo}-${rev}-src", owner, repo, rev, name ? gitRepoToName repo rev,
... # For hash agility ... # For hash agility
}@args: fetchzip ({ }@args: fetchzip ({
inherit name; inherit name;
@ -234,7 +236,7 @@ with pkgs;
# cgit example, snapshot support is optional in cgit # cgit example, snapshot support is optional in cgit
fetchFromSavannah = { fetchFromSavannah = {
repo, rev, name ? "${repo}-${rev}-src", repo, rev, name ? gitRepoToName repo rev,
... # For hash agility ... # For hash agility
}@args: fetchzip ({ }@args: fetchzip ({
inherit name; inherit name;
@ -244,7 +246,7 @@ with pkgs;
# gitlab example # gitlab example
fetchFromGitLab = { fetchFromGitLab = {
owner, repo, rev, name ? "${repo}-${rev}-src", owner, repo, rev, name ? gitRepoToName repo rev,
... # For hash agility ... # For hash agility
}@args: fetchzip ({ }@args: fetchzip ({
inherit name; inherit name;
@ -254,7 +256,7 @@ with pkgs;
# gitweb example, snapshot support is optional in gitweb # gitweb example, snapshot support is optional in gitweb
fetchFromRepoOrCz = { fetchFromRepoOrCz = {
repo, rev, name ? "${repo}-${rev}-src", repo, rev, name ? gitRepoToName repo rev,
... # For hash agility ... # For hash agility
}@args: fetchzip ({ }@args: fetchzip ({
inherit name; inherit name;