X-Git-Url: http://git.shadowcat.co.uk/gitweb/gitweb.cgi?p=gitmo%2FMouse.git;a=blobdiff_plain;f=Makefile.PL;h=feac472809f28d0ea244c71fabf862e7dd7994f9;hp=e6a0c6724796c2ed2defc65266686d2393acdc74;hb=31aa6299ca20515174f1b145e5b3d4dbd9e09a08;hpb=df6dd016657118a06b408d21767dbc9b4ca476b9 diff --git a/Makefile.PL b/Makefile.PL old mode 100755 new mode 100644 index e6a0c67..feac472 --- a/Makefile.PL +++ b/Makefile.PL @@ -1,146 +1,152 @@ +# 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; +BEGIN { + unshift @INC, 'inc'; + + # author requires, or bundled modules + my @devmods = qw( + inc::Module::Install 1.00 + Module::Install::TestTarget 0.13 + Module::Install::AuthorTests 0.002 + Module::Install::XSUtil 0.36 + Test::Exception::LessClever 0.005 + Test::Requires 0.06 + ); + my @not_available; + while(my($mod, $ver) = splice @devmods, 0, 2) { + eval qq{use $mod $ver (); 1} or push @not_available, $mod; + } + if(@not_available) { + print qq{# The following modules are not available.\n}; + print qq{# `perl $0 | cpanm` will install them:\n}; + print $_, "\n" for @not_available; + exit 1; + } +} use inc::Module::Install; -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; -test_requires 'Test::More' => 0.88; -test_requires 'Test::Exception' => 0.27; -# test_requires 'Test::Output' => 0.16; # too many dependencies! +test_requires 'Test::More' => 0.88; -include 'Test::Exception'; # work around 0.27_0x (its use of diehook might be wrong) +# to keep zero-dependencies +include 'Test::Exception::LessClever'; +include 'Test::Requires'; -recommends 'MRO::Compat' if $] < 5.010; +my %suggests = ( + 'Any::Moose' => 0.10, -my $use_xs; - -for (@ARGV) { - /^--pp$/ and $use_xs = 0; - /^--xs$/ and $use_xs = 1; + '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(!defined $use_xs){ - configure_requires 'ExtUtils::CBuilder'; - require ExtUtils::CBuilder; - $use_xs = ExtUtils::CBuilder->new(quiet => 1)->have_compiler(); +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" + ); + } } +# cc_want deals with the '--pp' and '--xs' options +my $use_xs = ($] >= 5.008_001 && want_xs()); + if($use_xs){ - require Module::Install::XSUtil; + 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){ + test_target test_pp => ( + env => { PERL_ONLY => 1 }, + ($Module::Install::AUTHOR ? (alias => 'test') : ()), + ); + } } else{ - print "Mouse configured in Pure Perl (--pp)\n"; + print "Mouse configured with Pure Perl.\n"; } +tests 't/*.t t/*/*.t'; +author_tests 'xt'; + +homepage 'http://git.shadowcat.co.uk/gitweb/gitweb.cgi?p=gitmo/Mouse.git'; +repository 'git://git.moose.perl.org/Mouse.git'; +# or web interface: +# http://git.shadowcat.co.uk/gitweb/gitweb.cgi?p=gitmo/Mouse.git;a=summary + +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) { - local @INC = ('lib', @INC); - require 'lib/Mouse/Spec.pm'; + require 'lib/Mouse/Spec.pm'; # for the version my $require_version = Mouse::Spec->MooseVersion; - if (eval{ require Moose; Moose->VERSION($require_version) }) { - if (eval 'use Module::Install::AuthorTests; 1') { - create_moose_compatibility_test(); - recursive_author_tests('xt'); - } else { - print "you don't have a M::I::AuthorTests.\n"; - } + 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'; + test_target test_moose => ( + tests => ['xt/compat/t/*/*.t'], + alias => 'test', + ); } else { - print "you don't have Moose $require_version. skipping moose compatibility test\n"; + print "You don't have Moose $require_version. skipping moose compatibility test\n"; } -} - -clean_files 'lib/Mouse/Tiny.pm'; - -WriteAll check_nmake => 0; - -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 :(", - '810-isa-or.t' => "Mouse has a [BUG]", - - '052-undefined-type-in-union.t' => "Mouse accepts undefined type as a member of union types", - '054-anon-leak.t' => 'Moose has memory leaks', - - '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 which are Moose specific - - return if /with_moose/; # tests with Moose - return if /100_bugs/; # some tests require Mouse specific files - return if /deprecated/; - - 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::(?:Util::)?is_class_loaded/Class::MOP::is_class_loaded/g; - $src =~ s/Mouse::(?:Util::)?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"; + # 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 q{ + lib/Mouse/Tiny.pm $(O_FILES) test-mydeps-*.log + xshelper.h + *.out + cover_db xs-src/*.gc{v,no,da} +}; + +WriteAll check_nmake => 0;