X-Git-Url: http://git.vpit.fr/?a=blobdiff_plain;f=Makefile.PL;h=dcac0c9053ad00db193941d1afe1bd59061b81f8;hb=9a6e8be3534feee179fe0d63d284948f340ac67d;hp=1d37fb9cc8b427147f5454fbea4ed6a39c890012;hpb=8e236cf7f5ac06829edb65527fcdf12716ecd159;p=perl%2Fmodules%2FTest-Valgrind.git diff --git a/Makefile.PL b/Makefile.PL index 1d37fb9..dcac0c9 100644 --- a/Makefile.PL +++ b/Makefile.PL @@ -1,32 +1,68 @@ +use 5.006; + use strict; use warnings; use ExtUtils::MakeMaker; -my $has_vg = 0; +BEGIN { + eval { require Config }; + die 'OS unsupported' if $@; + Config->import(qw/%Config/); + eval { require File::Spec }; + die 'OS unsupported' if $@; +} + my $vg; print 'Checking for valgrind >= 3.1.0 in PATH... '; for (split /:/, $ENV{PATH}) { - $vg = $_ . '/valgrind'; - if (-x $vg) { - my $ver = qx/$vg --version/; + $_ .= '/valgrind'; + if (-x) { + my $ver = qx/$_ --version/; if ($ver =~ s/^valgrind-//) { $ver = join '', map chr, split /\./, $ver; if ($ver ge v3.1.0) { - print "yes, $vg\n"; - $has_vg = 1; + print "$_\n"; + $vg = $_; last; } } } } -if (!$has_vg) { +if (!$vg) { print "no\n"; die 'OS unsupported'; } +# 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 $cc; +CC: +for my $c (@ccs) { + for my $dir (split /$Config{path_sep}/, $ENV{PATH}) { + my $abs = File::Spec->catfile($dir, $c); + if (-x $abs or MM->maybe_command($abs)) { + $cc = $c; + last CC; + } + } +} +my (@C); +if ($cc) { + my $xs = 'Valgrind.xs'; + (my $c = $xs) =~ s/\.xs$/.c/; + push @C, $c; + print $cc, "\n"; +} else { + print "none\n"; +} + my $BUILD_REQUIRES = { 'ExtUtils::MakeMaker' => 0, - 'Test::More' => 0 + 'File::Copy' => 0, + 'Test::More' => 0, + 'XSLoader' => 0 }; sub build_req { @@ -57,27 +93,47 @@ WriteMakefile( LICENSE => 'perl', VERSION_FROM => 'lib/Test/Valgrind.pm', ABSTRACT_FROM => 'lib/Test/Valgrind.pm', - PL_FILES => { './Gensupp.PL' => 'lib/' . $supp }, + PL_FILES => { + './Gensupp.PL' => 'blib/archpub/' . $supp, + './FixInstall.PL' => 'Makefile.bak', + }, + OPTIMIZE => '-g', PM => { 'lib/Test/Valgrind.pm' => '$(INST_LIB)/Test/Valgrind.pm', 'lib/Test/Valgrind/Suppressions.pm' - => '$(INST_ARCHLIB)/Test/Valgrind/Suppressions.pm', - 'lib/' . $supp => '$(INST_ARCHLIB)/' . $supp, + => 'blib/archpub/Test/Valgrind/Suppressions.pm', }, + C => \@C, PREREQ_PM => { 'Carp' => 0, 'Exporter' => 0, + 'Fcntl' => 0, 'POSIX' => 0, 'Perl::Destruct::Level' => 0, - 'Test::More' => 0, + 'Test::Builder' => 0, }, dist => { - PREOP => 'pod2text lib/Test/Valgrind.pm > $(DISTVNAME)/README; ' + PREOP => "touch lib/$supp; " + . 'pod2text lib/Test/Valgrind.pm > $(DISTVNAME)/README; ' . build_req, COMPRESS => 'gzip -9f', SUFFIX => 'gz', }, - clean => { FILES => "Test-Valgrind-* lib/$supp *.gcov *.gcda *.gcno cover_db" }, + clean => { FILES => "Test-Valgrind-* lib/$supp Makefile.bak *.gcov *.gcda *.gcno cover_db Debian_CPANTS.txt" }, ); 1 while unlink 'lib/' . $supp; +package MY; + +sub test { + my $test = shift->SUPER::test(@_); + return "test :: Makefile.bak blib/archpub/Test/Valgrind/perlTestValgrind.supp\n" . $test; +} + +sub postamble { + <<'POSTAMBLE'; +clean :: + $(CP) lib/Test/Valgrind/Suppressions.{tpl,pm} + $(TOUCH) lib/Test/Valgrind/perlTestValgrind.supp +POSTAMBLE +}