Merge pull request #83408 from NixOS/revert-79581-feature/fetcher-whitespace-clean
Revert "fetchzip, fetchgit: cleanup handling of optional features and whitespace"
This commit is contained in:
commit
33f0805fe0
@ -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.
|
||||||
|
@ -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 ];
|
||||||
|
Loading…
Reference in New Issue
Block a user