use strict;
use warnings FATAL => 'all';
use 5.006;
+use lib 'inc';
+use ExtUtils::HasCompiler 'can_compile_loadable_object';
-my $have_compiler
- = ! parse_args()->{PUREPERL_ONLY}
- && eval { require ExtUtils::CBuilder; 1 }
- && ExtUtils::CBuilder->new->have_compiler;
+my $want_pp = parse_args()->{PUREPERL_ONLY};
+my $should_xs
+ = defined $want_pp ? $want_pp : can_compile_loadable_object(quiet => 1);
my %extra_prereqs = (
indirect => 0,
my %META = (
name => 'strictures',
- license => 'perl_5',
+ license => [ 'perl_5' ],
+ dynamic_config => 1,
prereqs => {
configure => { requires => { } },
build => { requires => { } },
'Test::More' => 0,
} },
runtime => {
- requires => { },
- recommends => {
+ requires => {
+ perl => '5.006',
+ },
+ suggests => {
%extra_prereqs,
},
},
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 => 'git://git.shadowcat.co.uk/p5sagit/strictures.git',
- web => 'http://git.shadowcat.co.uk/gitweb/gitweb.cgi?p=p5sagit/strictures.git',
+ url => 'https://github.com/p5sagit/strictures.git',
+ web => 'https://github.com/p5sagit/strictures',
type => 'git',
},
bugtracker => {
license => [ 'http://dev.perl.org/licenses/' ],
},
no_index => {
- directory => [ 't', 'xt' ]
+ directory => [ 't', 'xt', 'inc' ]
},
+ x_authority => 'cpan:MSTROUT',
+ x_contributors => [ # manually added, from git shortlog -e -s -n
+ 'Graham Knop <haarg@haarg.org>',
+ 'Karen Etheridge <ether@cpan.org>',
+ 'Matt S Trout <mst@shadowcat.co.uk>',
+ 'Peter Rabbitson <ribasushi@cpan.org>',
+ 'Christian Walde <walde.christian@googlemail.com>',
+ 'Diab Jerius <djerius@cfa.harvard.edu>',
+ ],
);
my %MM_ARGS = (
PREREQ_PM => {
- ($] >= 5.008004 && $have_compiler ? %extra_prereqs : () )
+ ("$]" >= 5.008004 && $should_xs ? %extra_prereqs : () )
},
- realclean => { FILES => [ 'Distar/', 'MANIFEST*' ] },
);
sub parse_args {
return $tmp->{ARGS} || {};
}
-##############################################################################
+## BOILERPLATE ###############################################################
require ExtUtils::MakeMaker;
-(do 'maint/Makefile.PL.include' or die $@) unless -f 'META.yml';
+(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 = eval $ExtUtils::MakeMaker::VERSION;
+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;
-($MM_ARGS{VERSION_FROM} = "lib/$MM_ARGS{NAME}.pm") =~ s{::}{/}g;
-$MM_ARGS{LICENSE} = $META{license}
- if $eumm_version >= 6.30;
+( $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 $key = $_ eq 'runtime' ? 'PREREQ_PM' : uc $_ . '_REQUIRES';
my $r = $MM_ARGS{$key} = {
- %{$META{prereqs}{$_}{requires}},
- %{delete $MM_ARGS{$key} || {}},
+ %{ $META{prereqs}{$_}{requires} || {} },
+ %{ delete $MM_ARGS{$key} || {} },
};
defined $r->{$_} or delete $r->{$_} for keys %$r;
}
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}}}
+$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}}}
+$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 ###########################################################