summaryrefslogtreecommitdiffstats
path: root/urpm/download.pm
diff options
context:
space:
mode:
Diffstat (limited to 'urpm/download.pm')
-rw-r--r--urpm/download.pm59
1 files changed, 29 insertions, 30 deletions
diff --git a/urpm/download.pm b/urpm/download.pm
index 70e7e98d..ccb7b157 100644
--- a/urpm/download.pm
+++ b/urpm/download.pm
@@ -104,7 +104,7 @@ sub remove_proxy_media {
}
sub get_proxy_ {
- my ($urpm, $medium) = @_;
+ my ($urpm, $_medium) = @_;
-e $PROXY_CFG && !-r $PROXY_CFG and $urpm->{error}(N("can not read proxy settings (not enough rights to read %s)", $PROXY_CFG));
@@ -609,12 +609,12 @@ sub sync_aria2 {
#- force download to be done in cachedir to avoid polluting cwd.
(my $cwd) = getcwd() =~ /(.*)/;
chdir $options->{dir};
- my ($buf, $total, $file) = ('', undef, undef);
+ my ($buf, $_total, $file) = ('', undef, undef);
my @files;
- for(my $i = 0; $i < @_; $i++){
- my $metalinkfile = @_[$i];
+ for (my $i = 0; $i < @_; $i++) {
+ my $metalinkfile = $_[$i];
$metalinkfile =~ s/metalink:.*/metalink/;
- if ( not grep { $_ eq $metalinkfile } @files){
+ if (! grep { $_ eq $metalinkfile } @files) {
push(@files, $metalinkfile);
}
}
@@ -635,20 +635,20 @@ sub sync_aria2 {
$options->{debug} and $options->{debug}($aria2c_command);
- my $aria2_pid = open (my $aria2, "$aria2c_command |");
+ my $aria2_pid = open(my $aria2, "$aria2c_command |");
local $/ = \1; #- read input by only one char, this is slow but very nice (and it works!).
local $_;
- while(<$aria2>) {
- $buf .= "$_";
+ while (<$aria2>) {
+ $buf .= $_;
if ($_ eq "\r" || $_ eq "\n") {
if ($options->{callback}) {
- if (! defined $file and @_) {
+ if (!defined($file) && @_) {
$file = shift @_;
propagate_sync_callback($options, 'start', $file);
}
- if ($buf =~ /^\[\#\d*\s+\S+:([\d\.]+\w*).([\d\.]+\w*)\S([\d]+)\S+\s+\S+\s*([\d\.]+)\s\w*:([\d\.]+\w*\/\w)\s\w*:([\d]+\w*)\][\r\n]$/) {
+ if ($buf =~ m!^\[#\d*\s+\S+:([\d\.]+\w*).([\d\.]+\w*)\S([\d]+)\S+\s+\S+\s*([\d\.]+)\s\w*:([\d\.]+\w*/\w)\s\w*:(\d+\w*)\][\r\n]$!) {
my ($total, $percent, $speed, $eta) = ($2, $3, $5, $6);
#- $1 = current downloaded size, $4 = connections
if (propagate_sync_callback($options, 'progress', $file, $percent, $total, $eta, $speed) eq 'canceled') {
@@ -657,7 +657,7 @@ sub sync_aria2 {
return;
}
}
- if ($buf =~ /Download\scomplete:\s\.\//) {
+ if ($buf =~ m!Download\scomplete:\s\./!) {
propagate_sync_callback($options, 'end', $file);
$file = undef;
} elsif ($buf =~ /ERR\|/) {
@@ -800,7 +800,7 @@ sub get_content {
my @l = cat_($file);
unlink $file;
- wantarray ? @l : join('', @l);
+ wantarray() ? @l : join('', @l);
}
@@ -841,7 +841,7 @@ sub _sync_webfetch_raw {
my @l = (@{$files{ftp} || []}, @{$files{http} || []}, @{$files{https} || []});
# FIXME: This is rather crude and should probably be done some better place.
- if($options->{metalink}){
+ if ($options->{metalink}) {
_create_metalink_($urpm, \@l, $options);
}
while (@l) {
@@ -869,46 +869,45 @@ sub _sync_webfetch_raw {
sub _create_metalink_ {
my ($urpm, $files, $options) = @_;
# Don't create a metalink when downloading mirror list
- if(! $options->{media}){
+ if (! $options->{media}) {
return;
}
my $mirrors;
- foreach my $medium (@{$urpm->{media} || []}){
- if($medium->{name} eq $options->{media}){
+ foreach my $medium (@{$urpm->{media} || []}) {
+ if ($medium->{name} eq $options->{media}) {
my $mirrorlist = $medium->{mirrorlist};
- $mirrors = $urpm->{mirrors_cache}->{$mirrorlist};
+ $mirrors = $urpm->{mirrors_cache}{$mirrorlist};
}
}
my $metalinkfile = "$urpm->{cachedir}/$options->{media}.metalink";
# Even if not required by metalink spec, this line is needed at top of
# metalink file, otherwise aria2 won't be able to autodetect it..
- my $metalink = "<?xml version=\"1.0\" encoding=\"utf-8\"?>\n";
- $metalink .= "<metalink version=\"3.0\" generator=\"URPMI\"\n";
- $metalink .= "xmlns=\"http://www.metalinker.org/\">\n";
- $metalink .= "<files>\n";
+ my $metalink = qq(<?xml version="1.0" encoding="utf-8"?>\n);
+ $metalink .= qq(<metalink version="3.0" generator="URPMI"\n);
+ $metalink .= qq(xmlns="http://www.metalinker.org/">\n);
+ $metalink .= qq(<files>\n);
foreach my $append (@$files) {
$append =~ s/$mirrors->{chosen}//;
- $metalink .= "\t<file name=\"".basename($append)."\">\n";
- $metalink .= "\t\t<resources>\n";
+ $metalink .= qq(\t<file name=") . basename($append) . qq(">\n);
+ $metalink .= qq(\t\t<resources>\n);
my $i = 0; foreach my $mirror (@{$mirrors->{list}}) { $i++;
my $type = $mirror->{url};
- $type =~ s/:\/\/.*//;
- my $preference = 100-$i;
+ $type =~ s!://.*!!;
# If more than 100 mirrors, give all the remaining mirrors a priority of 0
my $preference = max(0, 100 - $i);
- $metalink .= "\t\t\t<url type=\"$type\" preference=\"$preference\"";
+ $metalink .= qq(\t\t\t<url type="$type" preference="$preference");
# Not supported in metalinks
- #if(@$list[$i]->{bw}){
+ #if (@$list[$i]->{bw}) {
# $metalink .= " bandwidth=\"".@$list[$i]->{bw}."\" ";
# }
# Supported in metalinks, but no longer used in mirror list..?
- if($mirror->{connections}){
- $metalink .= " maxconnections=\"".$mirror->{connections}."\"";
+ if ($mirror->{connections}) {
+ $metalink .= qq( maxconnections=") . $mirror->{connections} . qq(");
}
- $metalink .= " location=\"".lc($mirror->{zone})."\">".$mirror->{url}.$append."</url>\n";
+ $metalink .= qq( location=") . lc($mirror->{zone}) . qq(">) . $mirror->{url} . $append . "</url>\n";
}
$metalink .= "\t\t</resources>\n";
$metalink .= "\t</file>\n";