mirror of
https://github.com/NixOS/nix
synced 2025-07-08 06:53:54 +02:00
* Simplify deleting .lock files in /nix/store: just don't delete them
if they belong a path that's currently being built. This gets rid of some Cygwin-specific code.
This commit is contained in:
parent
ac36c6cd44
commit
0008b0006d
4 changed files with 38 additions and 34 deletions
|
@ -7,7 +7,7 @@ dependencies.sh gc.sh nix-push.sh nix-pull.in logging.sh nix-build.sh install-pa
|
|||
locking.sh: locking.nix
|
||||
parallel.sh: parallel.nix
|
||||
build-hook.sh: build-hook.nix
|
||||
gc-concurrent.sh: gc-concurrent.nix gc-concurrent2.nix
|
||||
gc-concurrent.sh: gc-concurrent.nix gc-concurrent2.nix simple.nix
|
||||
user-envs.sh: user-envs.nix
|
||||
fixed.sh: fixed.nix
|
||||
gc-runtime.sh: gc-runtime.nix
|
||||
|
|
|
@ -8,8 +8,15 @@ outPath1=$($nixstore -q $drvPath1)
|
|||
drvPath2=$($nixinstantiate gc-concurrent2.nix)
|
||||
outPath2=$($nixstore -q $drvPath2)
|
||||
|
||||
rm -f "$NIX_STATE_DIR"/gcroots/foo
|
||||
drvPath3=$($nixinstantiate simple.nix)
|
||||
outPath3=$($nixstore -r $drvPath3)
|
||||
|
||||
! test -e $outPath3.lock
|
||||
touch $outPath3.lock
|
||||
|
||||
rm -f "$NIX_STATE_DIR"/gcroots/foo*
|
||||
ln -s $drvPath2 "$NIX_STATE_DIR"/gcroots/foo
|
||||
ln -s $outPath3 "$NIX_STATE_DIR"/gcroots/foo2
|
||||
|
||||
# Start build #1 in the background. It starts immediately.
|
||||
$nixstore -rvv "$drvPath1" &
|
||||
|
@ -39,4 +46,13 @@ cat $outPath1/input-2/bar
|
|||
# derivation is a GC root.
|
||||
cat $outPath2/foobar
|
||||
|
||||
rm "$NIX_STATE_DIR"/gcroots/foo
|
||||
rm -f "$NIX_STATE_DIR"/gcroots/foo*
|
||||
|
||||
# The collector should have deleted lock files for paths that have
|
||||
# been built previously.
|
||||
! test -e $outPath3.lock
|
||||
|
||||
# If we run the collector now, it should delete outPath1/2.
|
||||
$NIX_BIN_DIR/nix-collect-garbage -vvvvv
|
||||
! test -e $outPath1
|
||||
! test -e $outPath2
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue