projects
/
openwrt.git
/ blobdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
|
commitdiff
|
tree
raw
|
inline
| side by side
prevent zombies from occuring when stdou/stdout are held open
[openwrt.git]
/
openwrt
/
scripts
/
download.pl
diff --git
a/openwrt/scripts/download.pl
b/openwrt/scripts/download.pl
index
607a9bd
..
8042e2d
100755
(executable)
--- a/
openwrt/scripts/download.pl
+++ b/
openwrt/scripts/download.pl
@@
-5,13
+5,11
@@
use warnings;
my $target = shift @ARGV;
my $filename = shift @ARGV;
my $md5sum = shift @ARGV;
my $target = shift @ARGV;
my $filename = shift @ARGV;
my $md5sum = shift @ARGV;
-my @mirrors
= @ARGV
;
+my @mirrors;
my $ok;
my $ok;
-@mirrors > 0 or die "Syntax: $0 <target dir> <filename> <md5sum> <mirror> [<mirror> ...]\n";
-
-push @mirrors, 'http://openwrt.inf.fh-brs.de/mirror';
+@ARGV > 0 or die "Syntax: $0 <target dir> <filename> <md5sum> <mirror> [<mirror> ...]\n";
sub download
{
sub download
{
@@
-56,10
+54,7
@@
sub cleanup
unlink "$target/$filename.md5sum";
}
unlink "$target/$filename.md5sum";
}
-while (!$ok) {
- my $mirror = shift @mirrors;
- $mirror or die "No more mirrors to try - giving up.\n";
-
+foreach my $mirror (@ARGV) {
if ($mirror =~ /^\@SF\/(.+)$/) {
my $sfpath = $1;
open SF, "wget -t1 -q -O- 'http://prdownloads.sf.net/$sfpath/$filename' |";
if ($mirror =~ /^\@SF\/(.+)$/) {
my $sfpath = $1;
open SF, "wget -t1 -q -O- 'http://prdownloads.sf.net/$sfpath/$filename' |";
@@
-70,8
+65,17
@@
while (!$ok) {
}
close SF;
} else {
}
close SF;
} else {
-
download($mirror)
;
+
push @mirrors, $mirror
;
}
}
+}
+
+push @mirrors, 'http://openwrt.inf.fh-brs.de/mirror';
+
+while (!$ok) {
+ my $mirror = shift @mirrors;
+ $mirror or die "No more mirrors to try - giving up.\n";
+
+ download($mirror);
-f "$target/$filename" and $ok = 1;
}
-f "$target/$filename" and $ok = 1;
}
This page took
0.026149 seconds
and
4
git commands to generate.