Makefile.PL requires Module::Install::XSUtil 0.21
[gitmo/Mouse.git] / Makefile.PL
index 45d8a17..314ab75 100755 (executable)
@@ -3,7 +3,7 @@ use warnings;
 use inc::Module::Install;
 
 # for co-developpers
-use Module::Install::XSUtil 0.17;
+use Module::Install::XSUtil 0.21;
 
 system($^X, 'tool/generate-mouse-tiny.pl', 'lib/Mouse/Tiny.pm') == 0
     or warn "Cannot generate Mouse::Tiny: $!";
@@ -21,54 +21,53 @@ test_requires 'Test::Exception' => 0.27;
 
 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';
+if($] < 5.010) {
+    recommends 'Class::C3';
 }
 
-my $use_xs;
-
-if($] < 5.008_001){
-    $use_xs = 0;
-}
+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';
+#}
 
-if(!defined $use_xs){
-    $use_xs = cc_available();
-}
+# 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";
 
-    use_ppport(3.19);
     cc_warnings();
+    use_ppport(3.19);
     cc_src_paths('xs-src');
 }
 else{
     print "Mouse configured with Pure Perl.\n";
 }
 
+
+tests 't/*.t t/*/*.t';
+
+repository 'git://git.moose.perl.org/Mouse.git';
+
+clean_files 'lib/Mouse/Tiny.pm $(O_FILES)';
+
+
 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';
             recursive_author_tests('xt');
         } 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 Moose $require_version. skipping moose compatibility test\n";
+        print "You don't have Moose $require_version. skipping moose compatibility test\n";
     }
 
     if($use_xs){
@@ -84,10 +83,4 @@ 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;