Revert "fetchzip, fetchgit: cleanup handling of optional features and whitespace"

This commit is contained in:
Benjamin Hipple 2020-03-26 00:35:40 -04:00 committed by GitHub
parent a0c0ae3af0
commit 259f3b3b68
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
3 changed files with 43 additions and 41 deletions

View File

@ -1,4 +1,4 @@
{ stdenvNoCC, git, cacert }: let {stdenvNoCC, git, cacert}: let
urlToName = url: rev: let urlToName = url: rev: let
inherit (stdenvNoCC.lib) removeSuffix splitString last; inherit (stdenvNoCC.lib) removeSuffix splitString last;
base = last (splitString ":" (baseNameOf (removeSuffix "/" url))); base = last (splitString ":" (baseNameOf (removeSuffix "/" url)));

View File

@ -1,5 +1,6 @@
#!/usr/bin/env bash #! /usr/bin/env bash
set -eo pipefail
set -e -o pipefail
url= url=
rev= rev=
@ -39,9 +40,9 @@ usage(){
Options: Options:
--out path Path where the output would be stored. --out path Path where the output would be stored.
--url url Any url understood by 'git clone'. --url url Any url understood by 'git clone'.
--rev ref Any sha1 or references (such as refs/heads/master). --rev ref Any sha1 or references (such as refs/heads/master)
--hash h Expected hash. --hash h Expected hash.
--branch-name Branch name to check out into. --branch-name Branch name to check out into
--deepClone Clone the entire repository. --deepClone Clone the entire repository.
--no-deepClone Make a shallow clone of just the required ref. --no-deepClone Make a shallow clone of just the required ref.
--leave-dotGit Keep the .git directories. --leave-dotGit Keep the .git directories.

View File

@ -5,22 +5,24 @@
# (e.g. due to minor changes in the compression algorithm, or changes # (e.g. due to minor changes in the compression algorithm, or changes
# in timestamps). # in timestamps).
{ lib, fetchurl, unzip }: { fetchurl, unzip }:
{ name ? "source" { # Optionally move the contents of the unpacked tree up one level.
stripRoot ? true
, url , url
# Optionally move the contents of the unpacked tree up one level.
, stripRoot ? true
, extraPostFetch ? "" , extraPostFetch ? ""
, name ? "source"
, ... } @ args: , ... } @ args:
(fetchurl ({ (fetchurl ({
inherit name; inherit name;
recursiveHash = true; recursiveHash = true;
downloadToTemp = true; downloadToTemp = true;
postFetch = '' postFetch =
''
unpackDir="$TMPDIR/unpack" unpackDir="$TMPDIR/unpack"
mkdir "$unpackDir" mkdir "$unpackDir"
cd "$unpackDir" cd "$unpackDir"
@ -28,23 +30,22 @@
renamed="$TMPDIR/${baseNameOf url}" renamed="$TMPDIR/${baseNameOf url}"
mv "$downloadedFile" "$renamed" mv "$downloadedFile" "$renamed"
unpackFile "$renamed" unpackFile "$renamed"
result=$unpackDir
'' ''
# Most src disted tarballs have a parent directory like foo-1.2.3/ to strip + (if stripRoot then ''
+ lib.optionalString stripRoot ''
if [ $(ls "$unpackDir" | wc -l) != 1 ]; then if [ $(ls "$unpackDir" | wc -l) != 1 ]; then
echo "error: zip file must contain a single file or directory." echo "error: zip file must contain a single file or directory."
echo "hint: Pass stripRoot=false; to fetchzip to assume flat list of files." echo "hint: Pass stripRoot=false; to fetchzip to assume flat list of files."
exit 1 exit 1
fi fi
fn=$(cd "$unpackDir" && echo *) fn=$(cd "$unpackDir" && echo *)
result="$unpackDir/$fn" if [ -f "$unpackDir/$fn" ]; then
'' + ''
mkdir $out mkdir $out
mv "$result" "$out" fi
'' mv "$unpackDir/$fn" "$out"
'' else ''
mv "$unpackDir" "$out"
'') #*/
+ extraPostFetch; + extraPostFetch;
} // removeAttrs args [ "stripRoot" "extraPostFetch" ])).overrideAttrs (x: { } // removeAttrs args [ "stripRoot" "extraPostFetch" ])).overrideAttrs (x: {
# Hackety-hack: we actually need unzip hooks, too # Hackety-hack: we actually need unzip hooks, too
nativeBuildInputs = x.nativeBuildInputs ++ [ unzip ]; nativeBuildInputs = x.nativeBuildInputs ++ [ unzip ];