remove realclean from Makefile.PL and let Distar handle it
[p5sagit/strictures.git] / Makefile.PL
CommitLineData
eae006ee 1use strict;
2use warnings FATAL => 'all';
2c87c763 3use 5.006;
394c3a46 4
2c87c763 5my $have_compiler
6 = ! parse_args()->{PUREPERL_ONLY}
7 && eval { require ExtUtils::CBuilder; 1 }
8 && ExtUtils::CBuilder->new->have_compiler;
eae006ee 9
27826cd1 10my %extra_prereqs = (
11 indirect => 0,
12 multidimensional => 0,
13 'bareword::filehandles' => 0,
14);
ae3262c9 15
2c87c763 16my %META = (
17 name => 'strictures',
18 license => 'perl_5',
19 prereqs => {
20 configure => { requires => { } },
21 build => { requires => { } },
22 test => { requires => {
23 'Test::More' => 0,
24 } },
25 runtime => {
c4ddf87f 26 requires => {
27 perl => '5.006',
28 },
2c87c763 29 recommends => {
30 %extra_prereqs,
31 },
32 },
33 develop => { requires => {
34 %extra_prereqs,
35 } },
36 },
37 resources => {
38 # r/w: p5sagit@git.shadowcat.co.uk:strictures.git
39 repository => {
40 url => 'git://git.shadowcat.co.uk/p5sagit/strictures.git',
41 web => 'http://git.shadowcat.co.uk/gitweb/gitweb.cgi?p=p5sagit/strictures.git',
42 type => 'git',
43 },
44 bugtracker => {
45 mailto => 'bug-strictures@rt.cpan.org',
46 web => 'https://rt.cpan.org/Public/Dist/Display.html?Name=strictures',
47 },
48 license => [ 'http://dev.perl.org/licenses/' ],
49 },
50 no_index => {
51 directory => [ 't', 'xt' ]
52 },
53);
54
55my %MM_ARGS = (
56 PREREQ_PM => {
57 ($] >= 5.008004 && $have_compiler ? %extra_prereqs : () )
58 },
59);
60
ae3262c9 61sub parse_args {
62 # copied from EUMM
2c87c763 63 require ExtUtils::MakeMaker;
64 require Text::ParseWords;
ae3262c9 65 ExtUtils::MakeMaker::parse_args(
66 my $tmp = {},
67 Text::ParseWords::shellwords($ENV{PERL_MM_OPT} || ''),
68 @ARGV,
69 );
70 return $tmp->{ARGS} || {};
71}
72
18f7122e 73## BOILERPLATE ###############################################################
2c87c763 74require ExtUtils::MakeMaker;
75(do 'maint/Makefile.PL.include' or die $@) unless -f 'META.yml';
27826cd1 76
2c87c763 77# have to do this since old EUMM dev releases miss the eval $VERSION line
78my $eumm_version = eval $ExtUtils::MakeMaker::VERSION;
79my $mymeta = $eumm_version >= 6.57_02;
80my $mymeta_broken = $mymeta && $eumm_version < 6.57_07;
de111885 81
2c87c763 82($MM_ARGS{NAME} = $META{name}) =~ s/-/::/g;
83($MM_ARGS{VERSION_FROM} = "lib/$MM_ARGS{NAME}.pm") =~ s{::}{/}g;
18f7122e 84$META{license} = [ $META{license} ]
85 if $META{license} && !ref $META{license};
86$MM_ARGS{LICENSE} = $META{license}[0]
87 if $META{license} && $eumm_version >= 6.30;
2c87c763 88$MM_ARGS{NO_MYMETA} = 1
89 if $mymeta_broken;
90$MM_ARGS{META_ADD} = { 'meta-spec' => { version => 2 }, %META }
91 unless -f 'META.yml';
77f9ff76 92
2c87c763 93for (qw(configure build test runtime)) {
94 my $key = $_ eq 'runtime' ? 'PREREQ_PM' : uc $_.'_REQUIRES';
95 my $r = $MM_ARGS{$key} = {
2ef98edd 96 %{$META{prereqs}{$_}{requires} || {}},
2c87c763 97 %{delete $MM_ARGS{$key} || {}},
98 };
99 defined $r->{$_} or delete $r->{$_} for keys %$r;
100}
dfdfcbae 101
2c87c763 102$MM_ARGS{MIN_PERL_VERSION} = delete $MM_ARGS{PREREQ_PM}{perl} || 0;
5468e090 103
2c87c763 104delete $MM_ARGS{MIN_PERL_VERSION}
105 if $eumm_version < 6.47_01;
106$MM_ARGS{BUILD_REQUIRES} = {%{$MM_ARGS{BUILD_REQUIRES}}, %{delete $MM_ARGS{TEST_REQUIRES}}}
107 if $eumm_version < 6.63_03;
108$MM_ARGS{PREREQ_PM} = {%{$MM_ARGS{PREREQ_PM}}, %{delete $MM_ARGS{BUILD_REQUIRES}}}
109 if $eumm_version < 6.55_01;
110delete $MM_ARGS{CONFIGURE_REQUIRES}
111 if $eumm_version < 6.51_03;
112
113ExtUtils::MakeMaker::WriteMakefile(%MM_ARGS);
18f7122e 114## END BOILERPLATE ###########################################################