* Handle .nar.xz.

git-svn-id: https://nixos.org/repos/nix/release/trunk/channels@34737 70bd8c7a-acb8-0310-9f0d-9cc1c95dcdbb
This commit is contained in:
Eelco Dolstra 2013-06-17 02:15:49 +00:00
parent 1c233f0b23
commit 9ff5956af0

View file

@ -32,11 +32,12 @@ foreach my $storePath (keys %narFiles) {
die unless defined $basename; die unless defined $basename;
#print STDERR "GOT $basename\n"; #print STDERR "GOT $basename\n";
$usedFiles{$basename} = 1; $usedFiles{$basename} = 1;
die "$storePath does not have a file hash" unless defined $file->{hash}; die "$storePath does not have a file hash" unless defined $file->{hash};
if ($file->{hash} =~ /sha256:(.+)/) { if ($file->{hash} =~ /sha256:(.+)/) {
die unless length($1) == 52; die unless length($1) == 52;
$usedFiles{"$1.nar.bz2"} = 1; $usedFiles{"$1.nar.bz2"} = 1;
} $usedFiles{"$1.nar.xz"} = 1;
}
#print STDERR "missing archive `$basename'\n" #print STDERR "missing archive `$basename'\n"
# unless defined $readcache::archives{$basename}; # unless defined $readcache::archives{$basename};
} }
@ -59,12 +60,12 @@ sub checkDir {
my ($dir) = @_; my ($dir) = @_;
opendir(DIR, "$dir") or die "cannot open `$dir': $!"; opendir(DIR, "$dir") or die "cannot open `$dir': $!";
while (readdir DIR) { while (readdir DIR) {
next unless $_ =~ /^sha256_/ || $_ =~ /\.nar-bsdiff$/ || $_ =~ /\.nar\.bz2$/; next unless $_ =~ /^sha256_/ || $_ =~ /\.nar-bsdiff$/ || $_ =~ /\.nar\.bz2$/ || $_ =~ /\.nar\.xz$/;
if (!defined $usedFiles{$_}) { if (!defined $usedFiles{$_}) {
print "$dir/$_\n"; print "$dir/$_\n";
} else { } else {
#print STDERR "keeping $dir/$_\n"; #print STDERR "keeping $dir/$_\n";
} }
} }
closedir DIR; closedir DIR;
@ -80,9 +81,9 @@ while (readdir DIR) {
next unless /^(.*)\.narinfo$/; next unless /^(.*)\.narinfo$/;
my $hashPart = $1; my $hashPart = $1;
if (!defined $hashParts{$hashPart}) { if (!defined $hashParts{$hashPart}) {
print "$cacheDir/$_\n"; print "$cacheDir/$_\n";
} else { } else {
#print STDERR "keeping $cacheDir/$_\n"; #print STDERR "keeping $cacheDir/$_\n";
} }
} }
closedir DIR; closedir DIR;