bump version to 1.06
[gitmo/Class-MOP.git] / Makefile.PL
index daeed08..c0af551 100644 (file)
@@ -1,13 +1,97 @@
-use ExtUtils::MakeMaker;
-WriteMakefile(
-    NAME         => 'Class::MOP',
-    VERSION_FROM => 'lib/Class/MOP.pm', 
-    PREREQ_PM    => {
-        'Test::More'      => '0.47',
-        'Test::Exception' => '0.21',    
-        'Scalar::Util'    => '1.17',
-        'Sub::Name'       => '0.02',
-        'Carp'            => '0.01',
-        'B'               => '0',
-    }
+use strict;
+use warnings;
+use inc::Module::Install;
+use 5.008001;
+
+check_conflicts();
+
+name 'Class-MOP';
+perl_version '5.008001';
+all_from 'lib/Class/MOP.pm';
+license 'perl';
+
+my %conflicts = (
+    'Moose' => '1.04',
 );
+
+check_conflicts(%conflicts);
+
+require Config;
+my $ccflags = ( $Config::Config{ccflags} || '' ) . ' -I.';
+
+if ( -d '.git' || $ENV{MAINTAINER_MODE} ) {
+    $ccflags .= ' -Wall -Wdeclaration-after-statement';
+}
+
+requires 'Carp';
+requires 'Data::OptList';
+requires 'Devel::GlobalDestruction';
+requires 'List::MoreUtils' => '0.12';
+requires 'MRO::Compat'  => '0.05';
+requires 'Package::DeprecationManager' => '0.04';
+requires 'Package::Stash';
+requires 'Scalar::Util' => '1.18';
+requires 'Sub::Name'    => '0.04';
+requires 'Try::Tiny'    => '0.02';
+requires 'Task::Weaken';
+
+test_requires 'File::Spec';
+test_requires 'Test::More'      => '0.88';
+test_requires 'Test::Exception' => '0.27';
+
+repository 'git://git.moose.perl.org/Class-MOP.git';
+add_metadata(x_authority => 'cpan:STEVAN');
+
+extra_tests();
+
+makemaker_args( CCFLAGS => $ccflags );
+
+{
+    my (@clean, @OBJECT, %XS);
+
+    for my $xs (<xs/*.xs>) {
+        (my $c = $xs) =~ s/\.xs$/.c/i;
+        (my $o = $xs) =~ s/\.xs$/\$(OBJ_EXT)/i;
+
+        $XS{$xs} = $c;
+        push @OBJECT, $o;
+        push @clean, $o;
+    }
+
+    for my $c (<*.c>) {
+        (my $o = $c) =~ s/\.c$/\$(OBJ_EXT)/i;
+        push @OBJECT, $o;
+        push @clean, $o;
+    }
+
+    makemaker_args(
+        clean  => { FILES => join(q{ }, @clean) },
+        OBJECT => join (q{ }, @OBJECT),
+        XS     => \%XS,
+    );
+}
+
+postamble(<<'EOM');
+$(OBJECT) : mop.h
+EOM
+
+WriteAll();
+
+package MY;
+
+use Config;
+
+sub const_cccmd {
+    my $ret = shift->SUPER::const_cccmd(@_);
+    return q{} unless $ret;
+
+    if ($Config{cc} =~ /^cl\b/i) {
+        warn 'you are using MSVC... my condolences.';
+        $ret .= ' /Fo$@';
+    }
+    else {
+        $ret .= ' -o $@';
+    }
+
+    return $ret;
+}