5 use ExtUtils::MakeMaker;
7 my $mymeta_works = eval { ExtUtils::MakeMaker->VERSION('6.5707'); 1 };
8 my $mymeta = $mymeta_works || eval { ExtUtils::MakeMaker->VERSION('6.5702'); 1 };
11 'Test::More' => '0.47',
13 my %OPT_BUILD_DEPS = ( $] < 5.009_005 and is_smoker() )
14 ? ( 'Devel::Hide' => 0 ) : ()
18 # needed by the PP version only, have them installed
19 # regardless of XS availability or perl version
20 # (for fatpacking and whatnot)
21 'Algorithm::C3' => '0.07',
22 'Scalar::Util' => '0',
24 my %OPT_RUN_DEPS = ( $] < 5.009_005 and can_xs() )
25 ? ( 'Class::C3::XS' => '0.13' ) : ()
30 homepage => 'http://search.cpan.org/dist/Class-C3',
31 repository => 'git://git.shadowcat.co.uk/gitmo/Class-C3.git',
32 bugtracker => 'http://rt.cpan.org/Public/Dist/Display.html?Name=Class-C3',
36 my %WriteMakefileArgs = (
37 'NAME' => 'Class::C3',
38 'AUTHOR' => 'Stevan Little, <stevan@iinteractive.com>',
39 'VERSION_FROM' => 'lib/Class/C3.pm',
40 'ABSTRACT_FROM' => 'lib/Class/C3.pm',
41 'CONFIGURE_REQUIRES' => { 'ExtUtils::CBuilder' => 0.27 },
43 %RUN_DEPS, %OPT_RUN_DEPS,
44 $mymeta_works ? () : (%BUILD_DEPS, %OPT_BUILD_DEPS),
48 ? ( # BUILD_REQUIRES makes MYMETA right, requires stops META being wrong
49 'BUILD_REQUIRES' => { %BUILD_DEPS, %OPT_BUILD_DEPS },
52 requires => \%RUN_DEPS,
55 : ( # META_ADD both to get META right - only Makefile written
58 requires => \%RUN_DEPS,
59 build_requires => \%BUILD_DEPS,
64 ($mymeta and !$mymeta_works) ? ( 'NO_MYMETA' => 1 ) : (),
70 unless ( eval { ExtUtils::MakeMaker->VERSION('6.56') } ) {
71 my $br = delete $WriteMakefileArgs{BUILD_REQUIRES};
72 my $pp = $WriteMakefileArgs{PREREQ_PM};
73 for my $mod ( keys %$br ) {
74 if ( exists $pp->{$mod} ) {
75 $pp->{$mod} = $br->{$mod} if $br->{$mod} > $pp->{$mod};
78 $pp->{$mod} = $br->{$mod};
83 delete $WriteMakefileArgs{CONFIGURE_REQUIRES}
84 unless eval { ExtUtils::MakeMaker->VERSION('6.52') };
86 system("pod2text lib/Class/C3.pm >README")
89 WriteMakefile(%WriteMakefileArgs);
91 # Secondary compile testing via ExtUtils::CBuilder
93 # Do we have the configure_requires checker?
95 eval "require ExtUtils::CBuilder;";
97 # They don't obey configure_requires, so it is
98 # someone old and delicate. Try to avoid hurting
99 # them by falling back to an older simpler test.
103 return ExtUtils::CBuilder->new( quiet => 1 )->have_compiler;
106 # can we locate a (the) C compiler
108 my @chunks = split(/ /, $Config::Config{cc}) or return;
110 # $Config{cc} may contain args; try to find out the program part
112 return can_run("@chunks") || (pop(@chunks), next);
118 # check if we can run some command
122 return $cmd if -x $cmd;
123 if (my $found_cmd = MM->maybe_command($cmd)) {
127 for my $dir ((split /$Config::Config{path_sep}/, $ENV{PATH}), '.') {
129 my $abs = File::Spec->catfile($dir, $cmd);
130 return $abs if (-x $abs or $abs = MM->maybe_command($abs));
137 return ( $ENV{AUTOMATED_TESTING} && ! $ENV{PERL5_CPANM_IS_RUNNING} && ! $ENV{RELEASE_TESTING} )