forked from lix-project/lix
* nix-switch now removes the link to the previously activated system
package as a root of the garbage collector, unless `--keep' is specified.
This commit is contained in:
parent
24b3d0759e
commit
243370bc52
|
@ -1,6 +1,14 @@
|
||||||
#! /usr/bin/perl -w
|
#! /usr/bin/perl -w
|
||||||
|
|
||||||
use strict;
|
use strict;
|
||||||
|
|
||||||
|
my $keep = 0;
|
||||||
|
|
||||||
|
if (scalar @ARGV > 0 && $ARGV[0] eq "--keep") {
|
||||||
|
shift @ARGV;
|
||||||
|
$keep = 1;
|
||||||
|
}
|
||||||
|
|
||||||
my $hash = $ARGV[0];
|
my $hash = $ARGV[0];
|
||||||
$hash || die "no package hash specified";
|
$hash || die "no package hash specified";
|
||||||
|
|
||||||
|
@ -31,6 +39,12 @@ open HASH, "> $hashfile" or die "cannot create $hashfile";
|
||||||
print HASH "$hash\n";
|
print HASH "$hash\n";
|
||||||
close HASH;
|
close HASH;
|
||||||
|
|
||||||
|
my $current = "$linkdir/current";
|
||||||
|
|
||||||
|
# Read the current generation so that we can delete it (if --keep
|
||||||
|
# wasn't specified).
|
||||||
|
my $oldlink = readlink($current);
|
||||||
|
|
||||||
# Make $link the current generation by pointing $linkdir/current to
|
# Make $link the current generation by pointing $linkdir/current to
|
||||||
# it. The rename() system call is supposed to be essentially atomic
|
# it. The rename() system call is supposed to be essentially atomic
|
||||||
# on Unix. That is, if we have links `current -> X' and `new_current
|
# on Unix. That is, if we have links `current -> X' and `new_current
|
||||||
|
@ -39,10 +53,14 @@ close HASH;
|
||||||
# condition. This is sufficient to atomically switch the current link
|
# condition. This is sufficient to atomically switch the current link
|
||||||
# tree.
|
# tree.
|
||||||
|
|
||||||
my $current = "$linkdir/current";
|
|
||||||
|
|
||||||
print "switching $current to $link\n";
|
print "switching $current to $link\n";
|
||||||
|
|
||||||
my $tmplink = "$linkdir/new_current";
|
my $tmplink = "$linkdir/new_current";
|
||||||
symlink($link, $tmplink) or die "cannot create $tmplink";
|
symlink($link, $tmplink) or die "cannot create $tmplink";
|
||||||
rename($tmplink, $current) or die "cannot rename $tmplink";
|
rename($tmplink, $current) or die "cannot rename $tmplink";
|
||||||
|
|
||||||
|
if (!$keep && defined $oldlink) {
|
||||||
|
print "deleting old $oldlink\n";
|
||||||
|
unlink $tmplink || print "cannot delete $tmplink";
|
||||||
|
unlink "$tmplink.hash" || print "cannot delete $tmplink.hash";
|
||||||
|
}
|
||||||
|
|
Loading…
Reference in a new issue