avoid cpan indexing of test::helper
[perl-fuse.git] / Makefile.PL
index 61a8420..b64ab59 100644 (file)
 use ExtUtils::MakeMaker;
+use POSIX;
+use Config;
 # See lib/ExtUtils/MakeMaker.pm for details of how to influence
 # the contents of the Makefile that is written.
 
-my $ver = `fusermount -V`;
-my $ver2 = `mount_fusefs -V`;
-chomp(my $ver3 = `mount_fusefs -V 2>&1 | head -n1`);
-$ver =~ s/^.*?version:\s+//;
-$ver2 =~ s/^.*?version:\s+//;
-$ver3 =~ s/^.*?version\s+//;
-if (! $ver && ! $ver2 && ! $ver3) {
-       # make CPANPLUS happy and don't report errors if fuse isn't installed
-       die("No support for os: $^O\n",
-               "You need to have fuse-dev (or similar) package installed and have sufficient permissions in order to install this module\n",
-               $^O eq 'darwin' ? ("One option on Mac is http://code.google.com/p/macfuse/\n") : (),
-       );
+# Note: This is a hack. This hack is necessary because MacFUSE's libfuse
+# (and libfuse_ino64, by extension) don't link in libiconv. This wouldn't
+# be a problem, but it appears the Darwin/OS X dynamic linker won't
+# satisfy runtime link dependencies in those libraries from libraries
+# imported by our library, and it uses a symbol from libiconv without
+# actually linking the library to itself. Awesome.
+package MY;
+sub test_via_harness {
+    my($self, $perl, $tests) = @_;
+    local $_ = $self->SUPER::test_via_harness($perl, $tests);
+    s/PERL_DL_NONLAZY=1//g if $^O eq 'darwin';
+    return $_;
 }
-if ($ver && $ver + 0 < 2.5) {
-       die "Fuse perl bindings need Linux fuse version 2.5 or newer\n";
-} elsif ($ver2 && $ver2 + 0 < 0.3) {
-       die "Fuse perl bindings need FreeBSD fuse version 0.3 or newer\n";
-} elsif ($^O eq 'darwin' && $ver3 && !(($ver3 ge "0.1.0b006") || ($ver3 eq "0.1.0"))) {
-       # the "ge" string-compare check will match all later revs and all later
-       # betas, but not the final release of the current rev (0.1.0).
-       die "Fuse perl bindings need MacFUSE version 0.1.0b006 or newer, your version is \"$ver3\"\n";
+
+sub test_via_script {
+    my($self, $perl, $tests) = @_;
+    local $_ = $self->SUPER::test_via_script($perl, $tests);
+    s/PERL_DL_NONLAZY=1//g if $^O eq 'darwin';
+    return $_;
+}
+
+package main;
+
+chomp(my $fusever = `pkg-config --modversion fuse 2> /dev/null`);
+# Required for refuse on NetBSD
+if (!$fusever && $^O eq 'netbsd') {
+    chomp($fusever = `fusermount -V`);
+    $fusever =~ s/^.*?version:\s+//;
+}
+
+unless ($fusever) {
+    # make CPANPLUS happy and don't report errors if fuse isn't installed
+    my $explanation;
+    if ($^O eq 'linux') {
+        if (-e '/etc/debian_version') {
+            $explanation = 'You need to install "libfuse-dev" to provide build support for this module';
+        }
+        elsif (-e '/etc/redhat-release') {
+            $explanation = 'You need to install "fuse-devel" to provide build support for this module';
+        }
+        else {
+            $explanation = 'I don\'t know your Linux distribution, but please install the FUSE libraries and headers to build this module';
+        }
+    }
+    elsif ($^O eq 'freebsd') {
+        $explanation = 'You need to install the "fusefs-libs" package from ports to support this module';
+    }
+    elsif ($^O eq 'netbsd') {
+        $explanation = 'Could not find librefuse? Maybe install "perfuse" from pkgsrc, or upgrade to newer NetBSD';
+    }
+    elsif ($^O eq 'darwin') {
+        $explanation = 'Please install OSXFUSE from http://osxfuse.github.com/';
+    }
+    else {
+        $explanation = 'There is no FUSE support for your platform to our knowledge, sorry';
+    }
+    die("Cannot build for platform: $^O\n", $explanation, "\n");
+}
+if ($fusever && $fusever + 0 < 2.6) {
+    die "FUSE API is ", $fusever, ", must be 2.6 or later\n";
 } else {
-       warn "fuse version found: ", $ver || $ver2 || $ver3, "\n";
+    warn "fuse version found: ", $fusever, "\n";
 }
 
-my $inc = '-DFUSE_USE_VERSION=25 ' . `pkg-config --cflags fuse` || '-I ../include -D_FILE_OFFSET_BITS=64';
-my $obj = `pkg-config --libs fuse` || '-lfuse';
-my $def = '-Wall -g -ggdb';
-$def .= ' -D__FreeBSD__=10 -D_FILE_OFFSET_BITS=64' if $^O eq 'darwin';
+chomp(my $inc = `pkg-config --cflags-only-I fuse 2> /dev/null`);
+chomp(my $libs = `pkg-config --libs-only-L fuse 2> /dev/null`);
+chomp($libs .= `pkg-config --libs-only-l fuse 2> /dev/null` || (($^O eq 'netbsd') ? '-lrefuse' : '-lfuse'));
+# Needed for Fuse on OS X 10.6, due to 10.6 and up always using the 64-bit
+# inode structs; unfortunately MacFuse doesn't just do the right thing
+# on its own. (Not applicable for OSXFUSE; it uses a new SONAME, so we
+# don't have to worry about conflicts/compatibility, it "just works".)
+if ($^O eq 'darwin' && (uname())[2] =~ /^1[01]\./) {
+    $libs =~ s/-lfuse\b/-lfuse_ino64/;
+}
+chomp(my $def = '-Wall -DFUSE_USE_VERSION=26 ' . `pkg-config --cflags-only-other fuse 2> /dev/null` || '-D_FILE_OFFSET_BITS=64');
+chomp($def .= `pkg-config --libs-only-other fuse 2> /dev/null`);
+$def .= ' -DPERL_HAS_64BITINT' if $Config{'use64bitint'};
 
 WriteMakefile(
-       'NAME'                  => 'Fuse',
-       'VERSION_FROM'  => 'Fuse.pm', # finds $VERSION
-       'PREREQ_PM'             => {}, # e.g., Module::Name => 1.1
-       ($] >= 5.005 ?  ## Add these new keywords supported since 5.005
-               (ABSTRACT_FROM  => 'Fuse.pm', # retrieve abstract from module
-               AUTHOR                  => 'Mark Glines <mark@glines.org>') : ()),
-               ($ExtUtils::MakeMaker::VERSION < 6.46 ? () : (
-                       META_MERGE => {
-                               resources => {
-                               bugtracker => 'https://rt.cpan.org/Public/Dist/Display.html?Name=Fuse',
-                               repository => 'http://github.com/dpavlin/perl-fuse'
-                       }
-               })
-       ),
-       'LIBS'                  => [''], # e.g., '-lm'
-       'DEFINE'                => $def, # e.g., '-DHAVE_SOMETHING'
-       # Insert -I. if you add *.h files later:
-       'INC'                   => $inc, # e.g., '-I/usr/include/other'
-       # Un-comment this if you add C files to link with later:
-       'OBJECT'                => "$obj Fuse.o -lpthread", # link all the C files too
+    'NAME'          => 'Fuse',
+    'VERSION_FROM'  => 'Fuse.pm', # finds $VERSION
+    'PREREQ_PM'     => { # e.g., Module::Name => 1.1
+        'Lchown'            => 0,
+        'Filesys::Statvfs'  => 0,
+        'Unix::Mknod'       => 0,
+    },
+    ($] >= 5.005 ?  ## Add these new keywords supported since 5.005
+       (ABSTRACT_FROM   => 'Fuse.pm', # retrieve abstract from module
+        AUTHOR          => 'Mark Glines <mark@glines.org>') : ()),
+    ($ExtUtils::MakeMaker::VERSION < 6.3002 ? () : (
+        'LICENSE' => 'LGPL_2_1',
+    )),
+    ($ExtUtils::MakeMaker::VERSION < 6.46 ? () : (
+        META_MERGE => {
+            resources => {
+                license => 'http://www.gnu.org/licenses/lgpl-2.1.html',
+                bugtracker => 'https://rt.cpan.org/Public/Dist/Display.html?Name=Fuse',
+                repository => 'http://github.com/dpavlin/perl-fuse'
+            },
+        })
+    ),
+    'LIBS'          => '-lpthread ' . $libs, # e.g., '-lm'
+    'DEFINE'        => $def, # e.g., '-DHAVE_SOMETHING'
+    'OPTIMIZE'      => '-g -ggdb',
+    # Insert -I. if you add *.h files later:
+    'INC'           => $inc, # e.g., '-I/usr/include/other'
+    # Un-comment this if you add C files to link with later:
+    'OBJECT'        => 'Fuse$(OBJ_EXT)', # link all the C files too
 );
 
 sub MY::postamble {
-       return <<'MAKE_MORE';
+    return <<'MAKE_MORE';
 
 cpan:
        make clean
@@ -75,3 +134,5 @@ sf:
 
 MAKE_MORE
 };
+
+# vim: ts=4 ai et hls