2024-05-02 00:46:19 +00:00
|
|
|
# This function downloads and unpacks an archive file, such as a zip
|
|
|
|
# or tar file. This is primarily useful for dynamically generated
|
|
|
|
# archives, such as GitHub's /archive URLs, where the unpacked content
|
|
|
|
# of the zip file doesn't change, but the zip file itself may
|
|
|
|
# (e.g. due to minor changes in the compression algorithm, or changes
|
|
|
|
# in timestamps).
|
|
|
|
|
2024-06-30 08:16:52 +00:00
|
|
|
{
|
|
|
|
lib,
|
|
|
|
fetchurl,
|
|
|
|
withUnzip ? true,
|
|
|
|
unzip,
|
|
|
|
glibcLocalesUtf8,
|
|
|
|
}:
|
2024-05-02 00:46:19 +00:00
|
|
|
|
2024-06-30 08:16:52 +00:00
|
|
|
{
|
|
|
|
name ? "source",
|
|
|
|
url ? "",
|
|
|
|
urls ? [ ],
|
|
|
|
nativeBuildInputs ? [ ],
|
|
|
|
postFetch ? "",
|
|
|
|
extraPostFetch ? "",
|
2024-05-02 00:46:19 +00:00
|
|
|
|
2024-06-30 08:16:52 +00:00
|
|
|
# Optionally move the contents of the unpacked tree up one level.
|
|
|
|
stripRoot ? true,
|
|
|
|
# Allows to set the extension for the intermediate downloaded
|
|
|
|
# file. This can be used as a hint for the unpackCmdHooks to select
|
|
|
|
# an appropriate unpacking tool.
|
|
|
|
extension ? null,
|
2024-05-02 00:46:19 +00:00
|
|
|
|
2024-06-30 08:16:52 +00:00
|
|
|
# the rest are given to fetchurl as is
|
|
|
|
...
|
|
|
|
}@args:
|
2024-05-02 00:46:19 +00:00
|
|
|
|
2024-06-30 08:16:52 +00:00
|
|
|
assert
|
|
|
|
(extraPostFetch != "")
|
|
|
|
-> lib.warn "use 'postFetch' instead of 'extraPostFetch' with 'fetchzip' and 'fetchFromGitHub' or 'fetchFromGitLab'." true;
|
2024-05-02 00:46:19 +00:00
|
|
|
|
|
|
|
let
|
|
|
|
tmpFilename =
|
2024-06-30 08:16:52 +00:00
|
|
|
if extension != null then
|
|
|
|
"download.${extension}"
|
|
|
|
else
|
|
|
|
baseNameOf (if url != "" then url else builtins.head urls);
|
2024-05-02 00:46:19 +00:00
|
|
|
in
|
|
|
|
|
2024-06-30 08:16:52 +00:00
|
|
|
fetchurl (
|
|
|
|
{
|
|
|
|
inherit name;
|
|
|
|
recursiveHash = true;
|
2024-05-02 00:46:19 +00:00
|
|
|
|
2024-06-30 08:16:52 +00:00
|
|
|
downloadToTemp = true;
|
2024-05-02 00:46:19 +00:00
|
|
|
|
2024-06-30 08:16:52 +00:00
|
|
|
# Have to pull in glibcLocalesUtf8 for unzip in setup-hook.sh to handle
|
|
|
|
# UTF-8 aware locale:
|
|
|
|
# https://github.com/NixOS/nixpkgs/issues/176225#issuecomment-1146617263
|
|
|
|
nativeBuildInputs =
|
|
|
|
lib.optionals withUnzip [
|
|
|
|
unzip
|
|
|
|
glibcLocalesUtf8
|
|
|
|
]
|
|
|
|
++ nativeBuildInputs;
|
2024-05-02 00:46:19 +00:00
|
|
|
|
2024-06-30 08:16:52 +00:00
|
|
|
postFetch =
|
|
|
|
''
|
|
|
|
unpackDir="$TMPDIR/unpack"
|
|
|
|
mkdir "$unpackDir"
|
|
|
|
cd "$unpackDir"
|
2024-05-02 00:46:19 +00:00
|
|
|
|
2024-06-30 08:16:52 +00:00
|
|
|
renamed="$TMPDIR/${tmpFilename}"
|
|
|
|
mv "$downloadedFile" "$renamed"
|
|
|
|
unpackFile "$renamed"
|
|
|
|
chmod -R +w "$unpackDir"
|
|
|
|
''
|
|
|
|
+ (
|
|
|
|
if stripRoot then
|
|
|
|
''
|
|
|
|
if [ $(ls -A "$unpackDir" | wc -l) != 1 ]; then
|
|
|
|
echo "error: zip file must contain a single file or directory."
|
|
|
|
echo "hint: Pass stripRoot=false; to fetchzip to assume flat list of files."
|
|
|
|
exit 1
|
|
|
|
fi
|
|
|
|
fn=$(cd "$unpackDir" && ls -A)
|
|
|
|
if [ -f "$unpackDir/$fn" ]; then
|
|
|
|
mkdir $out
|
|
|
|
fi
|
|
|
|
mv "$unpackDir/$fn" "$out"
|
|
|
|
''
|
|
|
|
else
|
|
|
|
''
|
|
|
|
mv "$unpackDir" "$out"
|
|
|
|
''
|
|
|
|
)
|
|
|
|
+ ''
|
|
|
|
${postFetch}
|
|
|
|
${extraPostFetch}
|
|
|
|
chmod 755 "$out"
|
|
|
|
'';
|
2024-05-02 00:46:19 +00:00
|
|
|
# ^ Remove non-owner write permissions
|
|
|
|
# Fixes https://github.com/NixOS/nixpkgs/issues/38649
|
2024-06-30 08:16:52 +00:00
|
|
|
}
|
|
|
|
// removeAttrs args [
|
|
|
|
"stripRoot"
|
|
|
|
"extraPostFetch"
|
|
|
|
"postFetch"
|
|
|
|
"extension"
|
|
|
|
"nativeBuildInputs"
|
|
|
|
]
|
|
|
|
)
|