use strict;
-use warnings;
+use warnings FATAL => 'all';
+use 5.006;
-require 5.008001;
+my %META = (
+ name => 'Devel-GlobalDestruction-XS',
+ license => 'perl_5',
+ dynamic_config => 0,
+ prereqs => {},
+ resources => {
+ repository => {
+ url => 'git://github.com/p5sagit/Devel-GlobalDestruction-XS.git',
+ # git://git.shadowcat.co.uk/p5sagit/Devel-GlobalDestruction-XS.git
+ web => 'http://github.com/p5sagit/Devel-GlobalDestruction-XS',
+ type => 'git',
+ },
+ bugtracker => {
+ web => 'https://rt.cpan.org/Public/Dist/Display.html?Name=Devel-GlobalDestruction-XS',
+ mailto => 'bug-Devel-GlobalDestruction-XS@rt.cpan.org',
+ },
+ x_IRC => 'irc://irc.perl.org/#toolchain',
+ license => [ 'http://dev.perl.org/licenses/' ],
+ },
+);
-use ExtUtils::MakeMaker;
+my %MM_ARGS = ();
-my $mymeta_works = eval { ExtUtils::MakeMaker->VERSION('6.5707'); 1 };
-my $mymeta = $mymeta_works || eval { ExtUtils::MakeMaker->VERSION('6.5702'); 1 };
+## BOILERPLATE ###############################################################
+require ExtUtils::MakeMaker;
+(do './maint/Makefile.PL.include' or die $@) unless -f 'META.yml';
-my %META_BITS = (
-);
-my %RUN_DEPS = (
-);
+# have to do this since old EUMM dev releases miss the eval $VERSION line
+my $eumm_version = eval $ExtUtils::MakeMaker::VERSION;
+my $mymeta = $eumm_version >= 6.57_02;
+my $mymeta_broken = $mymeta && $eumm_version < 6.57_07;
-my %WriteMakefileArgs = (
- NAME => 'Devel::GlobalDestruction::XS',
- VERSION_FROM => 'lib/Devel/GlobalDestruction/XS.pm',
- LICENSE => 'perl',
- INSTALLDIRS => 'site',
- PL_FILES => { },
- MIN_PERL_VERSION => '5.008001',
- PREREQ_PM => \%RUN_DEPS,
- CONFIGURE_REQUIRES => { 'ExtUtils::CBuilder' => 0.27 },
- META_ADD => {
- resources => {
- repository => 'git://git.shadowcat.co.uk/p5sagit/Devel-GlobalDestruction-XS.git',
- bugtracker => 'http://rt.cpan.org/Public/Dist/Display.html?Name=Devel-GlobalDestruction-XS',
- },
- requires => \%RUN_DEPS,
- },
- ($mymeta and !$mymeta_works) ? ( 'NO_MYMETA' => 1 ) : (),
-);
+($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{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';
-unless ( eval { ExtUtils::MakeMaker->VERSION('6.56') } ) {
- my $br = delete $WriteMakefileArgs{BUILD_REQUIRES};
- my $pp = $WriteMakefileArgs{PREREQ_PM};
- for my $mod ( keys %$br ) {
- if ( exists $pp->{$mod} ) {
- $pp->{$mod} = $br->{$mod} if $br->{$mod} > $pp->{$mod};
- }
- else {
- $pp->{$mod} = $br->{$mod};
- }
- }
+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;
}
-delete $WriteMakefileArgs{CONFIGURE_REQUIRES}
- unless eval { ExtUtils::MakeMaker->VERSION('6.52') };
+$MM_ARGS{MIN_PERL_VERSION} = delete $MM_ARGS{PREREQ_PM}{perl} || 0;
-WriteMakefile(%WriteMakefileArgs);
+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 ###########################################################