mirror of
https://github.com/ilyakooo0/nixpkgs.git
synced 2024-12-28 14:22:50 +03:00
ecd43e2bfe
nixos.org/tarballs. It no longer greps the source for fetchurl calls, because a lot of URLs are now computed (e.g. "http://foo/${name}.tar.bz2"). So instead we evaluate the Nix expression with "nix-instantiate --xml --strict" and look for URLs in the result. Because I'm lazy the script no longer checks whether the hash of the download matches the hash in the expression. svn path=/nixpkgs/trunk/; revision=15310
58 lines
1.6 KiB
Bash
Executable File
58 lines
1.6 KiB
Bash
Executable File
#! /bin/sh -e
|
|
|
|
distDir=/data/webserver/tarballs
|
|
|
|
urls=$(nix-instantiate --eval-only --xml --strict pkgs/top-level/build-for-release.nix \
|
|
| grep -A2 'name="urls"' \
|
|
| grep '<string value=' \
|
|
| sed 's/.*"\(.*\)".*/\1/' \
|
|
| sort | uniq)
|
|
|
|
for url in $urls; do
|
|
|
|
if echo "$url" | grep -q -E "www.cs.uu.nl|nixos.org|.stratego-language.org|java.sun.com|ut2004|linuxq3a|RealPlayer|Adbe|belastingdienst|microsoft|armijn/.nix|sun.com|archive.eclipse.org"; then continue; fi
|
|
|
|
base="$(basename "$url")"
|
|
newPath="$distDir/$base"
|
|
|
|
if ! test -e "$newPath"; then
|
|
|
|
#if echo $url | grep -q 'mirror://'; then
|
|
# echo "$fn: skipping mirrored $url"
|
|
# continue
|
|
#fi
|
|
|
|
echo "downloading $url to $newPath"
|
|
|
|
if test -n "$doCopy"; then
|
|
declare -a res
|
|
if ! res=($(PRINT_PATH=1 nix-prefetch-url "$url")); then
|
|
continue
|
|
fi
|
|
storePath=${res[1]}
|
|
cp $storePath "$newPath.tmp.$$"
|
|
mv -f "$newPath.tmp.$$" "$newPath"
|
|
fi
|
|
|
|
fi
|
|
|
|
if test -n "$doCopy" -a -e "$newPath"; then
|
|
|
|
echo "hashing $newPath"
|
|
|
|
md5=$(nix-hash --flat --type md5 "$newPath")
|
|
ln -sfn "../$base" $distDir/md5/$md5
|
|
|
|
sha1=$(nix-hash --flat --type sha1 "$newPath")
|
|
ln -sfn "../$base" $distDir/sha1/$sha1
|
|
|
|
sha256=$(nix-hash --flat --type sha256 "$newPath")
|
|
ln -sfn "../$base" $distDir/sha256/$sha256
|
|
ln -sfn "../$base" $distDir/sha256/$(nix-hash --type sha256 --to-base32 "$sha256")
|
|
|
|
fi
|
|
|
|
done
|
|
|
|
echo DONE
|