X-Git-Url: http://git.shadowcat.co.uk/gitweb/gitweb.cgi?a=blobdiff_plain;f=Makefile.PL;h=3b8f406ad0b1c43985762278098b4c509010e46e;hb=0b694b310e3c4cfb311fe4506dfdf17404c47461;hp=e1bfb3aeb3e67d944f7a2cb5578ff8d98117711f;hpb=8b945fac609fdb37fd9bfb54ce5fcd6ab8c10ac5;p=p5sagit%2FJSON-MaybeXS.git diff --git a/Makefile.PL b/Makefile.PL index e1bfb3a..3b8f406 100644 --- a/Makefile.PL +++ b/Makefile.PL @@ -1,38 +1,123 @@ use strict; use warnings FATAL => 'all'; -use 5.008001; use ExtUtils::MakeMaker; (do 'maint/Makefile.PL.include' or die $@) unless -f 'META.yml'; -my %BUILD_DEPS = ( - 'Test::Without::Module' => '0.17', - 'Test::More' => '0.88' -); - -# we require Cpanel::JSON::XS, except if JSON::XS is already installed we only -# reocmmend it. -my $require_cpanel_json_xs = can_xs() && !eval { require JSON::XS; 1; }; - -WriteMakefile( +my %WriteMakefileArgs = ( NAME => 'JSON::MaybeXS', VERSION_FROM => 'lib/JSON/MaybeXS.pm', - PREREQ_PM => { - 'JSON::PP' => '2.27202', - ($require_cpanel_json_xs - ? ('Cpanel::JSON::XS' => '2.3310') - : ()), - %BUILD_DEPS, - }, - BUILD_REQUIRES => \%BUILD_DEPS, + META_MERGE => { 'meta-spec' => { version => 2 }, dynamic_config => 1, - ($require_cpanel_json_xs - ? () - : (prereqs => { runtime => { recommends => { 'Cpanel::JSON::XS' => '2.3310' } } })), + resources => { + # r/w: p5sagit@git.shadowcat.co.uk:JSON-MaybeXS.git + repository => { + url => 'git://git.shadowcat.co.uk/p5sagit/JSON-MaybeXS.git', + web => 'http://git.shadowcat.co.uk/gitweb/gitweb.cgi?p=p5sagit/JSON-MaybeXS.git', + type => 'git', + }, + bugtracker => { + mailto => 'bug-JSON-MaybeXS@rt.cpan.org', + web => 'https://rt.cpan.org/Public/Dist/Display.html?Name=JSON-MaybeXS', + }, + }, + }, + + META_ADD => { + prereqs => { + configure => { + requires => { + 'ExtUtils::MakeMaker' => '0', + 'ExtUtils::CBuilder' => '0.27', + 'File::Spec' => '0', + 'File::Temp' => '0', + }, + }, + runtime => { + requires => { + 'Scalar::Util' => '0', + 'JSON::PP' => '2.27202', + # we may also add a runtime prereq for Cpanel::JSON::XS, on the + # installer's machine + perl => '5.006', + }, + recommends => { 'Cpanel::JSON::XS' => '2.3310' }, + }, + test => { + requires => { + 'Test::Without::Module' => '0.17', + 'Test::More' => '0.88', + }, + }, + }, }, ); +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. + +# we require Cpanel::JSON::XS, except if JSON::XS is already installed. +# (we also always recommend Cpanel::JSON::XS, just to make sure.) +$WriteMakefileArgs{PREREQ_PM}{'Cpanel::JSON::XS'} = '2.3310' + if not parse_args()->{PUREPERL_ONLY} + and not eval { require JSON::XS; 1; } + and can_xs(); + +$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); + + +sub parse_args { + # copied from EUMM + require ExtUtils::MakeMaker; + require Text::ParseWords; + ExtUtils::MakeMaker::parse_args( + my $tmp = {}, + Text::ParseWords::shellwords($ENV{PERL_MM_OPT} || ''), + @ARGV, + ); + return $tmp->{ARGS} || {}; +} + # can we locate a (the) C compiler sub can_cc { my @chunks = split(/ /, $Config::Config{cc}) or return;