forked from lix-project/lix
* Bug fix in nix-push.
This commit is contained in:
parent
078e20885e
commit
a3ca74a1c3
|
@ -10,15 +10,11 @@ until mkdir $tmpdir, 0777;
|
||||||
my $nixfile = "$tmpdir/create-nars.nix";
|
my $nixfile = "$tmpdir/create-nars.nix";
|
||||||
my $manifest = "$tmpdir/MANIFEST";
|
my $manifest = "$tmpdir/MANIFEST";
|
||||||
|
|
||||||
END { unlink $manifest; unlink $fixfile; rmdir $tmpdir; }
|
END { unlink $manifest; unlink $nixfile; rmdir $tmpdir; }
|
||||||
|
|
||||||
open NIX, ">$nixfile";
|
|
||||||
print NIX "[";
|
|
||||||
|
|
||||||
my @paths;
|
my @paths;
|
||||||
|
|
||||||
foreach my $id (@ARGV) {
|
foreach my $id (@ARGV) {
|
||||||
|
|
||||||
die unless $id =~ /^\//;
|
die unless $id =~ /^\//;
|
||||||
|
|
||||||
# Get all paths referenced by the normalisation of the given
|
# Get all paths referenced by the normalisation of the given
|
||||||
|
@ -33,22 +29,25 @@ foreach my $id (@ARGV) {
|
||||||
push @paths, $_;
|
push @paths, $_;
|
||||||
}
|
}
|
||||||
close PATHS;
|
close PATHS;
|
||||||
|
}
|
||||||
|
|
||||||
# For each path, create a Nix expression that turns the path into
|
# For each path, create a Nix expression that turns the path into
|
||||||
# a Nix archive.
|
# a Nix archive.
|
||||||
foreach my $path (@paths) {
|
open NIX, ">$nixfile";
|
||||||
|
print NIX "[";
|
||||||
|
|
||||||
die unless ($path =~ /\/[0-9a-z]{32}.*$/);
|
foreach my $path (@paths) {
|
||||||
print "$path\n";
|
|
||||||
|
|
||||||
# Construct a Nix expression that creates a Nix archive.
|
die unless ($path =~ /\/[0-9a-z]{32}.*$/);
|
||||||
my $nixexpr =
|
print "$path\n";
|
||||||
"((import @datadir@/nix/corepkgs/nar/nar.nix) " .
|
|
||||||
# !!! $path should be represented as a closure
|
|
||||||
"{path = \"$path\"; system = \"@system@\"}) ";
|
|
||||||
|
|
||||||
print NIX $nixexpr;
|
# Construct a Nix expression that creates a Nix archive.
|
||||||
}
|
my $nixexpr =
|
||||||
|
"((import @datadir@/nix/corepkgs/nar/nar.nix) " .
|
||||||
|
# !!! $path should be represented as a closure
|
||||||
|
"{path = \"$path\"; system = \"@system@\"}) ";
|
||||||
|
|
||||||
|
print NIX $nixexpr;
|
||||||
}
|
}
|
||||||
|
|
||||||
print NIX "]";
|
print NIX "]";
|
||||||
|
@ -63,6 +62,7 @@ while (<NIDS>) {
|
||||||
chomp;
|
chomp;
|
||||||
die unless /^\//;
|
die unless /^\//;
|
||||||
push @nids, $_;
|
push @nids, $_;
|
||||||
|
print "$_\n";
|
||||||
}
|
}
|
||||||
close NIDS;
|
close NIDS;
|
||||||
|
|
||||||
|
@ -70,7 +70,7 @@ close NIDS;
|
||||||
# Realise the store expression.
|
# Realise the store expression.
|
||||||
print STDERR "creating archives...\n";
|
print STDERR "creating archives...\n";
|
||||||
system "nix-store --realise -v @nids > /dev/null";
|
system "nix-store --realise -v @nids > /dev/null";
|
||||||
if ($?) { die "`nix --realise' failed"; }
|
if ($?) { die "`nix-store --realise' failed"; }
|
||||||
|
|
||||||
my @narpaths;
|
my @narpaths;
|
||||||
open NIDS, "nix-store --query --list @nids |" or die "cannot run nix";
|
open NIDS, "nix-store --query --list @nids |" or die "cannot run nix";
|
||||||
|
|
Loading…
Reference in a new issue