X-Git-Url: http://git.shadowcat.co.uk/gitweb/gitweb.cgi?a=blobdiff_plain;f=Makefile.PL;h=21082844226aba91c34339bbc09466c311d1d865;hb=42865691a20eb4d33df037c9677b9766126c98ec;hp=c739ef477b586b677df8932fce0b5bb2c17994de;hpb=97e41aa98026bf62907dfb9501643adfec4b3c75;p=gitmo%2FMoo.git diff --git a/Makefile.PL b/Makefile.PL index c739ef4..2108284 100644 --- a/Makefile.PL +++ b/Makefile.PL @@ -6,80 +6,97 @@ use ExtUtils::MakeMaker; check_conflicts(); (do 'maint/Makefile.PL.include' or die $@) unless -f 'META.yml'; +my %CONFIGURE_DEPS = ( + 'ExtUtils::MakeMaker' => 0, + 'Dist::CheckConflicts' => '0.02', +); my %BUILD_DEPS = (); my %TEST_DEPS = ( - 'Test::More' => 0.96, + 'Test::More' => 0.94, 'Test::Fatal' => 0.003, ); my %RUN_DEPS = ( - 'Class::Method::Modifiers' => 1.10, - 'strictures' => 1.004003, - 'Module::Runtime' => 0.012, - 'Role::Tiny' => 1.002004, - 'Devel::GlobalDestruction' => 0.11, + 'Class::Method::Modifiers' => 1.10, # for RT#80194 + 'strictures' => 1.004003, + 'Module::Runtime' => 0.012, # for RT#74789 + 'Role::Tiny' => 1.003002, + 'Devel::GlobalDestruction' => 0.11, # for RT#78617 + 'Dist::CheckConflicts' => 0.02, +); + +my %extra_info = ( + 'meta-spec' => { version => 2 }, + resources => { + repository => { + url => 'https://github.com/moose/Moo.git', + web => 'https://github.com/moose/Moo', + type => 'git', + }, + x_IRC => 'irc://irc.perl.org/#moose', + bugtracker => { + web => 'https://rt.cpan.org/Public/Dist/Display.html?Name=Moo', + mailto => 'bug-Moo@rt.cpan.org', + }, + license => [ 'http://dev.perl.org/licenses/' ], + }, + prereqs => { + configure => { requires => { %CONFIGURE_DEPS } }, + build => { requires => { %BUILD_DEPS } }, + test => { requires => { %TEST_DEPS } }, + runtime => { requires => { %RUN_DEPS, perl => '5.8.1' } }, + develop => { requires => { map { $_ => 0 } qw( + Class::XSAccessor + indirect multidimensional bareword::filehandles + Moose Mouse namespace::clean namespace::autoclean + MooseX::Types::Common::Numeric + ) } }, + }, ); # have to do this since old EUMM dev releases miss the eval $VERSION line -my $mymeta_works = do { no warnings; $ExtUtils::MakeMaker::VERSION >= 6.5707 }; -my $mymeta = do { no warnings; $ExtUtils::MakeMaker::VERSION >= 6.5702 }; +my $mymeta_works = do { no warnings; $ExtUtils::MakeMaker::VERSION >= 6.57_07 }; +my $mymeta = do { no warnings; $ExtUtils::MakeMaker::VERSION >= 6.57_02 }; my $has_test_requires = do { no warnings; $ExtUtils::MakeMaker::VERSION >= 6.63_03 }; -if (not $has_test_requires) -{ - %BUILD_DEPS = (%BUILD_DEPS, %TEST_DEPS); - %TEST_DEPS = (); -} +my $has_meta_v2 = do { no warnings; $ExtUtils::MakeMaker::VERSION >= 6.57_10 }; -my %extra_info = ( - resources => { - repository => 'git://git.shadowcat.co.uk/gitmo/Moo.git', - IRC => 'irc://irc.perl.org/#moose', - bugtracker => 'http://rt.cpan.org/NoAuth/Bugs.html?Dist=Moo', - license => 'http://dev.perl.org/licenses/', - } -); +if (! $has_meta_v2) { + %extra_info = (); +} +if (not $has_test_requires) { + %BUILD_DEPS = (%BUILD_DEPS, %TEST_DEPS); + %TEST_DEPS = (); +} +if (not $mymeta_works) { + %RUN_DEPS = (%RUN_DEPS, %BUILD_DEPS); + %BUILD_DEPS = (); +} WriteMakefile( NAME => 'Moo', VERSION_FROM => 'lib/Moo.pm', - CONFIGURE_REQUIRES => { - 'Dist::CheckConflicts' => '0.02', - }, + CONFIGURE_REQUIRES => \%CONFIGURE_DEPS, PREREQ_PM => { %RUN_DEPS, ($] >= 5.010 ? () : ('MRO::Compat' => 0)), - ($mymeta_works ? () : (%BUILD_DEPS)), - 'Dist::CheckConflicts' => '0.02', }, - ($mymeta_works - ? ( # BUILD_REQUIRES makes MYMETA right, requires stops META being wrong - BUILD_REQUIRES => \%BUILD_DEPS, - $has_test_requires ? ( TEST_REQUIRES => \%TEST_DEPS ) : (), - META_ADD => { requires => \%RUN_DEPS, %extra_info } - ) - : ( # META_ADD both to get META right - only Makefile written - META_ADD => { - requires => \%RUN_DEPS, - build_requires => \%BUILD_DEPS, - test_requires => \%TEST_DEPS, - %extra_info, - } - ) - ), + keys %BUILD_DEPS ? ( BUILD_REQUIRES => \%BUILD_DEPS ) : (), + keys %TEST_DEPS ? ( TEST_REQUIRES => \%TEST_DEPS ) : (), + META_ADD => \%extra_info, META_MERGE => { no_index => { directory => [ 'xt' ] }, - x_breaks => { - # enter conflicting data here, *and* in Moo::Conflicts - }, + Moo::Conflicts->can('conflicts') ? ( + x_breaks => { Moo::Conflicts->conflicts } + ) : (), }, ($mymeta && !$mymeta_works ? (NO_MYMETA => 1) : ()), LICENSE => 'perl', - 'EXE_FILES' => [ + EXE_FILES => [ 'bin/moo-outdated', ], ); @@ -108,6 +125,8 @@ sub check_conflicts { EOF } + return if $ENV{AUTOMATED_TESTING} || $ENV{NONINTERACTIVE_TESTING}; + # More or less copied from Module::Build return if $ENV{PERL_MM_USE_DEFAULT}; return unless -t STDIN && ( -t STDOUT || !( -f STDOUT || -c STDOUT ) );