aboutsummaryrefslogtreecommitdiff
path: root/scripts/nix-pull.in
diff options
context:
space:
mode:
authorEelco Dolstra <e.dolstra@tudelft.nl>2003-11-24 11:11:40 +0000
committerEelco Dolstra <e.dolstra@tudelft.nl>2003-11-24 11:11:40 +0000
commite7ea52d3b336e6336c801eb8f868c0b8dd464910 (patch)
treedd7bad3d993dac097e729e6922c777e599d932e4 /scripts/nix-pull.in
parentb8572678930568efcf0b44523e6a2a65afef7c43 (diff)
* One-click installation :-)
The script nix-install-package takes a `Nix package file' (which contains one or more derivations, along with URLs of Nix caches), unpacks it, pulls the caches, and installs the derivations in the user's environment. For best results, associate the command `xterm -e /nix/bin/nix-install-package' with the MIME type `application/x-nix-package' and visit http://losser.st-lab.cs.uu.nl/~eelco/test/.
Diffstat (limited to 'scripts/nix-pull.in')
-rw-r--r--scripts/nix-pull.in152
1 files changed, 82 insertions, 70 deletions
diff --git a/scripts/nix-pull.in b/scripts/nix-pull.in
index ad21b6f8a..1453a46ac 100644
--- a/scripts/nix-pull.in
+++ b/scripts/nix-pull.in
@@ -19,86 +19,98 @@ my @sucs;
my $fullexpr = "[";
-open CONFFILE, "<$conffile";
-while (<CONFFILE>) {
+sub processURL {
+ my $url = shift;
+ $url =~ s/\/$//;
+ print "obtaining list of Nix archives at $url...\n";
- chomp;
- if (/^\s*(\S+)\s*(\#.*)?$/) {
- my $url = $1;
- $url =~ s/\/$//;
-
- print "obtaining list of Nix archives at $url...\n";
-
- system "wget --cache=off '$url'/MANIFEST -O '$manifest' 2> /dev/null"; # !!! escape
- if ($?) { die "`wget' failed"; }
+ system "wget --cache=off '$url'/MANIFEST -O '$manifest' 2> /dev/null"; # !!! escape
+ if ($?) { die "`wget' failed"; }
- open MANIFEST, "<$manifest";
-
- my $inside = 0;
-
- my $storepath;
- my $narname;
- my $hash;
- my @preds;
-
- while (<MANIFEST>) {
- chomp;
- s/\#.*$//g;
- next if (/^$/);
-
- if (!$inside) {
- if (/^\{$/) {
- $inside = 1;
- undef $storepath;
- undef $narname;
- undef $hash;
- @preds = ();
- }
- else { die "bad line: $_"; }
- } else {
- if (/^\}$/) {
- $inside = 0;
- my $fullurl = "$url/$narname";
- print "$storepath\n";
-
- # Construct a Nix expression that fetches and unpacks a
- # Nix archive from the network.
- my $fetch =
- "(import @datadir@/nix/corepkgs/fetchurl) " .
- "{url = $fullurl; md5 = \"$hash\"; system = \"@host@\"}";
- my $nixexpr =
- "((import @datadir@/nix/corepkgs/nar/unnar.nix) " .
- "{narFile = ($fetch); outPath = \"$storepath\"; system = \"@host@\"}) ";
- $fullexpr .= $nixexpr; # !!! O(n^2)?
-
- push @srcpaths, $storepath;
-
- foreach my $p (@preds) {
- push @sucs, $p;
- push @sucs, $storepath;
- }
-
+ open MANIFEST, "<$manifest";
+
+ my $inside = 0;
+
+ my $storepath;
+ my $narname;
+ my $hash;
+ my @preds;
+
+ while (<MANIFEST>) {
+ chomp;
+ s/\#.*$//g;
+ next if (/^$/);
+
+ if (!$inside) {
+ if (/^\{$/) {
+ $inside = 1;
+ undef $storepath;
+ undef $narname;
+ undef $hash;
+ @preds = ();
}
- elsif (/^\s*StorePath:\s*(\/\S+)\s*$/) {
- $storepath = $1;
+ else { die "bad line: $_"; }
+ } else {
+ if (/^\}$/) {
+ $inside = 0;
+ my $fullurl = "$url/$narname";
+# print "$storepath\n";
+
+ # Construct a Nix expression that fetches and unpacks a
+ # Nix archive from the network.
+ my $fetch =
+ "(import @datadir@/nix/corepkgs/fetchurl) " .
+ "{url = $fullurl; md5 = \"$hash\"; system = \"@host@\"}";
+ my $nixexpr =
+ "((import @datadir@/nix/corepkgs/nar/unnar.nix) " .
+ "{narFile = ($fetch); outPath = \"$storepath\"; system = \"@host@\"}) ";
+ $fullexpr .= $nixexpr; # !!! O(n^2)?
+
+ push @srcpaths, $storepath;
+
+ foreach my $p (@preds) {
+ push @sucs, $p;
+ push @sucs, $storepath;
}
- elsif (/^\s*NarName:\s*(\S+)\s*$/) {
- $narname = $1;
- }
- elsif (/^\s*MD5:\s*(\S+)\s*$/) {
- $hash = $1;
- }
- elsif (/^\s*SuccOf:\s*(\/\S+)\s*$/) {
- push @preds, $1;
+
+ }
+ elsif (/^\s*StorePath:\s*(\/\S+)\s*$/) {
+ $storepath = $1;
+ }
+ elsif (/^\s*NarName:\s*(\S+)\s*$/) {
+ $narname = $1;
}
- else { die "bad line: $_"; }
+ elsif (/^\s*MD5:\s*(\S+)\s*$/) {
+ $hash = $1;
+ }
+ elsif (/^\s*SuccOf:\s*(\/\S+)\s*$/) {
+ push @preds, $1;
}
+ else { die "bad line: $_"; }
}
-
- close MANIFEST;
}
+ close MANIFEST;
+}
+
+
+# Obtain URLs either from the command line or from a configuration file.
+if (scalar @ARGV > 0) {
+ while (@ARGV) {
+ my $url = shift @ARGV;
+ processURL $url;
+ }
+} else {
+ open CONFFILE, "<$conffile";
+ while (<CONFFILE>) {
+ chomp;
+ if (/^\s*(\S+)\s*(\#.*)?$/) {
+ my $url = $1;
+ processURL $url;
+ }
+ }
+ close CONFFILE;
}
$fullexpr .= "]";