projects
/
oweals
/
openwrt.git
/ commitdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
| commitdiff |
tree
raw
|
patch
|
inline
| side by side (parent:
bc08f6a
)
add multiple download mirrors
author
Ralph Hempel
<ralph.hempel@lantiq.com>
Fri, 20 Feb 2009 10:16:47 +0000
(10:16 +0000)
committer
Ralph Hempel
<ralph.hempel@lantiq.com>
Fri, 20 Feb 2009 10:16:47 +0000
(10:16 +0000)
SVN-Revision: 14573
scripts/download.pl
patch
|
blob
|
history
diff --git
a/scripts/download.pl
b/scripts/download.pl
index e63595497f79591a1e0b76fda80424cc11e7c429..56069469672fe3e0516e58494484c35f5fe8eca4 100755
(executable)
--- a/
scripts/download.pl
+++ b/
scripts/download.pl
@@
-32,7
+32,8
@@
sub localmirrors {
while (<CONFIG>) {
/^CONFIG_LOCALMIRROR="(.+)"/ and do {
chomp;
while (<CONFIG>) {
/^CONFIG_LOCALMIRROR="(.+)"/ and do {
chomp;
- push @mlist, $1;
+ my @local_mirrors = split(/;/, $1);
+ push @mlist, @local_mirrors;
};
}
close CONFIG;
};
}
close CONFIG;
@@
-65,9
+66,15
@@
sub download
if( $mirror =~ /^file:\/\// ) {
my $cache = $mirror;
$cache =~ s/file:\/\///g;
if( $mirror =~ /^file:\/\// ) {
my $cache = $mirror;
$cache =~ s/file:\/\///g;
- print "Checking local cache: $cache\n";
- system("mkdir -p $target/");
- system("cp -f $cache/$filename $target/$filename.dl") == 0 or return;
+ if(system("test -d $cache")) {
+ print STDERR "Wrong local cache directory -$cache-.\n";
+ cleanup();
+ return;
+ }
+ if(! -d $target) {
+ system("mkdir -p $target/");
+ }
+ system("cp -vf $cache/$filename $target/$filename.dl") == 0 or return;
system("$md5cmd $target/$filename.dl > \"$target/$filename.md5sum\" ") == 0 or return;
} else {
open WGET, "wget -t5 --timeout=20 $options -O- \"$mirror/$filename\" |" or die "Cannot launch wget.\n";
system("$md5cmd $target/$filename.dl > \"$target/$filename.md5sum\" ") == 0 or return;
} else {
open WGET, "wget -t5 --timeout=20 $options -O- \"$mirror/$filename\" |" or die "Cannot launch wget.\n";