[carton] 104/472: Use CPAN::Meta to always convert MYMETA to version 2.

Lucas Kanashiro kanashiro-guest at moszumanska.debian.org
Fri Jul 24 00:38:37 UTC 2015


This is an automated email from the git hooks/post-receive script.

kanashiro-guest pushed a commit to branch master
in repository carton.

commit d3abbd70a27f9d0e190e91a50bdb78d0fe7c8ed8
Author: Tatsuhiko Miyagawa <miyagawa at bulknews.net>
Date:   Thu Oct 13 10:13:32 2011 +0900

    Use CPAN::Meta to always convert MYMETA to version 2.
    
    Fixed the build_index/tree to work with the new install.json/MYMETA
---
 lib/Carton.pm | 43 ++++++++++++++++++++++++++++---------------
 1 file changed, 28 insertions(+), 15 deletions(-)

diff --git a/lib/Carton.pm b/lib/Carton.pm
index a8a3867..97f0959 100644
--- a/lib/Carton.pm
+++ b/lib/Carton.pm
@@ -9,6 +9,7 @@ use Cwd;
 use Config qw(%Config);
 use Carton::Config;
 use Carton::Util;
+use CPAN::Meta;
 use File::Path;
 
 use constant CARTON_LOCK_VERSION => '0.9';
@@ -162,11 +163,9 @@ sub build_index {
 
     my $index;
 
-    for my $name (keys %$modules) {
-        my $metadata = $modules->{$name};
-        my $provides = $metadata->{provides};
-        for my $mod (keys %$provides) {
-            $index->{$mod} = { version => $provides->{$mod}, meta => $metadata };
+    while (my($name, $metadata) = each %$modules) {
+        for my $mod (keys %{$metadata->{provides}}) {
+            $index->{$mod} = { %{$metadata->{provides}{$mod}}, meta => $metadata };
         }
     }
 
@@ -235,18 +234,29 @@ sub _build_tree {
     }
 }
 
+sub merge_prereqs {
+    my($self, $prereqs) = @_;
+
+    my %requires;
+    for my $phase (qw( configure build test runtime )) {
+        %requires = (%requires, %{$prereqs->{$phase}{requires} || {}});
+    }
+
+    return \%requires;
+}
+
 sub build_deps {
     my($self, $meta, $idx) = @_;
 
+    my $requires = $self->merge_prereqs($meta->{mymeta}{prereqs});
+
     my @deps;
-    for my $requires (values %{$meta->{requires}}) {
-        for my $module (keys %$requires) {
-            next if $module eq 'perl';
-            if (exists $idx->{$module}) {
-                push @deps, $idx->{$module}{meta}{name};
-            } else {
-                push @deps, $module;
-            }
+    for my $module (keys %$requires) {
+        next if $module eq 'perl';
+        if (exists $idx->{$module}) {
+            push @deps, $idx->{$module}{meta}{name};
+        } else {
+            push @deps, $module;
         }
     }
 
@@ -304,12 +314,15 @@ sub find_installs {
     my @installs;
     my $wanted = sub {
         if ($_ eq 'install.json') {
-            push @installs, $File::Find::name;
+            push @installs, [ $File::Find::name, "$File::Find::dir/MYMETA.json" ];
         }
     };
     File::Find::find($wanted, $libdir);
 
-    return map { my $module = Carton::Util::load_json($_); ($module->{name} => $module) } @installs;
+    return map {
+        my $module = Carton::Util::load_json($_->[0]);
+        my $mymeta = CPAN::Meta->load_file($_->[1])->as_struct({ version => "2" });
+        ($module->{name} => { %$module, mymeta => $mymeta }) } @installs;
 }
 
 sub check_satisfies {

-- 
Alioth's /usr/local/bin/git-commit-notice on /srv/git.debian.org/git/pkg-perl/packages/carton.git



More information about the Pkg-perl-cvs-commits mailing list