X-Git-Url: http://git.shadowcat.co.uk/gitweb/gitweb.cgi?a=blobdiff_plain;f=Makefile.PL;h=17d8a3dada4c11ab7cc4cbae1ef82bd4a47aca74;hb=679fe9d02ec5d658e9556975c94898a08a42aa7d;hp=be54156db71aa2d3f8c0562ca2c8410ac333ccf0;hpb=6d2a9a35f591c2d30edf641882e1081cc8376123;p=p5sagit%2FData-Dumper-Concise.git diff --git a/Makefile.PL b/Makefile.PL index be54156..17d8a3d 100644 --- a/Makefile.PL +++ b/Makefile.PL @@ -1,8 +1,102 @@ -use 5.006; -use inc::Module::Install 0.91; use strict; use warnings FATAL => 'all'; +use ExtUtils::MakeMaker; +(do './maint/Makefile.PL.include' or die $@) unless -f 'META.yml'; -all_from 'lib/Data/Dumper/Concise.pm'; +my %WriteMakefileArgs = ( + NAME => 'Data::Dumper::Concise', + VERSION_FROM => 'lib/Data/Dumper/Concise.pm', -WriteAll; + META_MERGE => { + 'meta-spec' => { version => 2 }, + dynamic_config => 0, + 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/Data-Dumper-Concise.git + # r/w: p5sagit@git.shadowcat.co.uk:Data-Dumper-Concise.git + # web: http://git.shadowcat.co.uk/gitweb/gitweb.cgi?p=p5sagit/Data-Dumper-Concise.git + repository => { + url => 'https://github.com/p5sagit/Data-Dumper-Concise.git', + web => 'https://github.com/p5sagit/Data-Dumper-Concise', + type => 'git', + }, + bugtracker => { + mailto => 'bug-Data-Dumper-Concise@rt.cpan.org', + web => 'https://rt.cpan.org/Public/Dist/Display.html?Name=Data-Dumper-Concise', + }, + }, + x_contributors => [ # manually added, from git shortlog -e -s -n + 'Arthur Axel \'fREW\' Schmidt ', + 'Matt S Trout ', + 'Karen Etheridge ', + ], + }, + + META_ADD => { + 'meta-spec' => { version => 2 }, + prereqs => { + configure => { + requires => { + 'ExtUtils::MakeMaker' => '0', + }, + }, + runtime => { + requires => { + 'Exporter' => '0', + 'Data::Dumper' => '0', + 'perl' => '5.006', + }, + }, + test => { + requires => { + 'Test::More' => '0', + }, + }, + }, + }, +); + +my $eumm_version = eval $ExtUtils::MakeMaker::VERSION; + +for (qw(configure build test runtime)) { + my $key = $_ eq 'runtime' ? 'PREREQ_PM' : uc $_.'_REQUIRES'; + next unless exists $WriteMakefileArgs{META_ADD}{prereqs}{$_} + or exists $WriteMakefileArgs{$key}; + my $r = $WriteMakefileArgs{$key} = { + %{$WriteMakefileArgs{META_ADD}{prereqs}{$_}{requires} || {}}, + %{delete $WriteMakefileArgs{$key} || {}}, + }; + defined $r->{$_} or delete $r->{$_} for keys %$r; +} + +# dynamic prereqs get added here... + +$WriteMakefileArgs{MIN_PERL_VERSION} = delete $WriteMakefileArgs{PREREQ_PM}{perl} || 0; + +die 'attention developer: you need to do a sane meta merge here!' + if keys %{$WriteMakefileArgs{BUILD_REQUIRES}}; + +$WriteMakefileArgs{BUILD_REQUIRES} = { + %{$WriteMakefileArgs{BUILD_REQUIRES} || {}}, + %{delete $WriteMakefileArgs{TEST_REQUIRES}} +} if $eumm_version < 6.63_03; + +$WriteMakefileArgs{PREREQ_PM} = { + %{$WriteMakefileArgs{PREREQ_PM}}, + %{delete $WriteMakefileArgs{BUILD_REQUIRES}} +} if $eumm_version < 6.55_01; + +delete $WriteMakefileArgs{CONFIGURE_REQUIRES} + if $eumm_version < 6.51_03; + +delete $WriteMakefileArgs{MIN_PERL_VERSION} + if $eumm_version < 6.48; + +delete @WriteMakefileArgs{qw(META_ADD META_MERGE)} + if $eumm_version < 6.46; + +delete $WriteMakefileArgs{LICENSE} + if $eumm_version < 6.31; + +WriteMakefile(%WriteMakefileArgs);