X-Git-Url: http://git.shadowcat.co.uk/gitweb/gitweb.cgi?p=catagits%2FCatalyst-Runtime.git;a=blobdiff_plain;f=Makefile.PL;h=cc00a0909b9f5601cadec74cec47793f5686d9f8;hp=910922656b8c3bc0dda234bf67937f9523f91724;hb=dfa27f53795d92fb1b4f38dfbc17c6af3bdc4e86;hpb=a24c0135f19ff9b2fe78359c2aa10f5df3e9ab08 diff --git a/Makefile.PL b/Makefile.PL index 9109226..cc00a09 100644 --- a/Makefile.PL +++ b/Makefile.PL @@ -6,10 +6,11 @@ name 'Catalyst-Runtime'; all_from 'lib/Catalyst/Runtime.pm'; requires 'namespace::clean'; -requires 'MooseX::Emulate::Class::Accessor::Fast' => '0.00400'; -requires 'Moose' => '0.59'; +requires 'Scope::Upper' => '0.06'; +requires 'MooseX::Emulate::Class::Accessor::Fast' => '0.00800'; +requires 'Moose' => '0.70'; requires 'Carp'; -requires 'Class::C3::Adopt::NEXT'; +requires 'Class::C3::Adopt::NEXT' => '0.05'; requires 'Class::MOP'; requires 'CGI::Simple::Cookie'; requires 'Data::Dump'; @@ -33,7 +34,10 @@ requires 'URI' => '1.35'; requires 'Text::Balanced'; # core in 5.8.x but mentioned for completeness requires 'MRO::Compat'; +recommends 'B::Hooks::OP::Check::StashChange'; + test_requires 'Class::Data::Inheritable'; +test_requires 'Test::MockObject'; if ( ( exists $ENV{AGGREGATE_TESTS} && !$ENV{AGGREGATE_TESTS}) || (!exists $ENV{AGGREGATE_TESTS} && !can_use('Test::Aggregate', '0.34_01'))) { @@ -44,11 +48,19 @@ if ( ( exists $ENV{AGGREGATE_TESTS} && !$ENV{AGGREGATE_TESTS}) else { test_requires('Test::Aggregate', '0.34_01'); } +my @force_build_requires_if_author = qw( + Test::NoTabs + Test::Pod + Test::Pod::Coverage + Pod::Coverage +); + +if ($Module::Install::AUTHOR) { + + foreach my $module (@force_build_requires_if_author) { + build_requires $module; + } -if (-e 'inc/.author') { - build_requires 'Test::NoTabs'; - build_requires 'Test::Pod' => 1.14; - build_requires 'Test::Pod::Coverage' => 1.04; if ($^O eq 'darwin') { my $osx_ver = `/usr/bin/sw_vers -productVersion`; @@ -68,6 +80,31 @@ install_script glob('script/*.pl'); auto_install; WriteAll; +if ($Module::Install::AUTHOR) { + + # Strip out the author only build_requires from META.yml + # Need to do this _after_ WriteAll else it looses track of them + Meta->{values}{build_requires} = [ grep { + my $ok = 1; + foreach my $module (@force_build_requires_if_author) { + if ($_->[0] =~ /$module/) { + $ok = 0; + last; + } + } + $ok; + } @{Meta->{values}{build_requires}} ]; + + Meta->{values}{resources} = [ + [ 'MailingList', 'http://lists.scsys.co.uk/cgi-bin/mailman/listinfo/catalyst' ], + [ 'IRC', 'irc://irc.perl.org/#catalyst' ], + [ 'license', 'http://dev.perl.org/licenses/' ], + [ 'homepage', 'http://dev.catalyst.perl.org/'], + [ 'repository', 'http://dev.catalyst.perl.org/repos/Catalyst/Catalyst-Runtime/' ], + ]; + + Meta->write; +} print <<"EOF"; Important: @@ -85,3 +122,52 @@ print <<"EOF"; Have fun! EOF + +check_conflicts(); + +# Nicked straight from Moose! +sub check_conflicts { + # NOTE - This is the version number of the _incompatible_ code, + # not the version number of the fixed version. + my %conflicts = ( + 'Catalyst::Plugin::SmartURI' => '0.029', + 'CatalystX::CRUD' => '0.37', + 'Catalyst::Action::RenderView' => '0.07', + 'Catalyst::Plugin::DebugCookie' => '0.999002', + 'Catalyst::Plugin::Authentication' => '0.100091', + 'CatalystX::Imports' => '0.03', + 'Catalyst::Plugin::HashedCookies' => '1.03', + ); + + my $found = 0; + for my $mod ( sort keys %conflicts ) { + eval "require($mod)"; + next if $@; + + my $installed = $mod->VERSION(); + if ( $installed le $conflicts{$mod} ) { + + print <<"EOF"; + +*** + This version of Catalyst conflicts with the version of + $mod ($installed) you have installed. + + You will need to upgrade $mod after installing + this version of Catalyst. +*** + +EOF + + $found = 1; + } + } + + return unless $found; + + # More or less copied from Module::Build + return if $ENV{PERL_MM_USE_DEFAULT}; + return unless -t STDIN && (-t STDOUT || !(-f STDOUT || -c STDOUT)); + + sleep 4; +}