From 6329fc761cd5bb9b8fe8ce2a475f23459cfd30a6 Mon Sep 17 00:00:00 2001 From: Pascal Rigaux Date: Fri, 27 Apr 2007 12:30:47 +0000 Subject: re-sync after the big svn loss --- URPM.pm | 35 ++++++++++++++++++++++++----------- 1 file changed, 24 insertions(+), 11 deletions(-) diff --git a/URPM.pm b/URPM.pm index 3ac5207..da97f46 100644 --- a/URPM.pm +++ b/URPM.pm @@ -10,7 +10,7 @@ use URPM::Resolve; use URPM::Signature; our @ISA = qw(DynaLoader); -our $VERSION = '1.59'; +our $VERSION = '1.60'; URPM->bootstrap($VERSION); @@ -26,6 +26,16 @@ sub new { sub set_nofatal { $_[0]{nofatal} = $_[1] } +sub packages_providing { + my ($urpm, $name) = @_; + map { $urpm->{depslist}[$_] } keys %{$urpm->{provides}{$name} || {}}; +} + +sub packages_by_name { + my ($urpm, $name) = @_; + grep { $name eq $_->name } packages_providing($urpm, $name); +} + sub search { my ($urpm, $name, %options) = @_; my $best; @@ -33,15 +43,13 @@ sub search { #- tries other alternative if no strict searching. unless ($options{strict_name}) { if ($name =~ /^(.*)-([^\-]*)-([^\-]*)\.([^\.\-]*)$/) { - foreach (keys %{$urpm->{provides}{$1} || {}}) { - my $pkg = $urpm->{depslist}[$_]; + foreach my $pkg (packages_providing($urpm, $1)) { $pkg->fullname eq $name and return $pkg; } } unless ($options{strict_fullname}) { if ($name =~ /^(.*)-([^\-]*)-([^\-]*)$/) { - foreach (keys %{$urpm->{provides}{$1} || {}}) { - my $pkg = $urpm->{depslist}[$_]; + foreach my $pkg (packages_providing($urpm, $1)) { my ($n, $v, $r, $a) = $pkg->fullname; $options{src} && $a eq 'src' || $pkg->is_arch_compat or next; "$n-$v-$r" eq $name or next; @@ -50,8 +58,7 @@ sub search { $best and return $best; } if ($name =~ /^(.*)-([^\-]*)$/) { - foreach (keys %{$urpm->{provides}{$1} || {}}) { - my $pkg = $urpm->{depslist}[$_]; + foreach my $pkg (packages_providing($urpm, $1)) { my ($n, $v, undef, $a) = $pkg->fullname; $options{src} && $a eq 'src' || $pkg->is_arch_compat or next; "$n-$v" eq $name or next; @@ -63,8 +70,7 @@ sub search { } unless ($options{strict_fullname}) { - foreach (keys %{$urpm->{provides}{$name} || {}}) { - my $pkg = $urpm->{depslist}[$_]; + foreach my $pkg (packages_providing($urpm, $name)) { my ($n, undef, undef, $a) = $pkg->fullname; $options{src} && $a eq 'src' || $pkg->is_arch_compat or next; $n eq $name or next; @@ -105,8 +111,7 @@ sub traverse_tag { if (@{$names || []}) { if ($tag eq 'name') { foreach my $n (@$names) { - foreach (keys %{$urpm->{provides}{$n} || {}}) { - my $p = $urpm->{depslist}[$_]; + foreach my $p (packages_providing($urpm, $n)) { $p->name eq $n or next; $callback and $callback->($p); ++$count; @@ -321,6 +326,14 @@ and adds them to the URPM object. Allowed options are If C isn't specified, URPM will drop all memory-consuming tags (notably changelogs, filelists, scriptlets). +=item $urpm->packages_providing($name) + +Returns a list of C providing <$name> + +=item $urpm->packages_by_name($name) + +Returns a list of C corresponding to the wanted <$name> + =item $urpm->search($name, %options) Search an RPM by name or by part of name in the list of RPMs represented by -- cgit v1.2.1