summaryrefslogtreecommitdiffstats
path: root/urpm.pm
diff options
context:
space:
mode:
authorOlivier Thauvin <nanardon@mandriva.org>2004-01-13 01:00:14 +0000
committerOlivier Thauvin <nanardon@mandriva.org>2004-01-13 01:00:14 +0000
commit4e17a6dee03f78e739cdf85d482dd1a2677d54cc (patch)
tree2a88aa22737f21d96db78d9db9de65a90fe059d4 /urpm.pm
parentc80509f5785b7f53c18f3b823648f96ced2c7b24 (diff)
downloadurpmi-4e17a6dee03f78e739cdf85d482dd1a2677d54cc.tar
urpmi-4e17a6dee03f78e739cdf85d482dd1a2677d54cc.tar.gz
urpmi-4e17a6dee03f78e739cdf85d482dd1a2677d54cc.tar.bz2
urpmi-4e17a6dee03f78e739cdf85d482dd1a2677d54cc.tar.xz
urpmi-4e17a6dee03f78e739cdf85d482dd1a2677d54cc.zip
- fix urpmq for virtual medium
- apply blino's patch: - permit urpmq -i for user - fix urpmq --sources for user (don't give a wrong url) - fix urpme --root
Diffstat (limited to 'urpm.pm')
-rw-r--r--urpm.pm12
1 files changed, 10 insertions, 2 deletions
diff --git a/urpm.pm b/urpm.pm
index bc0ce9ca..8c3e9dca 100644
--- a/urpm.pm
+++ b/urpm.pm
@@ -1770,7 +1770,6 @@ this could happen if you mounted manually the directory when creating the medium
$urpm->{error}(N("no hdlist file found for medium \"%s\"", $medium->{name}));
}
- #- make sure group and other does not have any access to this file.
unless ($error || $medium->{virtual}) {
#- sort list file contents according to id.
my %list;
@@ -1852,6 +1851,7 @@ this could happen if you mounted manually the directory when creating the medium
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}"
or $error = 1, $urpm->{error}(N("unable to write list file of \"%s\"", $medium->{name}));
@@ -2532,7 +2532,7 @@ sub get_unwanted_packages {
#- have a null list.
sub get_source_packages {
my ($urpm, $packages, %options) = @_;
- my ($id, $error, %protected_files, %local_sources, @list, %fullname2id, %file2fullnames, %examined);
+ my ($id, $error, @list_error, %protected_files, %local_sources, @list, %fullname2id, %file2fullnames, %examined);
local (*D, *F, $_);
#- build association hash to retrieve id and examine all list files.
@@ -2618,6 +2618,11 @@ sub get_source_packages {
}
}
close F;
+ } elsif (-e $file) {
+ # list file exists but isn't readable
+ # report error only if no result found, list files are only readable by root
+ push @list_error, N("unable to access list file of \"%s\", medium ignored", $medium->{name});
+ next;
}
if (defined $medium->{url}) {
foreach ($medium->{start} .. $medium->{end}) {
@@ -2647,6 +2652,9 @@ sub get_source_packages {
#- examine package list to see if a package has not been found.
foreach (grep { ! exists($examined{$_}) } keys %fullname2id) {
+ # print list errors only once if any
+ @list_error and map { $urpm->{error}($_) } @list_error;
+ @list_error = ();
$error = 1;
$urpm->{error}(N("package %s is not found.", $_));
}