diff options
author | Eelco Dolstra <eelco.dolstra@logicblox.com> | 2005-02-22 16:27:28 +0000 |
---|---|---|
committer | Eelco Dolstra <eelco.dolstra@logicblox.com> | 2005-02-22 16:27:28 +0000 |
commit | fa88e75c4587aacebbc0c3f37b6a15f0c57d8268 (patch) | |
tree | 1564da3ba307851e6b10a7d615fca549dceb1439 /pkgs/build-support/fetchsvn/nix-prefetch-svn | |
parent | 1177e8925fdb228def13654d517f9c40e500a32b (diff) | |
download | nixlib-fa88e75c4587aacebbc0c3f37b6a15f0c57d8268.tar nixlib-fa88e75c4587aacebbc0c3f37b6a15f0c57d8268.tar.gz nixlib-fa88e75c4587aacebbc0c3f37b6a15f0c57d8268.tar.bz2 nixlib-fa88e75c4587aacebbc0c3f37b6a15f0c57d8268.tar.lz nixlib-fa88e75c4587aacebbc0c3f37b6a15f0c57d8268.tar.xz nixlib-fa88e75c4587aacebbc0c3f37b6a15f0c57d8268.tar.zst nixlib-fa88e75c4587aacebbc0c3f37b6a15f0c57d8268.zip |
* Use fixed-output hashes in fetchsvn.
* In nix-prefetch-svn, support setuid installations where the user has no write access to the Nix store. svn path=/nixpkgs/trunk/; revision=2275
Diffstat (limited to 'pkgs/build-support/fetchsvn/nix-prefetch-svn')
-rwxr-xr-x | pkgs/build-support/fetchsvn/nix-prefetch-svn | 22 |
1 files changed, 16 insertions, 6 deletions
diff --git a/pkgs/build-support/fetchsvn/nix-prefetch-svn b/pkgs/build-support/fetchsvn/nix-prefetch-svn index 7f5f6828941b..00d860e347ed 100755 --- a/pkgs/build-support/fetchsvn/nix-prefetch-svn +++ b/pkgs/build-support/fetchsvn/nix-prefetch-svn @@ -24,6 +24,15 @@ if test -z "$hash"; then # !!! race? should be relatively safe, `svn export' barfs if $tmpPath exists. tmpPath1=$storeDir/svn-checkout-tmp-$$ + # Test whether we have write permission in the store. If not, + # fetch to /tmp and don't copy to the store. This is a hack to + # make this script at least work somewhat in setuid installations. + if ! touch $tmpPath1 2> /dev/null; then + echo "(cannot write to the store, result won't be cached)" >&2 + dummyMode=1 + tmpPath1=/tmp/nix-prefetch-svn-$$ # !!! security? + fi + # Perform the checkout. svn export -r "$rev" "$url" $tmpPath1 >&2 @@ -32,9 +41,10 @@ if test -z "$hash"; then echo "hash is $hash" >&2 # Rename it so that the fetchsvn builder can find it. - tmpPath2=$storeDir/svn-checkout-tmp-$hash - test -e $tmpPath2 || mv $tmpPath1 $tmpPath2 # !!! race - + if test "$dummyMode" != 1; then + tmpPath2=$storeDir/svn-checkout-tmp-$hash + test -e $tmpPath2 || mv $tmpPath1 $tmpPath2 # !!! race + fi fi # Create a Nix expression that does a fetchsvn. @@ -44,12 +54,12 @@ storeExpr=$( \ | nix-instantiate -) # Realise it. -finalPath=$(nix-store -qnB --force-realise $storeExpr) +finalPath=$(nix-store -r $storeExpr) echo "path is $finalPath" >&2 -if test -n "$tmpPath2"; then - rm -rf $tmpPath2 || true +if test -n "$tmpPath1" -o -n "$tmpPath2"; then + rm -rf $tmpPath1 $tmpPath2 || true fi echo $hash |