X-Git-Url: http://git.shadowcat.co.uk/gitweb/gitweb.cgi?p=gitmo%2FMouse.git;a=blobdiff_plain;f=Makefile.PL;h=d83108e70875eba7dd898ed2f5ac756761fb0e9e;hp=a54311cd0b4e62e83dfac7a38714d9fabcc09af5;hb=4aaed9e5cc435a2085e46f4c98a3abc233ecacaf;hpb=08f7a8dbc5e48fcece4396a500d37bb2c6e45b74 diff --git a/Makefile.PL b/Makefile.PL index a54311c..d83108e 100755 --- a/Makefile.PL +++ b/Makefile.PL @@ -1,108 +1,113 @@ use strict; use warnings; use inc::Module::Install; -use 5.008; + +# for co-developpers +use Module::Install::XSUtil 0.21; + +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; -build_requires 'Test::Exception' => 0.21; -build_requires 'Test::More' => 0.80; +test_requires 'Test::More' => 0.88; +test_requires 'Test::Exception' => 0.29; +# test_requires 'Test::Output' => 0.16; # too many dependencies! + +if($] < 5.010) { + recommends 'Class::C3'; +} + +my %suggests = ( + 'Class::Method::Modifiers::Fast' => 0.041, + 'MouseX::AttributeHelpers' => 0.06, +); + +while(my($mod, $least) = each %suggests){ + if(can_use($mod)){ + if(!eval { $mod->VERSION($least) }){ + my $ver = $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" + ); + } + } +} + +require 'lib/Mouse/Spec.pm'; # for the version + +#if(Mouse::Spec->MouseVersion =~ /_/){ # DEVEL RELEASE +# require Carp::Always; Carp::Always->import(); +# include_deps 'Carp::Always'; +#} + +# cc_available recognizes the '--pp' and '--xs' options +my $use_xs = ($] >= 5.008_001 && cc_available()); + +if($use_xs){ + print "Mouse configured with XS.\n", + "NOTE: You can try --pp option to configure Mouse with Pure Perl.\n"; + + cc_warnings(); + use_ppport(3.19); + cc_src_paths('xs-src'); +} +else{ + print "Mouse configured with Pure Perl.\n"; +} + + +tests 't/*.t t/*/*.t'; +author_tests 'xt'; + + +repository 'git://git.moose.perl.org/Mouse.git'; + +clean_files 'lib/Mouse/Tiny.pm $(O_FILES)'; -if ($Module::Install::AUTHOR) { - if (eval "package foo; use Moose; 1;") { - if (eval 'use Module::Install::AuthorTests; 1') { - create_moose_compatibility_test(); - recursive_author_tests('xt'); + +if (author_context()) { + my $require_version = Mouse::Spec->MooseVersion; + + if (eval { require Moose; Moose->VERSION($require_version) }) { + print "You have Moose ", Moose->VERSION, ".\n"; + if (eval { require Module::Install::AuthorTests }) { + do 'tool/create-moose-compatibility-tests.pl'; + # repeat testing + # see also ExtUtils::MM_Any::test_via_harness() + my $t_moose = q{$(FULLPERLRUN) -MExtUtils::Command::MM -e} + .q{ "test_harness($(TEST_VERBOSE), '$(INST_LIB)', '$(INST_ARCHLIB)')"} + .q{ xt/compatibility/t/*/*.t } . "\n"; + + postamble qq{test_dynamic :: test_moose\n\n} + . qq{test_moose :: pure_all\n} + . qq{\t} . $t_moose; } else { - print "you don't have a M::I::AuthorTests.\n"; + print "You don't have a M::I::AuthorTests.\n"; } } else { - print "you don't have a moose. skipping moose compatibility test\n"; + print "You don't have Moose $require_version. skipping moose compatibility test\n"; } - system("author/generate-mouse-tiny.pl"); -} -auto_include; -WriteAll; - -sub create_moose_compatibility_test { - require File::Path; - require File::Spec; - require File::Basename; - - print "Creating compatibility tests in xt/compatibility/* ...\n"; - - File::Path::rmtree(File::Spec->catfile('xt', 'compatibility')); - - # some test does not pass... currently skip it. - my %SKIP_TEST = ( - '016-trigger.t' => "trigger's argument is incompatble :(", -# '020-load-class.t' => "&Moose::is_class_loaded doesn't exists", - '019-handles.t' => 'incompatible', - '029-new.t' => 'Class->new(undef) incompatible', - '010-isa-or.t' => 'Mouse has a [BUG]', - '044-attribute-metaclass.t' => 'Moose::Meta::Attribute does not have a "create"', - '047-attribute-metaclass-role.t' => 'Moose::Meta::Attribute does not have a "create"', - '201-squirrel.t' => 'skip Squirrel', - '202-squirrel-role.t' => 'Squirrel is ...', - '600-tiny-tiny.t' => "Moose doesn't support ::Tiny", - '601-tiny-mouse.t' => "Moose doesn't support ::Tiny", - '602-mouse-tiny.t' => "Moose doesn't support ::Tiny", - '031_roles_applied_in_create.t' => 't/lib/* classes are not Moose classes/roles', - ); - - my @compat_tests; - - File::Find::find( - { - wanted => sub { - return unless -f $_; - - return if /failing/; # skip tests in failing/ directories - - my $basename = File::Basename::basename($_); - return if $basename =~ /^\./; - - if(exists $SKIP_TEST{$basename}){ - print "# skip $basename because: $SKIP_TEST{$basename}\n"; - return; - } - - my $dirname = File::Basename::dirname($_); - - my $tmpdir = File::Spec->catfile('xt', 'compatibility', $dirname); - File::Path::mkpath($tmpdir); - - my $tmpfile = File::Spec->catfile($tmpdir, $basename); - open my $wfh, '>', $tmpfile or die $!; - print $wfh do { - my $src = do { - open my $rfh, '<', $_ or die $!; - my $s = do { local $/; <$rfh> }; - close $rfh; - $s; - }; - $src =~ s/Mouse::is_class_loaded/Class::MOP::is_class_loaded/g; - $src =~ s/Mouse::load_class/Class::MOP::load_class/g; - $src =~ s/Mouse/Moose/g; - $src; - }; - close $wfh; - push @compat_tests, $tmpfile; - }, - no_chdir => 1 - }, - 't', - ); - print "Compatibility tests created.\n"; - - clean_files "@compat_tests"; + 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), '$(INST_LIB)', '$(INST_ARCHLIB)')"} + .q{ $(TEST_FILES)} . "\n"; + + postamble qq{test_dynamic :: test_pp\n\n} + . qq{test_pp :: pure_all\n} + . qq{\t} . $t_pp; + } } + +WriteAll check_nmake => 0;