]> git.vpit.fr Git - perl/modules/Scalar-Vec-Util.git/blobdiff - Makefile.PL
Revamp compiler/linker discovery in Makefile.PL
[perl/modules/Scalar-Vec-Util.git] / Makefile.PL
index fc3276b1cde0b7daa417b11455c3ed107527a453..846e489b82688f75755b1c758e242488c6c03817 100644 (file)
+use 5.006;
+
 use strict;
 use warnings;
 use ExtUtils::MakeMaker;
 
-BEGIN {
- eval { require Config };
- die 'OS unsupported' if $@;
- Config->import(qw/%Config/);
- eval { require File::Spec };
- die 'OS unsupported' if $@;
+use Config;
+use File::Spec;
+
+sub validate_exe {
+ my ($name) = @_;
+
+ 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 $base, @args) = split ' ', $name;
+  @candidates = map File::Spec->catfile($_, $base), File::Spec->path;
+ }
+
+ for my $path (@candidates) {
+  my $command = MM->maybe_command($path);
+  if (defined $command) {
+   $command .= " @args" if @args;
+   return $command;
+  }
+ }
+
+ return;
 }
 
-# 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;
+sub check_exe {
+ my ($desc, $arg_var, $config_var, $env_var) = @_;
+
+ my $exe;
+
+ for (@ARGV) {
+  if (/^\Q$arg_var\E=(.*)/) {
+   $exe = validate_exe($1);
+   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... ";
+  $exe = validate_exe($Config{$config_var});
+  # Only fall back to env if we cannot find the one used to build perl.
+  if (not defined $exe and defined $ENV{$env_var}) {
+   $exe = validate_exe($ENV{$env_var});
+  }
+  if (defined $exe) {
+   print "$exe\n";
+  } else {
+   print "none\n";
+  }
+ }
+
+ return $exe;
 }
-my @C;
-if ($cc) {
- push @C, 'Util.c';
- print $cc, "\n";
-} else {
print "none\n";
+
+my $cc = check_exe('C compiler', 'CC', 'cc', 'CC');
+
+my $ld;
+if (defined $cc) {
$ld = check_exe('linker', 'LD', 'ld', 'LD');
 }
 
-my $arch = $Config{archname} || '';
-my ($cpu) = $arch =~ /^([^-]+)/;
+sub is_little_endian {
+ my $order = $Config{byteorder};
+ return 0 unless $order;
+ my $len = length $order;
+ if ($len > 8) {
+  $order = substr $order, 0, 8;
+  $len   = 8;
+ }
+ return $order eq (join '', 1 .. $len);
+}
 
+my %PARAMS;
 my @DEFINES;
-my $unit;
-if (unpack("h*", pack("s", 0x1234)) != 4321) {
- print "Forcing unit size of 8 on non-little-endian systems.\n";
- $unit = 8;
-} else {
- my $align = int($Config{alignbytes} || 0);
- print "Checking unit size in bits... ";
- for (8, 16, 32, 64) {
-  my $size = int($Config{'u' . $_ . 'size'} || 0);
-  $unit = $_ if $size && $size <= $align;
+
+if (defined $cc and defined $ld) {
+ $PARAMS{C}  = [ 'Util.c' ];
+ $PARAMS{XS} = { 'Util.xs' => 'Util.c' };
+ $PARAMS{CC} = $cc;
+ $PARAMS{LD} = $ld;
+
+ my $unit = { bits => 8, size => 1 };
+ if (not is_little_endian()) {
+  print "Forcing unit size of 8 on non-little-endian systems.\n";
+ } else {
+  print "Checking unit size in bits... ";
+  my $align = $Config{alignbytes} || 1;
+  my @bits = (8, 16, 32, 64);
+  for my $bits (@bits) {
+   my $size = $Config{"u${bits}size"};
+   next unless $size;
+   $unit = { bits => $bits, size => $size } if $size && $size <= $align;
+  }
+  print $unit->{bits},
+                " (actually $unit->{size} bytes for $align bytes alignment).\n";
  }
- print $unit, "\n";
+
+ my $bits = $unit->{bits};
+ push @DEFINES, '-DBV_UNIT="' . ($Config{"u${bits}type"} || "U$bits") . '"';
+ push @DEFINES, "-DSVU_SIZE=$bits";
+} else {
+ $PARAMS{C}      = [ ];
+ $PARAMS{XS}     = { };
+ $PARAMS{OBJECT} = '';
 }
-push @DEFINES, DEFINE => '-DBV_UNIT="'
-                                 . ($unit == 64 ? 'uint64_t' : 'U' . $unit)
-                                 . '"'
-                      . ' -DSVU_SIZE=' . $unit;
 
-my $BUILD_REQUIRES = {
+$PARAMS{DEFINE} = join ' ', @DEFINES if @DEFINES;
+
+my $dist = 'Scalar-Vec-Util';
+
+(my $name = $dist) =~ s{-}{::}g;
+
+(my $file = $dist) =~ s{-}{/}g;
+$file = "lib/$file.pm";
+
+my %PREREQ_PM = (
+ 'Exporter' => 0,
+ 'Carp'     => 0,
+ 'XSLoader' => 0,
+ 'base'     => 0,
+);
+
+my %BUILD_REQUIRES = (
  'Config'              => 0,
  'ExtUtils::MakeMaker' => 0,
+ 'File::Spec'          => 0,
  'Test::More'          => 0,
-};
-
-sub build_req {
- my $tometa = ' >> $(DISTVNAME)/META.yml;';
- my $build_req = 'echo "build_requires:" ' . $tometa;
- foreach my $mod ( sort { lc $a cmp lc $b } keys %$BUILD_REQUIRES ) {
-  my $ver = $BUILD_REQUIRES->{$mod};
-  $build_req .= sprintf 'echo "    %-30s %s" %s', "$mod:", $ver, $tometa;
- }
- return $build_req;
-}
+ %PREREQ_PM,
+);
+
+my %META = (
+ configure_requires => {
+  'Config'              => 0,
+  'ExtUtils::MakeMaker' => 0,
+  'File::Spec'          => 0,
+ },
+ build_requires => {
+  %BUILD_REQUIRES,
+ },
+ dynamic_config => 1,
+ resources => {
+  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/?p=perl%2Fmodules%2F$dist.git",
+ },
+);
 
 WriteMakefile(
-    NAME          => 'Scalar::Vec::Util',
-    AUTHOR        => 'Vincent Pit <perl@profvince.com>',
-    LICENSE       => 'perl',
-    VERSION_FROM  => 'lib/Scalar/Vec/Util.pm',
-    ABSTRACT_FROM => 'lib/Scalar/Vec/Util.pm',
-    PL_FILES      => {},
-    C             => \@C,
-    @DEFINES,
-    PREREQ_PM     => {
-        'Exporter' => 0,
-        'Carp'     => 0,
-        'XSLoader' => 0
-    },
-    dist          => {
-        PREOP      => 'pod2text lib/Scalar/Vec/Util.pm > $(DISTVNAME)/README; '
-                      . build_req,
-        COMPRESS   => 'gzip -9f', SUFFIX => 'gz'
-    },
-    clean         => { FILES => 'Scalar-Vec-Util-* *.gcov *.gcda *.gcno cover_db' },
+ NAME             => $name,
+ AUTHOR           => 'Vincent Pit <perl@profvince.com>',
+ LICENSE          => 'perl',
+ VERSION_FROM     => $file,
+ ABSTRACT_FROM    => $file,
+ PL_FILES         => {},
+ 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,
 );
 
 1;
@@ -99,7 +182,7 @@ package MY;
 
 sub postamble {
  my $cv = join ' -coverage ', 'cover',
-                            qw/statement branch condition path subroutine time/;
+                            qw<statement branch condition path subroutine time>;
  <<POSTAMBLE;
 cover test_cover:
        $cv -test