X-Git-Url: http://git.vpit.fr/?a=blobdiff_plain;f=lib%2FCPANPLUS%2FDist%2FGentoo.pm;h=a753ab4048f3dbaccf7fb7e5f7ad7074bb0c55f3;hb=00e09b5e966914ebedb5c08927cf5a66af177171;hp=297a15d1eb33ca1ae932b56aae109447848b9770;hpb=689888cc60d6c3f0bdca8a2b61605d56cf9c7c8a;p=perl%2Fmodules%2FCPANPLUS-Dist-Gentoo.git diff --git a/lib/CPANPLUS/Dist/Gentoo.pm b/lib/CPANPLUS/Dist/Gentoo.pm index 297a15d..a753ab4 100644 --- a/lib/CPANPLUS/Dist/Gentoo.pm +++ b/lib/CPANPLUS/Dist/Gentoo.pm @@ -16,6 +16,7 @@ use CPANPLUS::Error (); use base qw/CPANPLUS::Dist::Base/; +use CPANPLUS::Dist::Gentoo::Atom; use CPANPLUS::Dist::Gentoo::Maps; =head1 NAME @@ -190,7 +191,7 @@ sub init { my $conf = $self->parent->parent->configure_object; $stat->mk_accessors(qw/name version author distribution desc uri src license - fetched_arch deps + fetched_arch requires ebuild_name ebuild_version ebuild_dir ebuild_file portdir_overlay overlay distdir keywords do_manifest header footer @@ -338,8 +339,8 @@ sub prepare { $stat->license($self->intuit_license); - my $prereqs = $mod->status->prereqs; - my @depends; + my $prereqs = $mod->status->requires; + my @requires; for my $prereq (sort keys %$prereqs) { next if $prereq =~ /^perl(?:-|\z)/; my $obj = $int->module_tree($prereq); @@ -354,10 +355,10 @@ sub prepare { $version = $obj->package_version; } } - push @depends, [ $obj->package_name, $version ]; + push @requires, [ $obj->package_name, $version ]; } } - $stat->deps(\@depends); + $stat->requires(\@requires); return $OK->(); } @@ -510,8 +511,8 @@ sub ebuild_source { # We must resolve the deps now and not inside prepare because _cpan2portage # has to see the ebuilds already generated for the dependencies of the current # dist. - my @deps; - for (@{$stat->deps}) { + my @requires; + for (@{$stat->requires}) { my $dep = $self->_cpan2portage(@$_); unless (defined $dep) { $self->_abort( @@ -519,10 +520,10 @@ sub ebuild_source { ); return; } - push @deps, $dep; + push @requires, $dep; } - @deps = do { my %seen; sort grep !$seen{$_}++, 'dev-lang/perl', @deps }; + @requires = do { my %seen; sort grep !$seen{$_}++, 'dev-lang/perl',@requires }; my $d = $stat->header; $d .= "# Generated by CPANPLUS::Dist::Gentoo version $VERSION\n\n"; @@ -534,7 +535,7 @@ sub ebuild_source { $d .= "SLOT=\"0\"\n"; $d .= 'LICENSE="|| ( ' . join(' ', sort @{$stat->license}) . " )\"\n"; $d .= 'KEYWORDS="' . join(' ', sort @{$stat->keywords}) . "\"\n"; - $d .= 'RDEPEND="' . join("\n", @deps) . "\"\n"; + $d .= 'RDEPEND="' . join("\n", @requires) . "\"\n"; $d .= "DEPEND=\"\${RDEPEND}\"\n"; $d .= "SRC_TEST=\"do\"\n"; $d .= $stat->footer; @@ -562,14 +563,13 @@ sub _cpan2portage { "$atom-*.ebuild", ) or next; - my $last = reduce { - CPANPLUS::Dist::Gentoo::Maps::version_gcmp($b->[1], $a->[1]) >= 0 ? $b : $a - } map [ $_, /\Q$atom\E-v?([\d._pr-]+).*?\.ebuild$/ ? $1 : 0 ], @ebuilds; + my $last = reduce { $a->[1] < $b->[1] ? $b : $a } + map [ $_, CPANPLUS::Dist::Gentoo::Atom->new(ebuild => $_) ], + @ebuilds; my $dep; if (defined $ver) { # implies that $version is defined - next unless - CPANPLUS::Dist::Gentoo::Maps::version_gcmp($last->[1], $ver) >= 0; + next if $last < $ver; $dep = ">=$category/$atom-$ver"; } else { $dep = "$category/$atom";