use warnings;
use ExtUtils::MakeMaker;
-my $has_version_pm;
-BEGIN {
- eval { require Config };
- die 'OS unsupported' if $@;
- Config->import(qw/%Config/);
- eval { require File::Spec };
- die 'OS unsupported' if $@;
- $has_version_pm = eval "require version; 1" || 0;
+use Config;
+use File::Spec;
+
+sub validate_exe {
+ my ($name, $preferred_path) = @_;
+
+ my (@candidates, @args);
+ if (File::Spec->file_name_is_absolute($name)) {
+ # No need to look for args if the name is absolute.
+ @candidates = $name;
+ } else {
+ my @path;
+ if (defined $preferred_path) {
+ @path = ($preferred_path, grep { $_ ne $preferred_path } File::Spec->path);
+ } else {
+ @path = File::Spec->path;
+ }
+
+ (my $base, @args) = split ' ', $name;
+ for my $path_entry (@path) {
+ my ($vol, $dir, $file) = File::Spec->splitpath($path_entry, 1);
+ next if defined $file and length $file;
+ push @candidates, File::Spec->catpath($vol, $dir, $base);
+ }
+ }
+
+ for my $path (@candidates) {
+ my $command = MM->maybe_command($path);
+ if (defined $command) {
+ $command .= " @args" if @args;
+ return $command;
+ }
+ }
+
+ return;
}
-use lib 'lib';
-
-print 'Checking for valgrind ' . ('>= 3.1.0 ' x $has_version_pm) .'in PATH... ';
-require Test::Valgrind::Session;
-my $vg = eval q[
- Test::Valgrind::Session->new((min_version => '3.1.0') x $has_version_pm)
- ->valgrind
-];
-if ($vg) {
- print "$vg\n";
-} else {
- print "no\n";
- die 'OS unsupported';
+
+sub check_exe {
+ my (%args) = @_;
+
+ my $desc = delete $args{desc};
+ my $arg_var = delete $args{arg_var};
+ my $tries = delete $args{try};
+ my $preferred_path = delete $args{preferred_path};
+
+ my $exe;
+
+ for (@ARGV) {
+ if (/^\Q$arg_var\E=(.*)/) {
+ $exe = validate_exe($1, $preferred_path);
+ last if defined $exe;
+ }
+ }
+
+ if (defined $exe) {
+ print "Forcing the use of $exe as the $desc.\n";
+ } else {
+ print "Checking for a valid $desc in the PATH... ";
+ for my $try (@$tries) {
+ next unless defined $try;
+ $exe = validate_exe($try, $preferred_path);
+ last if defined $exe;
+ }
+ if (defined $exe) {
+ print "$exe\n";
+ } else {
+ print "none\n";
+ }
+ }
+
+ return $exe;
}
-# Inspired from Module::Install::Can
-print "Checking for a valid C compiler in the PATH... ";
-my @ccs = ($Config{cc});
-unshift @ccs, $ENV{CC} if $ENV{CC};
-my @path = File::Spec->path;
-@ccs = map {
- my $cc = $_;
- File::Spec->file_name_is_absolute($cc)
- ? $cc
- : map File::Spec->catfile($_, $cc), @path
-} @ccs;
-my $has_cc;
-CC:
-for my $cc (@ccs) {
- if (-x $cc or MM->maybe_command($cc)) {
- $has_cc = $cc;
- last CC;
+my %PARAMS;
+
+my $cc = check_exe(
+ desc => 'C compiler',
+ arg_var => 'CC',
+ try => [ $Config{cc}, $ENV{CC}, 'cc' ],
+);
+if (defined $cc) {
+ my ($vol, $dir, $file) = File::Spec->splitpath($cc);
+ my $preferred_path = File::Spec->catpath($vol, $dir, '');
+ my $ld = check_exe(
+ desc => 'linker',
+ arg_var => 'LD',
+ try => [ $Config{ld}, $ENV{LD}, 'ld' ],
+ preferred_path => $preferred_path,
+ );
+ if (defined $ld) {
+ my $xs = 'Valgrind.xs';
+ (my $c = $xs) =~ s/\.xs$/.c/;
+ my $opt = $Config{optimize};
+ $opt =~ s/-O\S*//g;
+ $opt .= ' -O0 -g';
+ $PARAMS{C} = [ $c ];
+ $PARAMS{XS} = { $xs => $c };
+ $PARAMS{CC} = $cc;
+ $PARAMS{LD} = $ld;
+ $PARAMS{OPTIMIZE} = $opt;
}
}
-my (@C);
-if ($has_cc) {
- my $xs = 'Valgrind.xs';
- (my $c = $xs) =~ s/\.xs$/.c/;
- push @C, $c;
- print $has_cc, "\n";
-} else {
- print "none\n";
+
+unless ($PARAMS{C}) {
+ $PARAMS{C} = [ ];
+ $PARAMS{XS} = { };
+ $PARAMS{OBJECT} = '';
}
+my $dist = 'Test-Valgrind';
+
+(my $name = $dist) =~ s{-}{::}g;
+
+(my $file = $dist) =~ s{-}{/}g;
+$file = "lib/$file.pm";
+
my %PREREQ_PM = (
'Carp' => 0,
'Digest::MD5' => 0,
'File::HomeDir' => '0.86',
'File::Path' => 0,
'File::Spec' => 0,
- 'File::Temp' => 0,
+ 'File::Temp' => '0.14', # OO interface
+ 'Filter::Util::Call' => 0,
'Fcntl' => 0,
+ 'List::Util' => 0,
'POSIX' => 0,
'Perl::Destruct::Level' => 0,
'Scalar::Util' => 0,
'Test::Builder' => 0,
+ 'Test::More' => 0,
'XML::Twig' => 0,
'base' => 0,
'version' => 0,
);
-my $dist = 'Test-Valgrind';
+my %CONFIGURE_REQUIRES = (
+ 'Config' => 0,
+ 'ExtUtils::MakeMaker' => 0,
+ 'File::Spec' => 0,
+);
+
+my %BUILD_REQUIRES = (
+ %CONFIGURE_REQUIRES,
+ 'File::Temp' => 0,
+ 'Test::More' => 0,
+ 'base' => 0,
+ 'lib' => 0,
+ %PREREQ_PM,
+);
my %META = (
configure_requires => {
- 'Carp' => 0,
- 'Config' => 0,
- 'ExtUtils::MakeMaker' => 0,
- 'Fcntl' => 0,
- 'File::Spec' => 0,
- 'POSIX' => 0,
- 'Scalar::Util' => 0,
- 'base' => 0,
- 'version' => 0,
+ %CONFIGURE_REQUIRES,
},
build_requires => {
- 'ExtUtils::MakeMaker' => 0,
- 'Test::More' => 0,
- %PREREQ_PM,
+ %BUILD_REQUIRES,
},
recommends => {
'DynaLoader' => 0,
'XSLoader' => 0,
},
+ dynamic_config => 1,
resources => {
- bugtracker => "http://rt.cpan.org/NoAuth/ReportBug.html?Queue=$dist",
+ bugtracker => "http://rt.cpan.org/Dist/Display.html?Name=$dist",
homepage => "http://search.cpan.org/dist/$dist/",
license => 'http://dev.perl.org/licenses/',
- repository => "http://git.profvince.com/perl/modules/$dist.git",
+ repository => "http://git.profvince.com/?p=perl%2Fmodules%2F$dist.git",
},
);
WriteMakefile(
- NAME => 'Test::Valgrind',
- AUTHOR => 'Vincent Pit <perl@profvince.com>',
- LICENSE => 'perl',
- VERSION_FROM => 'lib/Test/Valgrind.pm',
- ABSTRACT_FROM => 'lib/Test/Valgrind.pm',
- OPTIMIZE => '-g',
- C => \@C,
- PREREQ_PM => \%PREREQ_PM,
- MIN_PERL_VERSION => 5.006,
- META_MERGE => \%META,
- dist => {
- PREOP => 'pod2text lib/Test/Valgrind.pm > $(DISTVNAME)/README',
- COMPRESS => 'gzip -9f', SUFFIX => 'gz',
- },
- clean => {
- FILES => "$dist-* Makefile.bak *.gcov *.gcda *.gcno cover_db Debian_CPANTS.txt"
- },
+ NAME => $name,
+ AUTHOR => 'Vincent Pit <perl@profvince.com>',
+ LICENSE => 'perl',
+ VERSION_FROM => $file,
+ ABSTRACT_FROM => $file,
+ BUILD_REQUIRES => \%BUILD_REQUIRES,
+ PREREQ_PM => \%PREREQ_PM,
+ MIN_PERL_VERSION => '5.006',
+ META_MERGE => \%META,
+ dist => {
+ PREOP => "pod2text -u $file > \$(DISTVNAME)/README",
+ COMPRESS => 'gzip -9f', SUFFIX => 'gz',
+ },
+ clean => {
+ FILES => "$dist-* *.gcov *.gcda *.gcno cover_db Debian_CPANTS.txt*"
+ },
+ %PARAMS,
);