diff options
author | Eelco Dolstra <e.dolstra@tudelft.nl> | 2009-06-10 11:30:34 +0000 |
---|---|---|
committer | Eelco Dolstra <e.dolstra@tudelft.nl> | 2009-06-10 11:30:34 +0000 |
commit | f24cf5d303dac3e82068f80091d2f312455ba8cf (patch) | |
tree | db30d7d9adc4f885166e41b26c2d22a663233701 /scripts/nix-build.in | |
parent | c6cb792d48a8b4290df15202ec30b06a3383dc6a (diff) |
* nix-build: if nix-instantiate or nix-store fails due to a signal
(e.g. out of memory or a segfault), print an error message.
Otherwise the user doesn't see anything.
Diffstat (limited to 'scripts/nix-build.in')
-rw-r--r-- | scripts/nix-build.in | 10 |
1 files changed, 8 insertions, 2 deletions
diff --git a/scripts/nix-build.in b/scripts/nix-build.in index d90b902ae..458b333f3 100644 --- a/scripts/nix-build.in +++ b/scripts/nix-build.in @@ -142,7 +142,10 @@ foreach my $expr (@exprs) { # !!! would prefer the perl 5.8.0 pipe open feature here. my $pid = open(DRVPATHS, "-|") || exec "$binDir/nix-instantiate", "--add-root", $drvLink, "--indirect", @instArgs, $expr; while (<DRVPATHS>) {chomp; push @drvPaths, $_;} - close DRVPATHS or exit 1; + if (!close DRVPATHS) { + die "nix-instantiate killed by signal " . ($? & 127) . "\n" if ($? & 127); + exit 1; + } foreach my $drvPath (@drvPaths) { my $target = readlink $drvPath or die "cannot read symlink `$drvPath'"; @@ -154,7 +157,10 @@ foreach my $expr (@exprs) { $pid = open(OUTPATHS, "-|") || exec "$binDir/nix-store", "--add-root", $outLink, "--indirect", "-rv", @buildArgs, @drvPaths; while (<OUTPATHS>) {chomp; push @outPaths, $_;} - close OUTPATHS or exit 1; + if (!close OUTPATHS) { + die "nix-store killed by signal " . ($? & 127) . "\n" if ($? & 127); + exit 1; + } next if $dryRun; |