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;