aboutsummaryrefslogtreecommitdiff
path: root/scripts
diff options
context:
space:
mode:
authorEelco Dolstra <e.dolstra@tudelft.nl>2011-10-11 15:41:13 +0000
committerEelco Dolstra <e.dolstra@tudelft.nl>2011-10-11 15:41:13 +0000
commit67617574280a5db534e5b5c643a3b880d1b9336c (patch)
tree9ea4ae6a7b529585a18e339061a4cce44947b2f9 /scripts
parentd43a148204a983bf676750f50640969f8edf7350 (diff)
* Use the Store API bindings in nix-copy-closure.
Diffstat (limited to 'scripts')
-rwxr-xr-xscripts/nix-copy-closure.in31
1 files changed, 3 insertions, 28 deletions
diff --git a/scripts/nix-copy-closure.in b/scripts/nix-copy-closure.in
index 966f860d0..db76b7165 100755
--- a/scripts/nix-copy-closure.in
+++ b/scripts/nix-copy-closure.in
@@ -2,6 +2,7 @@
use Nix::SSH;
use Nix::Config;
+use Nix::Store;
if (scalar @ARGV < 1) {
@@ -57,19 +58,8 @@ openSSHConnection $sshHost or die "$0: unable to start SSH\n";
if ($toMode) { # Copy TO the remote machine.
- my @allStorePaths;
-
# Get the closure of this path.
- my $pid = open(READ, "set -f; $Nix::Config::binDir/nix-store --query --requisites @storePaths|") or die;
-
- while (<READ>) {
- chomp;
- die "bad: $_" unless /^\//;
- push @allStorePaths, $_;
- }
-
- close READ or die "nix-store failed: $?";
-
+ my @allStorePaths = reverse(topoSortPaths(computeFSClosure(0, 0, map { followLinksToStorePath $_ } @storePaths)));
# Ask the remote host which paths are invalid.
open(READ, "set -f; ssh $sshHost @sshOpts nix-store --check-validity --print-invalid @allStorePaths|");
@@ -80,7 +70,6 @@ if ($toMode) { # Copy TO the remote machine.
}
close READ or die;
-
# Export the store paths and import them on the remote machine.
if (scalar @missing > 0) {
print STDERR "copying these missing paths:\n";
@@ -93,7 +82,6 @@ if ($toMode) { # Copy TO the remote machine.
}
-
else { # Copy FROM the remote machine.
# Query the closure of the given store paths on the remote
@@ -102,27 +90,14 @@ else { # Copy FROM the remote machine.
my $pid = open(READ,
"set -f; ssh @sshOpts $sshHost nix-store --query --requisites @storePaths|") or die;
- my @allStorePaths;
-
while (<READ>) {
chomp;
die "bad: $_" unless /^\//;
- push @allStorePaths, $_;
+ push @missing, $_ unless isValidPath($_);
}
close READ or die "nix-store on remote machine `$sshHost' failed: $?";
-
- # What paths are already valid locally?
- open(READ, "set -f; @bindir@/nix-store --check-validity --print-invalid @allStorePaths|");
- my @missing = ();
- while (<READ>) {
- chomp;
- push @missing, $_;
- }
- close READ or die;
-
-
# Export the store paths on the remote machine and import them on locally.
if (scalar @missing > 0) {
print STDERR "copying these missing paths:\n";