aboutsummaryrefslogtreecommitdiff
path: root/scripts
diff options
context:
space:
mode:
authorEelco Dolstra <e.dolstra@tudelft.nl>2003-11-22 20:39:51 +0000
committerEelco Dolstra <e.dolstra@tudelft.nl>2003-11-22 20:39:51 +0000
commit9486dda1152d18b502fc31ff1d6aed4eba6f2fe3 (patch)
treec89d92a5b7a75529656a493969ee4a1c6349e9eb /scripts
parentab0bc4999a49efbc8e1c25989662a96e32fa0cc5 (diff)
* Fix nix-push.
Diffstat (limited to 'scripts')
-rw-r--r--scripts/nix-push.in68
1 files changed, 32 insertions, 36 deletions
diff --git a/scripts/nix-push.in b/scripts/nix-push.in
index 2e8158a6a..c1624d835 100644
--- a/scripts/nix-push.in
+++ b/scripts/nix-push.in
@@ -7,14 +7,13 @@ my $tmpdir;
do { $tmpdir = tmpnam(); }
until mkdir $tmpdir, 0777;
-my $fixfile = "$tmpdir/create-nars.fix";
+my $nixfile = "$tmpdir/create-nars.nix";
my $manifest = "$tmpdir/MANIFEST";
END { unlink $manifest; unlink $fixfile; rmdir $tmpdir; }
-open FIX, ">$fixfile";
-print FIX "[";
-my $first = 1;
+open NIX, ">$nixfile";
+print NIX "[";
my @paths;
@@ -24,10 +23,10 @@ foreach my $id (@ARGV) {
# Get all paths referenced by the normalisation of the given
# Nix expression.
- system "nix --install $id > /dev/null";
- if ($?) { die "`nix --install' failed"; }
+ system "nix-store --realise $id > /dev/null";
+ die if ($?);
- open PATHS, "nix --query --requisites --include-successors $id 2> /dev/null |" or die "nix -qr";
+ open PATHS, "nix-store --query --requisites --include-successors $id 2> /dev/null |" or die;
while (<PATHS>) {
chomp;
die "bad: $_" unless /^\//;
@@ -35,34 +34,31 @@ foreach my $id (@ARGV) {
}
close PATHS;
- # For each path, create a Fix expression that turns the path into
+ # For each path, create a Nix expression that turns the path into
# a Nix archive.
foreach my $path (@paths) {
- die unless ($path =~ /\/[0-9a-z]{32}.*$/);
- print "$path\n";
-
- # Construct a Fix expression that creates a Nix archive.
- my $fixexpr =
- "Call(IncludeFix(\"nar/nar.fix\"), " .
- "[ (\"path\", Closure([\"$path\"], [(\"$path\", [])]))" .
- "])";
-
- print FIX "," unless ($first);
- $first = 0;
- print FIX $fixexpr;
+ die unless ($path =~ /\/[0-9a-z]{32}.*$/);
+ print "$path\n";
+ # 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 = \"@host@\"}) ";
+
+ print NIX $nixexpr;
}
}
-print FIX "]";
-close FIX;
+print NIX "]";
+close NIX;
-# Instantiate a Nix expression from the Fix expression.
+# Instantiate a store expression from the Nix expression.
my @nids;
-print STDERR "running fix...\n";
-open NIDS, "fix $fixfile |" or die "cannot run fix";
+print STDERR "instantiating Nix expression...\n";
+open NIDS, "nix-instantiate $nixfile |" or die "cannot run nix-instantiate";
while (<NIDS>) {
chomp;
die unless /^\//;
@@ -71,13 +67,13 @@ while (<NIDS>) {
close NIDS;
-# Realise the Nix expression.
+# Realise the store expression.
print STDERR "creating archives...\n";
-system "nix --install -v @nids > /dev/null";
-if ($?) { die "`nix --install' failed"; }
+system "nix-store --realise -v @nids > /dev/null";
+if ($?) { die "`nix --realise' failed"; }
my @narpaths;
-open NIDS, "nix --query --list @nids |" or die "cannot run nix";
+open NIDS, "nix-store --query --list @nids |" or die "cannot run nix";
while (<NIDS>) {
chomp;
die unless (/^\//);
@@ -120,13 +116,13 @@ for (my $n = 0; $n < scalar @paths; $n++) {
print MANIFEST " MD5: $hash\n";
if ($storepath =~ /\.nix$/) {
- open PREDS, "nix --query --predecessors $storepath |" or die "cannot run nix";
- while (<PREDS>) {
- chomp;
- die unless (/^\//);
- print MANIFEST " SuccOf: $_\n";
- }
- close PREDS;
+ open PREDS, "nix-store --query --predecessors $storepath |" or die "cannot run nix";
+ while (<PREDS>) {
+ chomp;
+ die unless (/^\//);
+ print MANIFEST " SuccOf: $_\n";
+ }
+ close PREDS;
}
print MANIFEST "}\n";