X-Git-Url: http://git.shadowcat.co.uk/gitweb/gitweb.cgi?a=blobdiff_plain;f=Makefile.PL;h=11fe390d8cafb658976172e9e81e1d83b8791c48;hb=5ecfc2defd2955d68c9cbc3ad048ce80bd1020da;hp=8e9ed086cba2763e0559f03aa397631c35d1b303;hpb=4358792dc58251272a77bb89d5f722e595c10a2c;p=gitmo%2FMouse.git diff --git a/Makefile.PL b/Makefile.PL index 8e9ed08..11fe390 100755 --- a/Makefile.PL +++ b/Makefile.PL @@ -1,16 +1,16 @@ -BEGIN{ $INC{'Module/Install/ExtraTests.pm'} = __FILE__ } # to disable the use of ExtrTests use strict; use warnings; use inc::Module::Install; +# for co-developpers +use Module::Install::XSUtil 0.17; + system($^X, 'author/generate-mouse-tiny.pl', 'lib/Mouse/Tiny.pm') == 0 or warn "Cannot generate Mouse::Tiny: $!"; name 'Mouse'; all_from 'lib/Mouse.pm'; -tests 't/*.t t/*/*.t'; - # Scalar::Util < 1.14 has a bug. # > Fixed looks_like_number(undef) to return false for perl >= 5.009002 requires 'Scalar::Util' => 1.14; @@ -19,10 +19,17 @@ test_requires 'Test::More' => 0.88; test_requires 'Test::Exception' => 0.27; # test_requires 'Test::Output' => 0.16; # too many dependencies! -include 'Test::Exception'; # work around 0.27_0x (its use of diehook might be wrong) +include_deps 'Test::Exception'; # work around 0.27_0x (its use of diehook might be wrong) recommends 'MRO::Compat' if $] < 5.010; +require 'lib/Mouse/Spec.pm'; # for the version + +if(Mouse::Spec->MouseVersion =~ /_/){ # DEVEL RELEASE + require Carp::Always; Carp::Always->import(); + include_deps 'Carp::Always'; +} + my $use_xs; for (@ARGV) { @@ -30,31 +37,31 @@ for (@ARGV) { /^--xs$/ and $use_xs = 1; } +if($] < 5.008_001){ + $use_xs = 0; +} + if(!defined $use_xs){ - configure_requires 'ExtUtils::CBuilder'; - require ExtUtils::CBuilder; - $use_xs = ExtUtils::CBuilder->new(quiet => 1)->have_compiler(); + $use_xs = cc_available(); } if($use_xs){ - require Module::Install::XSUtil; + print "Mouse configured with XS.\n", + "NOTE: You can try --pp option to configure Mouse with Pure Perl.\n"; + use_ppport(3.19); cc_warnings(); cc_src_paths('xs-src'); - - print "Mouse configured in XS (--xs)\n"; } else{ - print "Mouse configured in Pure Perl (--pp)\n"; + print "Mouse configured with Pure Perl.\n"; } if (author_context()) { - local @INC = ('lib', @INC); - require 'lib/Mouse/Spec.pm'; my $require_version = Mouse::Spec->MooseVersion; - if (eval{ require Moose; Moose->VERSION($require_version) }) { - if (eval 'use Module::Install::AuthorTests; 1') { + if (eval { require Moose; Moose->VERSION($require_version) }) { + if (eval { require Module::Install::AuthorTests }) { do 'author/create-moose-compatibility-tests.pl'; recursive_author_tests('xt'); } else { @@ -77,6 +84,8 @@ if (author_context()) { } } -clean_files 'lib/Mouse/Tiny.pm'; +tests 't/*.t t/*/*.t'; + +clean_files 'lib/Mouse/Tiny.pm $(O_FILES)'; WriteAll check_nmake => 0;