From: Graham Knop Date: Wed, 27 Nov 2019 15:06:17 +0000 (+0100) Subject: update Makefile.PL with better metadata X-Git-Tag: v0.004001~3 X-Git-Url: http://git.shadowcat.co.uk/gitweb/gitweb.cgi?a=commitdiff_plain;h=f21cb0e90bc5e35a7874d6b95f7cef4d8b56b6cd;p=scpubgit%2FObject-Remote.git update Makefile.PL with better metadata --- diff --git a/Makefile.PL b/Makefile.PL index ea296b8..dcd9918 100644 --- a/Makefile.PL +++ b/Makefile.PL @@ -1,27 +1,109 @@ use strict; use warnings FATAL => 'all'; -use ExtUtils::MakeMaker; +use 5.008; -(do './maint/Makefile.PL.include' or die $@) unless -f 'META.yml'; - -WriteMakefile( - NAME => 'Object::Remote', - VERSION_FROM => 'lib/Object/Remote.pm', - PREREQ_PM => { - Moo => 1.006, - 'Module::Runtime' => 0, - 'JSON::PP' => 0, - 'Future' => 0.29, - 'MRO::Compat' => 0, # required to fatpack Moo - 'Class::C3' => 0, # required to fatpack Moo - 'Devel::GlobalDestruction' => 0, # required to fatpack Moo - 'String::ShellQuote' => 0, # required for ssh argument manipulation - 'Log::Contextual' => 0.005000, - strictures => 2, +my %META = ( + name => 'Object-Remote', + license => 'perl_5', + prereqs => { + configure => { requires => { + 'ExtUtils::MakeMaker' => 0, + } }, + build => { requires => { + } }, + test => { + requires => { + 'Test::More' => '0.96', + }, + }, + runtime => { + requires => { + 'Moo' => 1.006, + 'Module::Runtime' => 0, + 'JSON::PP' => 0, + 'Future' => 0.29, + 'MRO::Compat' => 0, # required to fatpack Moo + 'Class::C3' => 0, # required to fatpack Moo + 'Devel::GlobalDestruction' => 0, # required to fatpack Moo + 'String::ShellQuote' => 0, # required for ssh argument manipulation + 'Log::Contextual' => 0.005000, + 'strictures' => 2, + }, + }, + develop => { + requires => { + }, + }, + }, + resources => { + repository => { + url => 'git://git.shadowcat.co.uk/scpubgit/Object-Remote.git', + # r/w: scpubgit@git.shadowcat.co.uk:Object-Remote.git + web => 'http://git.shadowcat.co.uk/gitweb/gitweb.cgi?p=scpubgit/Object-Remote.git', + type => 'git', + }, + bugtracker => { + web => 'https://rt.cpan.org/Public/Dist/Display.html?Name=Object-Remote', + mailto => 'bug-Object-Remote@rt.cpan.org', + }, + license => [ 'http://dev.perl.org/licenses/' ], + }, + no_index => { + directory => [ 't', 'xt' ] }, + x_authority => 'cpan:MSTROUT', +); + +my %MM_ARGS = ( EXE_FILES => [ 'bin/object-remote-node', 'bin/object-remote-slave', 'bin/remoterepl', ], ); + +## BOILERPLATE ############################################################### +require ExtUtils::MakeMaker; +(do './maint/Makefile.PL.include' or die $@) unless -f 'META.yml'; + +# 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'; +$MM_ARGS{PL_FILES} ||= {}; +$MM_ARGS{NORECURS} = 1 + if not exists $MM_ARGS{NORECURS}; + +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 ###########################################################