From: Graham Knop Date: Fri, 15 Feb 2019 13:45:52 +0000 (+0100) Subject: packaging for CPAN X-Git-Url: http://git.shadowcat.co.uk/gitweb/gitweb.cgi?a=commitdiff_plain;h=3a3f2e10c013b0ec16d9c3164f433a329ed42ca8;p=p5sagit%2FDistar.git packaging for CPAN --- diff --git a/.gitignore b/.gitignore new file mode 100644 index 0000000..2693e07 --- /dev/null +++ b/.gitignore @@ -0,0 +1,17 @@ +/MANIFEST +/MANIFEST.bak +/MYMETA.* +/Makefile +/Makefile.old +/README +/blib/ +/pm_to_blib +*~ +*# +.#* +/Distar-*/ +/Distar-*.tar +/Distar-*.tar.gz +/cover_db/ +/_eumm/ +/MANIFEST.SKIP diff --git a/Makefile.PL b/Makefile.PL new file mode 100644 index 0000000..6b7b552 --- /dev/null +++ b/Makefile.PL @@ -0,0 +1,90 @@ +use strict; +use warnings FATAL => 'all'; +use 5.006; + +my %META = ( + name => 'Distar', + license => 'perl_5', + prereqs => { + configure => { requires => { + 'ExtUtils::MakeMaker' => 0, + } }, + build => { requires => { + } }, + test => { requires => { + 'Test::More' => '0.88', + } }, + runtime => { requires => { + 'ExtUtils::MakeMaker' => 0, + 'File::Spec' => 0, + 'File::Basename' => 0, + } }, + develop => { requires => { + 'Test::Pod' => 0, + } }, + }, + resources => { + repository => { + url => 'https://github.com/p5sagit/Distar.git', + web => 'https://github.com/p5sagit/Distar', + type => 'git', + }, + x_IRC => 'irc://irc.perl.org/#toolchain', + bugtracker => { + web => 'https://github.com/p5sagit/Distar/issues', + }, + license => [ 'https://dev.perl.org/licenses/' ], + }, + no_index => { + directory => [ 't', 'xt' ] + }, + x_authority => 'cpan:MSTROUT', +); + +my %MM_ARGS = (); + +## 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 ########################################################### diff --git a/maint/Makefile.PL.include b/maint/Makefile.PL.include new file mode 100644 index 0000000..7b2c6a2 --- /dev/null +++ b/maint/Makefile.PL.include @@ -0,0 +1,8 @@ +use lib 'lib'; +use Distar; + +author 'mst - Matt S. Trout (cpan:MSTROUT) '; + +manifest_include 'lib/Distar/helpers' => qr/.*/; + +1; diff --git a/t/basic.t b/t/basic.t new file mode 100644 index 0000000..2c18504 --- /dev/null +++ b/t/basic.t @@ -0,0 +1,9 @@ +use strict; +use warnings; +use Test::More; + +use Distar; + +ok 1, 'Distar loaded properly'; + +done_testing; diff --git a/xt/author/pod-syntax.t b/xt/author/pod-syntax.t new file mode 100644 index 0000000..8a3ebed --- /dev/null +++ b/xt/author/pod-syntax.t @@ -0,0 +1,6 @@ +use strict; +use warnings; + +use Test::Pod 1.41; + +all_pod_files_ok();