diff options
-rw-r--r-- | urpm/get_pkgs.pm | 17 |
1 files changed, 13 insertions, 4 deletions
diff --git a/urpm/get_pkgs.pm b/urpm/get_pkgs.pm index 071a4dbe..e5a842ac 100644 --- a/urpm/get_pkgs.pm +++ b/urpm/get_pkgs.pm @@ -24,7 +24,7 @@ sub clean_all_cache { #- associated to a null list. sub selected2list { my ($urpm, $packages, %options) = @_; - my (%protected_files, %local_sources, %fullname2id); + my (%protected_files, %local_sources, %fullname2id, %id_map); #- build association hash to retrieve id and examine all list files. foreach (keys %$packages) { @@ -33,7 +33,16 @@ sub selected2list { my $file = $local_sources{$id} = $urpm->{source}{$id}; $protected_files{$file} = undef; } else { - $fullname2id{$urpm->{depslist}[$id]->fullname} = $id; + my $pkg = $urpm->{depslist}[$id]; + my $fullname = $pkg->fullname; + my @pkgs = map { $_->id } grep { $fullname eq $_->fullname } $urpm->packages_by_name($pkg->name); + + # id_map is a remapping of id. + # it is needed because @list must be [ { id => pkg } ] where id is one the selected id, + # not really the real package id + $id_map{$_} = $id foreach @pkgs; + + push @{$fullname2id{$fullname2id}}, @pkgs; } } } @@ -55,7 +64,7 @@ sub selected2list { } } - my @remaining_ids = sort { $a <=> $b } values %fullname2id; + my @remaining_ids = sort { $a <=> $b } map { @$_ } values %fullname2id; my @list = map { my $medium = $_; @@ -68,7 +77,7 @@ sub selected2list { my $pkg = $urpm->{depslist}[$id]; if ($pkg->filename !~ /\.delta\.rpm$/ || $urpm->is_delta_installable($pkg, $urpm->{root})) { - $sources{$id} = "$medium->{url}/" . $pkg->filename; + $sources{$id_map{$id}} = "$medium->{url}/" . $pkg->filename; } } } |