summaryrefslogtreecommitdiffstats
path: root/urpm/removable.pm
diff options
context:
space:
mode:
Diffstat (limited to 'urpm/removable.pm')
-rw-r--r--urpm/removable.pm39
1 files changed, 20 insertions, 19 deletions
diff --git a/urpm/removable.pm b/urpm/removable.pm
index 19081f7b..cae0acaa 100644
--- a/urpm/removable.pm
+++ b/urpm/removable.pm
@@ -6,7 +6,7 @@ use urpm::msg;
use urpm::sys;
use urpm::util;
use urpm::get_pkgs;
-use urpm 'file_from_local_url', 'is_local_medium';
+use urpm 'file_from_local_medium', 'is_local_medium';
@@ -102,20 +102,20 @@ sub try_umounting_removables {
#- side-effects:
#- + those of try_mounting_ ($urpm->{removable_mounted}, "mount")
sub _mount_and_check_notfound {
- my ($urpm, $medium_list, $dir) = @_;
+ my ($urpm, $blist, $dir) = @_;
try_mounting_($urpm, $dir);
-e $dir or return 2;
- _check_notfound($medium_list);
+ _check_notfound($blist);
}
#- side-effects: none
sub _check_notfound {
- my ($medium_list) = @_;
+ my ($blist) = @_;
- foreach (values %$medium_list) {
- my $dir_ = _filepath($_) or next;
+ foreach (values %{$blist->{list}}) {
+ my $dir_ = _filepath($blist->{medium}, $_) or next;
-r $dir_ or return 1;
}
0;
@@ -132,7 +132,7 @@ sub _examine_removable_medium {
my $medium = $blist->{medium};
if (is_local_medium($medium)) {
- _examine_removable_medium_($urpm, $medium, $blist->{list}, $sources, $o_ask_for_medium);
+ _examine_removable_medium_($urpm, $blist, $sources, $o_ask_for_medium);
} else {
#- we have a removable device that is not removable, well...
$urpm->{error}(N("inconsistent medium \"%s\" marked removable but not really", $medium->{name}));
@@ -143,14 +143,15 @@ sub _examine_removable_medium {
#- + those of _mount_and_check_notfound ($urpm->{removable_mounted}, "mount")
#- + those of try_umounting ($urpm->{removable_mounted}, "umount")
sub _mount_it {
- my ($urpm, $medium, $medium_list, $o_ask_for_medium) = @_;
+ my ($urpm, $blist, $o_ask_for_medium) = @_;
+ my $medium = $blist->{medium};
- my $dir = file_from_local_url($medium->{url});
+ my $dir = file_from_local_medium($medium);
#- the directory given does not exist and may be accessible
#- by mounting some other directory. Try to figure it out and mount
#- everything that might be necessary.
- while (_mount_and_check_notfound($urpm, $medium_list, $dir)) {
+ while (_mount_and_check_notfound($urpm, $blist, $dir)) {
$o_ask_for_medium
or $urpm->{fatal}(4, N("medium \"%s\" is not available", $medium->{name}));
@@ -166,10 +167,10 @@ sub _mount_it {
#- side-effects: none
sub _filepath {
- my ($url) = @_;
+ my ($medium, $url) = @_;
chomp $url;
- my $filepath = file_from_local_url($url) or return;
+ my $filepath = file_from_local_medium($medium, $url) or return;
$filepath =~ m!/.*/! or return; #- is this really needed??
$filepath;
}
@@ -195,18 +196,18 @@ sub _do_the_copy {
#- + those of _mount_it ($urpm->{removable_mounted}, "mount", "umount", "eject")
#- + those of _do_the_copy: "copy-move-files"
sub _examine_removable_medium_ {
- my ($urpm, $medium, $medium_list, $sources, $o_ask_for_medium) = @_;
+ my ($urpm, $blist, $sources, $o_ask_for_medium) = @_;
- my $dir = _mount_it($urpm, $medium, $medium_list, $o_ask_for_medium);
+ my $dir = _mount_it($urpm, $blist, $o_ask_for_medium);
- while (my ($i, $url) = each %$medium_list) {
- my $filepath = _filepath($url) or next;
+ while (my ($i, $url) = each %{$blist->{list}}) {
+ my $filepath = _filepath($blist->{medium}, $url) or next;
if (my $rpm = _do_the_copy($urpm, $filepath)) {
$sources->{$i} = $rpm;
} else {
#- fallback to use other method for retrieving the file later.
- $urpm->{error}(N("unable to read rpm file [%s] from medium \"%s\"", $filepath, $medium->{name}));
+ $urpm->{error}(N("unable to read rpm file [%s] from medium \"%s\"", $filepath, $blist->{medium}{name}));
}
}
}
@@ -228,7 +229,7 @@ sub try_mounting_non_cdroms {
sub try_mounting_non_cdrom {
my ($urpm, $medium) = @_;
- my $dir = file_from_local_url($medium->{url}) or return;
+ my $dir = file_from_local_medium($medium) or return;
-e $dir || try_mounting($urpm, $dir, $medium->{iso}) or
$urpm->{error}(N("unable to access medium \"%s\"", $medium->{name})), return;
@@ -273,7 +274,7 @@ sub _sort_media {
@l = sort { values(%{$a->{list}}) <=> values(%{$b->{list}}) } @l;
#- check if a removable device is already mounted (and files present).
- if (my ($already_mounted) = grep { !_check_notfound($_->{list}) } @l) {
+ if (my ($already_mounted) = grep { !_check_notfound($_) } @l) {
@l = ($already_mounted, grep { $_ != $already_mounted } @l);
}
}