update warning category list for 5.39.8
[p5sagit/strictures.git] / Makefile.PL
index d2c495e..9002eab 100644 (file)
@@ -1,11 +1,12 @@
 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,
@@ -15,7 +16,8 @@ my %extra_prereqs = (
 
 my %META = (
   name => 'strictures',
-  license => 'perl_5',
+  license => [ 'perl_5' ],
+  dynamic_config => 1,
   prereqs => {
     configure => { requires => { } },
     build => { requires => { } },
@@ -26,19 +28,25 @@ my %META = (
       requires => {
         perl => '5.006',
       },
-      recommends => {
+      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 => {
@@ -48,15 +56,23 @@ my %META = (
     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 {
@@ -73,29 +89,40 @@ sub parse_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;
-$META{license} = [ $META{license} ]
-  if $META{license} && !ref $META{license};
+( $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;
 }
@@ -104,9 +131,9 @@ $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}}}
+$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;