X-Git-Url: http://git.shadowcat.co.uk/gitweb/gitweb.cgi?a=blobdiff_plain;f=Makefile.PL;h=9002eabadb669166e14bb87e3bef8e199e038524;hb=HEAD;hp=7c80f4c6b1203f69c560ee02386b201a189accb9;hpb=bfbeb6fd919a8d504c82e743d8c3483cddc9869c;p=p5sagit%2Fstrictures.git diff --git a/Makefile.PL b/Makefile.PL index 7c80f4c..9002eab 100644 --- a/Makefile.PL +++ b/Makefile.PL @@ -1,35 +1,142 @@ use strict; use warnings FATAL => 'all'; -use ExtUtils::MakeMaker; +use 5.006; +use lib 'inc'; +use ExtUtils::HasCompiler 'can_compile_loadable_object'; -(do 'maint/Makefile.PL.include' or die $@) unless -f 'META.yml'; +my $want_pp = parse_args()->{PUREPERL_ONLY}; +my $should_xs + = defined $want_pp ? $want_pp : can_compile_loadable_object(quiet => 1); -WriteMakefile( - NAME => 'strictures', - VERSION_FROM => 'lib/strictures.pm', - MIN_PERL_VERSION => '5.006', - - META_MERGE => { - 'meta-spec' => { version => 2 }, - dynamic_config => 0, +my %extra_prereqs = ( + indirect => 0, + multidimensional => 0, + 'bareword::filehandles' => 0, +); - resources => { - # r/w: p5sagit@git.shadowcat.co.uk:strictures.git - repository => { - url => 'git://git.shadowcat.co.uk/p5sagit/strictures.git', - web => 'http://git.shadowcat.co.uk/gitweb/gitweb.cgi?p=p5sagit/strictures.git', - type => 'git', +my %META = ( + name => 'strictures', + license => [ 'perl_5' ], + dynamic_config => 1, + prereqs => { + configure => { requires => { } }, + build => { requires => { } }, + test => { requires => { + 'Test::More' => 0, + } }, + runtime => { + requires => { + perl => '5.006', }, - bugtracker => { - mailto => 'bug-strictures@rt.cpan.org', - web => 'https://rt.cpan.org/Public/Dist/Display.html?Name=strictures', + suggests => { + %extra_prereqs, }, }, - - recommends => { - indirect => 0, - multidimensional => 0, - 'bareword::filehandles' => 0, + develop => { requires => { + 'Test::Pod' => 0, + 'Test::Pod::Coverage::TrustMe' => 0, + %extra_prereqs, + } }, + }, + resources => { + # GitHub mirrors from Shadowcat. We list it so we can get pull requests. + # The canonical repo is: + # r/o: git://git.shadowcat.co.uk/p5sagit/strictures.git + # r/w: p5sagit@git.shadowcat.co.uk:strictures.git + # web: http://git.shadowcat.co.uk/gitweb/gitweb.cgi?p=p5sagit/strictures.git + repository => { + url => 'https://github.com/p5sagit/strictures.git', + web => 'https://github.com/p5sagit/strictures', + type => 'git', + }, + bugtracker => { + mailto => 'bug-strictures@rt.cpan.org', + web => 'https://rt.cpan.org/Public/Dist/Display.html?Name=strictures', }, + license => [ 'http://dev.perl.org/licenses/' ], + }, + no_index => { + directory => [ 't', 'xt', 'inc' ] + }, + x_authority => 'cpan:MSTROUT', + x_contributors => [ # manually added, from git shortlog -e -s -n + 'Graham Knop ', + 'Karen Etheridge ', + 'Matt S Trout ', + 'Peter Rabbitson ', + 'Christian Walde ', + 'Diab Jerius ', + ], +); + +my %MM_ARGS = ( + PREREQ_PM => { + ("$]" >= 5.008004 && $should_xs ? %extra_prereqs : () ) }, ); + +sub parse_args { + # copied from EUMM + require ExtUtils::MakeMaker; + require Text::ParseWords; + ExtUtils::MakeMaker::parse_args( + my $tmp = {}, + Text::ParseWords::shellwords($ENV{PERL_MM_OPT} || ''), + @ARGV, + ); + return $tmp->{ARGS} || {}; +} + +## BOILERPLATE ############################################################### +require ExtUtils::MakeMaker; +(do './maint/Makefile.PL.include' or die $@) unless -f 'META.yml'; + +# have to do this since old EUMM dev releases miss the eval $VERSION line +my $eumm_version = $ExtUtils::MakeMaker::VERSION; +$eumm_version =~ tr/_//d; +my $mymeta = $eumm_version >= 6.57_02; +my $mymeta_broken = $mymeta && $eumm_version < 6.57_07; + +( $MM_ARGS{NAME} = $META{name} ) =~ s/-/::/g + if !$MM_ARGS{NAME}; +( $MM_ARGS{VERSION_FROM} = "lib/$MM_ARGS{NAME}.pm" ) =~ s{::}{/}g + if !$MM_ARGS{VERSION} && $MM_ARGS{VERSION_FROM}; +$MM_ARGS{ABSTRACT_FROM} ||= $MM_ARGS{VERSION_FROM} + if !$MM_ARGS{ABSTRACT}; +$MM_ARGS{AUTHOR} ||= $META{author}; +$MM_ARGS{AUTHOR} = join ', ', @{ $MM_ARGS{AUTHOR} } + if $eumm_version < 6.5702 && $MM_ARGS{AUTHOR}; +$MM_ARGS{LICENSE} = $META{license}[0] + if $META{license} && $eumm_version >= 6.30; +$MM_ARGS{LICENSE} = $META{license}[0] + if $META{license} && $eumm_version >= 6.30; +$MM_ARGS{NO_MYMETA} = 1 + if $mymeta_broken; +$MM_ARGS{META_ADD} = { 'meta-spec' => { version => 2 }, %META } + unless -f 'META.yml'; +$MM_ARGS{PL_FILES} ||= {}; +$MM_ARGS{NORECURS} = 1 + if not exists $MM_ARGS{NORECURS}; + +for (qw(configure build test runtime)) { + my $key = $_ eq 'runtime' ? 'PREREQ_PM' : uc $_ . '_REQUIRES'; + my $r = $MM_ARGS{$key} = { + %{ $META{prereqs}{$_}{requires} || {} }, + %{ delete $MM_ARGS{$key} || {} }, + }; + defined $r->{$_} or delete $r->{$_} for keys %$r; +} + +$MM_ARGS{MIN_PERL_VERSION} = delete $MM_ARGS{PREREQ_PM}{perl} || 0; + +delete $MM_ARGS{MIN_PERL_VERSION} + if $eumm_version < 6.47_01; +$MM_ARGS{BUILD_REQUIRES} = { %{ $MM_ARGS{BUILD_REQUIRES} }, %{ delete $MM_ARGS{TEST_REQUIRES} } } + if $eumm_version < 6.63_03; +$MM_ARGS{PREREQ_PM} = { %{ $MM_ARGS{PREREQ_PM} }, %{ delete $MM_ARGS{BUILD_REQUIRES} } } + if $eumm_version < 6.55_01; +delete $MM_ARGS{CONFIGURE_REQUIRES} + if $eumm_version < 6.51_03; + +ExtUtils::MakeMaker::WriteMakefile(%MM_ARGS); +## END BOILERPLATE ###########################################################