X-Git-Url: http://git.shadowcat.co.uk/gitweb/gitweb.cgi?a=blobdiff_plain;f=Makefile.PL;h=45d8a170af1558374c916d85623521044dddbab3;hb=3821b191b0493223e0f67b05ad351e3753fcfc66;hp=1c2a121bbe0def41fa2064cc472f001b5bfc4d9f;hpb=7b92a82b2c23a9003e5f736e85008111c904acc4;p=gitmo%2FMouse.git diff --git a/Makefile.PL b/Makefile.PL index 1c2a121..45d8a17 100755 --- a/Makefile.PL +++ b/Makefile.PL @@ -2,54 +2,52 @@ use strict; use warnings; use inc::Module::Install; -system($^X, 'author/generate-mouse-tiny.pl', 'lib/Mouse/Tiny.pm') == 0 +# for co-developpers +use Module::Install::XSUtil 0.17; + +system($^X, 'tool/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; -configure_requires 'ExtUtils::CBuilder'; - test_requires 'Test::More' => 0.88; test_requires 'Test::Exception' => 0.27; # test_requires 'Test::Output' => 0.16; # too many dependencies! - include_deps 'Test::Exception'; # work around 0.27_0x (its use of diehook might be wrong) recommends 'MRO::Compat' if $] < 5.010; -my $use_xs; +require 'lib/Mouse/Spec.pm'; # for the version -for (@ARGV) { - /^--pp$/ and $use_xs = 0; - /^--xs$/ and $use_xs = 1; +if(Mouse::Spec->MouseVersion =~ /_/){ # DEVEL RELEASE + require Carp::Always; Carp::Always->import(); + include_deps 'Carp::Always'; } +my $use_xs; + if($] < 5.008_001){ $use_xs = 0; } +for (@ARGV) { + /^--pp$/ and $use_xs = 0; + /^--xs$/ and $use_xs = 1; +} + if(!defined $use_xs){ - $use_xs = eval { - require ExtUtils::CBuilder; - ExtUtils::CBuilder->new(quiet => 1)->have_compiler(); - }; + $use_xs = cc_available(); } if($use_xs){ print "Mouse configured with XS.\n", - "You can try --pp option to configure it with Pure Perl.\n"; - ; - - require Module::Install::XSUtil; - Module::Install::XSUtil->VERSION(0.15); # for co-developpers + "NOTE: You can try --pp option to configure Mouse with Pure Perl.\n"; use_ppport(3.19); cc_warnings(); @@ -60,13 +58,11 @@ else{ } 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') { - do 'author/create-moose-compatibility-tests.pl'; + if (eval { require Moose; Moose->VERSION($require_version) }) { + if (eval { require Module::Install::AuthorTests }) { + do 'tool/create-moose-compatibility-tests.pl'; recursive_author_tests('xt'); } else { print "you don't have a M::I::AuthorTests.\n"; @@ -79,7 +75,7 @@ if (author_context()) { # repeat testing # see also ExtUtils::MM_Any::test_via_harness() my $test_via_harness = q{$(FULLPERLRUN) -MExtUtils::Command::MM -e} - .q{ "do 'author/force-pp.pl'; test_harness($(TEST_VERBOSE), '$(INST_LIB)', '$(INST_ARCHLIB)')"} + .q{ "do 'tool/force-pp.pl'; test_harness($(TEST_VERBOSE), '$(INST_LIB)', '$(INST_ARCHLIB)')"} .q{ $(TEST_FILES)} . "\n"; postamble qq{test_dynamic :: test_pp\n\n} @@ -88,6 +84,10 @@ if (author_context()) { } } +repository 'git://git.moose.perl.org/Mouse.git'; + +tests 't/*.t t/*/*.t'; + clean_files 'lib/Mouse/Tiny.pm $(O_FILES)'; WriteAll check_nmake => 0;