diff options
Diffstat (limited to 'urpm.pm')
-rw-r--r-- | urpm.pm | 96 |
1 files changed, 45 insertions, 51 deletions
@@ -270,16 +270,15 @@ sub probe_medium { unless ($medium->{url}) { my %probe; if (-r "$urpm->{statedir}/$medium->{list}") { - local *L; - open L, "$urpm->{statedir}/$medium->{list}"; - while (<L>) { + open my $listfile, "$urpm->{statedir}/$medium->{list}"; + while (<$listfile>) { #- /./ is end of url marker in list file (typically generated by a #- find . -name "*.rpm" > list #- for exportable list file. m|^(.*)/\./| and $probe{$1} = undef; m|^(.*)/[^/]*$| and $probe{$1} = undef; } - close L; + close $listfile; } foreach (sort { length($a) <=> length($b) } keys %probe) { if ($medium->{url}) { @@ -392,26 +391,25 @@ sub configure { my ($parallel_options, $parallel_handler); #- handle parallel configuration, examine all module available that #- will handle the parallel mode (configuration is /etc/urpmi/parallel.cfg). - local ($_, *PARALLEL); - open PARALLEL, "/etc/urpmi/parallel.cfg"; - while (<PARALLEL>) { + local $_; + open my $parallel, "/etc/urpmi/parallel.cfg"; + while (<$parallel>) { chomp; s/#.*$//; s/^\s*//; s/\s*$//; /\s*([^:]*):(.*)/ or $urpm->{error}(N("unable to parse \"%s\" in file [%s]", $_, "/etc/urpmi/parallel.cfg")), next; $1 eq $options{parallel} and $parallel_options = ($parallel_options && "\n") . $2; } - close PARALLEL; + close $parallel; #- if a configuration options has been found, use it else fatal error. if ($parallel_options) { foreach my $dir (grep { -d $_ } map { "$_/urpm" } @INC) { - local *DIR; - opendir DIR, $dir; - while ($_ = readdir DIR) { + opendir my $dh, $dir or die $!; + while ($_ = readdir $dh) { -f "$dir/$_" or next; $urpm->{log}->(N("examining parallel handler in file [%s]", "$dir/$_")); eval { require "$dir/$_"; $parallel_handler = $urpm->handle_parallel_options($parallel_options) }; $parallel_handler and last; } - closedir DIR; + closedir $dh; $parallel_handler and last; } } @@ -573,18 +571,17 @@ sub configure { my $sig_handler = sub { undef $db; exit 3 }; local $SIG{INT} = $sig_handler; local $SIG{QUIT} = $sig_handler; - local *RPMDB; $db or $urpm->{fatal}(9, N("unable to open rpmdb")); - open RPMDB, "| " . ($ENV{LD_LOADER} || '') . " gzip -9 >'$options{bug}/rpmdb.cz'"; + open my $rpmdb, "| " . ($ENV{LD_LOADER} || '') . " gzip -9 >'$options{bug}/rpmdb.cz'"; $db->traverse(sub { my ($p) = @_; #- this is not right but may be enough. my $files = join '@', grep { exists($urpm->{provides}{$_}) } $p->files; $p->pack_header; - $p->build_info(fileno *RPMDB, $files); + $p->build_info(fileno $rpmdb, $files); }); - close RPMDB; + close $rpmdb; } } @@ -719,10 +716,9 @@ sub add_distrib_media { #- at this point, we have found an hdlists file, so parse it #- and create all necessary media according to it. - local *HDLISTS; - if (open HDLISTS, $hdlists_file) { + if (open my $hdlistsfh, $hdlists_file) { my $medium = 1; - foreach (<HDLISTS>) { + foreach (<$hdlistsfh>) { chomp; s/\s*#.*$//; /^\s*$/ and next; @@ -736,7 +732,7 @@ sub add_distrib_media { ++$medium; } - close HDLISTS; + close $hdlistsfh; } else { $urpm->{error}(N("unable to access first installation medium (no hdlists file found)")), return; } @@ -1112,15 +1108,15 @@ this could happen if you mounted manually the directory when creating the medium } if ($medium->{md5sum}) { $urpm->{log}(N("examining MD5SUM file")); - local (*F, $_); - open F, reduce_pathname("$with_hdlist_dir/../MD5SUM"); - while (<F>) { + local $_; + open my $fh, reduce_pathname("$with_hdlist_dir/../MD5SUM"); + while (<$fh>) { my ($md5sum, $file) = m|(\S+)\s+(?:\./)?(\S+)| or next; #- keep md5sum got here to check download was ok ! so even if md5sum is not defined, we need #- to compute it, keep it in mind ;) $file eq $basename and $retrieved_md5sum = $md5sum; } - close F; + close $fh; #- If an existing hdlist or synthesis file has the same md5sum, we assume #- the files are the same. #- If the local md5sum is the same as the distant md5sum, this means @@ -1385,15 +1381,15 @@ this could happen if you mounted manually the directory when creating the medium } if ($medium->{md5sum}) { $urpm->{log}(N("examining MD5SUM file")); - local (*F, $_); - open F, "$urpm->{cachedir}/partial/MD5SUM"; - while (<F>) { + local $_; + open my $fh, "$urpm->{cachedir}/partial/MD5SUM"; + while (<$fh>) { my ($md5sum, $file) = m|(\S+)\s+(?:\./)?(\S+)| or next; #- keep md5sum got here to check download was ok ! so even if md5sum is not defined, we need #- to compute it, keep it in mind ;) $file eq $basename and $retrieved_md5sum = $md5sum; } - close F; + close $fh; #- if an existing hdlist or synthesis file has the same md5sum, we assume the #- file are the same. #- if local md5sum is the same as distant md5sum, this means there is no need to @@ -1680,14 +1676,14 @@ this could happen if you mounted manually the directory when creating the medium @unresolved_before == @unresolved_after or $second_pass = 1; if ($medium->{hdlist} ne 'list' && -s "$urpm->{cachedir}/partial/list") { - local (*F, $_); - open F, "$urpm->{cachedir}/partial/list"; - while (<F>) { + local $_; + open my $fh, "$urpm->{cachedir}/partial/list"; + while (<$fh>) { m|/([^/]*\.rpm)$| or next; $list{$1} and $urpm->{error}(N("file [%s] already used in the same medium \"%s\"", $1, $medium->{name})), next; $list{$1} = "$medium->{url}/$_"; } - close F; + close $fh; } else { #- if url is clear and no relative list file has been downloaded, #- there is no need for a list file. @@ -1704,14 +1700,13 @@ this could happen if you mounted manually the directory when creating the medium unless ($error) { if (%list) { #- write list file. - local *LIST; #- make sure group and other do not have any access to this file, used to hide passwords. my $mask = umask 077; - open LIST, ">$urpm->{cachedir}/partial/$medium->{list}" + open my $listfh, ">$urpm->{cachedir}/partial/$medium->{list}" or $error = 1, $urpm->{error}(N("unable to write list file of \"%s\"", $medium->{name})); umask $mask; - print LIST values %list; - close LIST; + print $listfh values %list; + close $listfh; #- check if at least something has been written into list file. if (-s "$urpm->{cachedir}/partial/$medium->{list}") { @@ -1867,13 +1862,13 @@ this could happen if you mounted manually the directory when creating the medium #- useful according to the depslist. if ($urpm->{modified}) { if ($options{noclean}) { - local (*D, $_); + local $_; my %headers; - opendir D, "$urpm->{cachedir}/headers"; - while (defined($_ = readdir D)) { + opendir my $dh, "$urpm->{cachedir}/headers"; + while (defined($_ = readdir $dh)) { m|^([^/]*-[^-]*-[^-]*\.[^\.]*)(?::\S*)?$| and $headers{$1} = $_; } - closedir D; + closedir $dh; $urpm->{log}(N("found %d headers in cache", scalar(keys %headers))); foreach (@{$urpm->{depslist}}) { delete $headers{$_->fullname}; @@ -1893,12 +1888,11 @@ this could happen if you mounted manually the directory when creating the medium foreach (@{$urpm->{media}}) { unlink "$urpm->{statedir}/names.$_->{name}"; if (defined $_->{start} && defined $_->{end}) { - local *F; - open F, ">$urpm->{statedir}/names.$_->{name}"; + open my $fh, ">$urpm->{statedir}/names.$_->{name}"; foreach ($_->{start} .. $_->{end}) { - print F $urpm->{depslist}[$_]->name."\n"; + print $fh $urpm->{depslist}[$_]->name."\n"; } - close F; + close $fh; } } @@ -2271,7 +2265,7 @@ sub get_packages_list { sub get_source_packages { my ($urpm, $packages, %options) = @_; my ($id, $error, @list_error, %protected_files, %local_sources, @list, %fullname2id, %file2fullnames, %examined); - local (*D, *F, $_); + local $_; #- build association hash to retrieve id and examine all list files. foreach (keys %$packages) { @@ -2290,8 +2284,8 @@ sub get_source_packages { } #- examine the local repository, which is trusted (no gpg or pgp signature check but md5 is now done). - opendir D, "$urpm->{cachedir}/rpms"; - while (defined($_ = readdir D)) { + opendir my $dh, "$urpm->{cachedir}/rpms"; + while (defined($_ = readdir $dh)) { if (my ($filename) = m|^([^/]*\.rpm)$|) { my $filepath = "$urpm->{cachedir}/rpms/$filename"; if (!$options{clean_all} && -s $filepath) { @@ -2314,7 +2308,7 @@ sub get_source_packages { } } #- no error on unknown filename located in cache (because .listing) inherited from old urpmi } - closedir D; + closedir $dh; #- clean download directory, do it here even if this is not the best moment. if ($options{clean_all}) { @@ -2336,8 +2330,8 @@ sub get_source_packages { -s $file or $file = "$dir/list"; } if ($file && -r $file) { - open F, $file; - while (<F>) { + open my $fh, $file or die $!; + while (<$fh>) { if (my ($filename) = m|/([^/]*\.rpm)$|) { if (keys(%{$file2fullnames{$filename} || {}}) > 1) { $urpm->{error}(N("there are multiple packages with the same rpm filename \"%s\""), $filename); @@ -2355,7 +2349,7 @@ sub get_source_packages { last; } } - close F; + close $fh; } elsif ($file && -e $file) { # list file exists but isn't readable # report error only if no result found, list files are only readable by root |