X-Git-Url: http://git.shadowcat.co.uk/gitweb/gitweb.cgi?p=p5sagit%2FPackage-Variant.git;a=blobdiff_plain;f=Makefile.PL;h=9dda482833a93ea4dc2c886e7dae265ea3603248;hp=83dc455a183673c307575b234ab51226d4402039;hb=master;hpb=be21891218fed13d656c3779c46abfa3ff7dd7d2 diff --git a/Makefile.PL b/Makefile.PL index 83dc455..9dda482 100644 --- a/Makefile.PL +++ b/Makefile.PL @@ -1,32 +1,77 @@ use strict; use warnings FATAL => 'all'; -use ExtUtils::MakeMaker; -(do 'maint/Makefile.PL.include' or die $@) unless -f 'META.yml'; - -WriteMakefile( - NAME => 'Package::Variant', - VERSION_FROM => 'lib/Package/Variant.pm', - CONFIGURE_REQUIRES => { - 'ExtUtils::MakeMaker' => '6.55_01', # for BUILD_REQUIRES +my %META = ( + name => 'Package-Variant', + prereqs => { + test => { requires => { + 'Test::Fatal' => '0', + }, }, + runtime => { requires => { + 'perl' => '5.006', + 'strictures' => '2.000000', + 'Carp' => '0', + 'Import::Into' => '1.000000', + 'Module::Runtime' => '0.013', + }, }, }, - BUILD_REQUIRES => { 'Test::Fatal' => 0 }, - PREREQ_PM => { - strictures => 1, - Carp => 0, - 'Import::Into' => 1, - 'Module::Runtime' => '0.013', + dynamic_config => 0, + resources => { + # r/w: p5sagit@git.shadowcat.co.uk:Package-Variant.git + repository => { + url => 'git://git.shadowcat.co.uk/p5sagit/Package-Variant.git', + web => 'http://git.shadowcat.co.uk/gitweb/gitweb.cgi?p=p5sagit/Package-Variant.git', + type => 'git', + }, + bugtracker => { + mailto => 'bug-Package-Variant@rt.cpan.org', + web => 'https://rt.cpan.org/Public/Dist/Display.html?Name=Package-Variant', + }, }, + no_index => { directory => [ 't', 'xt', ], package => [ 'string' ] }, +); - META_MERGE => { - dynamic_config => 0, +my %MM_ARGS = (); - resources => { - # r/w: p5sagit@git.shadowcat.co.uk:Package-Variant.git - repository => 'git://git.shadowcat.co.uk/p5sagit/Package-Variant.git', - homepage => 'http://git.shadowcat.co.uk/gitweb/gitweb.cgi?p=p5sagit/Package-Variant.git', - }, +## BOILERPLATE ############################################################### +require ExtUtils::MakeMaker; +(do './maint/Makefile.PL.include' or die $@) unless -f 'META.yml'; - no_index => { package => [ 'string' ] }, - }, -); +# 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; + +($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'; + +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 ###########################################################