X-Git-Url: http://git.shadowcat.co.uk/gitweb/gitweb.cgi?a=blobdiff_plain;f=Makefile.PL;h=7a4ea860d7a0b7b78dab1a8589d7f0f71060a771;hb=be06d3b055e9040a1d009987c83c601a6b5823fc;hp=050fca77e4b007b5b66fb3e33028a47e0c424588;hpb=bb543d7f2801453d43998f7a47f92c4ec0d8c2cc;p=gitmo%2FMouse.git diff --git a/Makefile.PL b/Makefile.PL old mode 100755 new mode 100644 index 050fca7..7a4ea86 --- a/Makefile.PL +++ b/Makefile.PL @@ -1,92 +1,144 @@ -BEGIN{ $INC{'Module/Install/ExtraTests.pm'} = __FILE__ } # to disable the use of ExtrTests +# COMPAT_TEST=1 genrates Moose compatible tests +# for developpers: +BEGIN{ + if(grep{ $_ eq '--author' } @ARGV){ + print "$^X -S cpanm < author/requires.cpanm\n"; + system "$^X -S cpanm < author/requires.cpanm"; + } +} + use strict; use warnings; -use inc::Module::Install; +use inc::Module::Install 1.00; -system($^X, 'author/generate-mouse-tiny.pl', 'lib/Mouse/Tiny.pm') == 0 - or warn "Cannot generate Mouse::Tiny: $!"; +# for co-developpers +use Module::Install::XSUtil 0.30; +use Module::Install::AuthorTests; 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; - -for (@ARGV) { - /^--pp$/ and $use_xs = 0; - /^--xs$/ and $use_xs = 1; +test_requires 'Test::More' => 0.88; +test_requires 'Test::Requires' => 0.06; # works on 5.6.0 +test_requires 'Test::Exception::LessClever' => 0.005; + +# to keep zero-dependencies +include 'Test::Exception::LessClever'; +include 'Test::Requires'; + +my %suggests = ( + 'Any::Moose' => 0.10, + + 'MouseX::AttributeHelpers' => 0.06, + 'MouseX::NativeTraits' => 1.00, +); +while(my($mod, $least) = each %suggests){ + my $status = system $^X, '-e', <<"CHECK"; +if(eval q{ use $mod (); 1 }) { + if(eval q{ use $mod $least (); 1 }) { + exit 0; # installd, and new enough + } + else { + exit 1; # installed, but too old + } } - -if($] < 5.008_001){ - $use_xs = 0; +CHECK + + if($status != 0){ + my $ver = `$^X -e "use $mod (); print $mod->VERSION"`; + warn("\n", + "WARNING: $mod is installed, but its version ($ver) is too old (< $least).\n", + " Please update $mod after installation of Mouse.\n", + "\n" + ); + } } -if(!defined $use_xs){ - $use_xs = eval { - require ExtUtils::CBuilder; - ExtUtils::CBuilder->new(quiet => 1)->have_compiler(); - }; -} +# cc_want deals with the '--pp' and '--xs' options +my $use_xs = ($] >= 5.008_001 && want_xs()); if($use_xs){ - require Module::Install::XSUtil; - Module::Install::XSUtil->VERSION(0.15); # for co-developpers + print "Mouse configured with XS.\n"; use_ppport(3.19); + use_xshelper(); cc_warnings(); cc_src_paths('xs-src'); - - print "Mouse configured in XS (--xs)\n"; } + if($use_xs){ + # repeat testing + # see also ExtUtils::MM_Any::test_via_harness() + my $t_pp = q{$(FULLPERLRUN) -MExtUtils::Command::MM -e} + .q{ "do 'tool/force-pp.pl'; test_harness($(TEST_VERBOSE), 'inc', '$(INST_LIB)', '$(INST_ARCHLIB)')"} + .q{ $(TEST_FILES)} . "\n"; + + postamble qq{test_pp :: pure_all\n} + . qq{\t} . $t_pp; + if($Module::Install::AUTHOR) { + postamble qq{test :: test_pp }; + } + } 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; +tests 't/*.t t/*/*.t'; +author_tests 'xt'; - if (eval{ require Moose; Moose->VERSION($require_version) }) { - if (eval 'use Module::Install::AuthorTests; 1') { - do 'author/create-moose-compatibility-tests.pl'; - recursive_author_tests('xt'); - } else { - print "you don't have a M::I::AuthorTests.\n"; - } - } else { - print "you don't have Moose $require_version. skipping moose compatibility test\n"; - } +repository 'git://git.moose.perl.org/Mouse.git'; - if($use_xs){ +system($^X, 'tool/generate-mouse-tiny.pl', 'lib/Mouse/Tiny.pm') == 0 + or warn "Cannot generate Mouse::Tiny: $!"; +makemaker_args PL_FILES => { + 'tool/generate-mouse-tiny.pl' => 'lib/Mouse/Tiny.pm', +}; + +if ($Module::Install::AUTHOR) { + require 'lib/Mouse/Spec.pm'; # for the version + my $require_version = Mouse::Spec->MooseVersion; + + if ($ENV{COMPAT_TEST} + && eval { require Moose; Moose->VERSION($require_version) }) { + print "You have Moose ", Moose->VERSION, ".\n"; + do 'tool/create-moose-compatibility-tests.pl'; # 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{ $(TEST_FILES)} . "\n"; + my $t_moose = q{$(FULLPERLRUN) -MExtUtils::Command::MM -e} + .q{ "test_harness($(TEST_VERBOSE), 'inc', '$(INST_LIB)', '$(INST_ARCHLIB)')"} + .q{ xt/compat/t/*/*.t } . "\n"; - postamble qq{test_dynamic :: test_pp\n\n} - . qq{test_pp :: pure_all\n} - . qq{\t} . $test_via_harness; + postamble qq{test :: test_moose\n\n} + . qq{test_moose :: pure_all\n} + . qq{\t} . $t_moose; + } else { + print "You don't have Moose $require_version. skipping moose compatibility test\n"; } + + + # Hack to disable Test::Exception, which might pull a perl internal bug. + # See also Test::Exception::LessClever. + open my $out, '>', 'inc/Test/Exception.pm' or die $!; + print $out <<'EOT'; +package Test::Exception; # wapper to T::E::LessClever +require Test::Exception::LessClever; +$INC{'Test/Exception.pm'} = __FILE__; +sub import { + shift; + Test::Exception::LessClever->export_to_level(1, @_); +} +1; +EOT + close $out or die $!; } -clean_files 'lib/Mouse/Tiny.pm $(O_FILES)'; +clean_files q{ + lib/Mouse/Tiny.pm $(O_FILES) test-mydeps-*.log + *.out + cover_db xs-src/*.gc{v,no,da} +}; WriteAll check_nmake => 0;