X-Git-Url: http://git.shadowcat.co.uk/gitweb/gitweb.cgi?a=blobdiff_plain;f=Makefile.PL;h=9fe331c40f89a6d5e73dad051effe30a9075693b;hb=d37aa91528eeb9294dfe7f54f090298a85bd4355;hp=51d31fd328d6b81a957ec0c78db136d5abdba5e7;hpb=adfe7ead04d6f4431a624299c529d6ff3a396166;p=catagits%2FCatalyst-Runtime.git diff --git a/Makefile.PL b/Makefile.PL index 51d31fd..9fe331c 100644 --- a/Makefile.PL +++ b/Makefile.PL @@ -1,31 +1,174 @@ -# Note: this file was auto-generated by Module::Build::Compat version 0.03 - - unless (eval "use Module::Build::Compat 0.02; 1" ) { - print "This module requires Module::Build to install itself.\n"; - - require ExtUtils::MakeMaker; - my $yn = ExtUtils::MakeMaker::prompt - (' Install Module::Build now from CPAN?', 'y'); - - unless ($yn =~ /^y/i) { - die " *** Cannot install without Module::Build. Exiting ...\n"; +use inc::Module::Install 0.64; + +perl_version '5.008001'; + +name 'Catalyst-Runtime'; +all_from 'lib/Catalyst/Runtime.pm'; + +requires 'namespace::clean'; +requires 'Scope::Upper' => '0.06'; +requires 'MooseX::MethodAttributes::Inheritable' => '0.03'; +requires 'MooseX::Emulate::Class::Accessor::Fast' => '0.00800'; +requires 'Moose' => '0.70'; +requires 'Carp'; +requires 'Class::C3::Adopt::NEXT' => '0.07'; +requires 'Class::MOP'; +requires 'CGI::Simple::Cookie'; +requires 'Data::Dump'; +requires 'File::Modified'; +requires 'HTML::Entities'; +requires 'HTTP::Body' => '1.04'; # makes uploadtmp work +requires 'HTTP::Headers' => '1.64'; +requires 'HTTP::Request'; +requires 'HTTP::Response'; +requires 'HTTP::Request::AsCGI' => '0.5'; +requires 'LWP::UserAgent'; +requires 'Module::Pluggable' => '3.01'; +requires 'Path::Class' => '0.09'; +requires 'Scalar::Util'; +requires 'Sub::Exporter'; +requires 'Text::SimpleTable' => '0.03'; +requires 'Time::HiRes'; +requires 'Tree::Simple' => '1.15'; +requires 'Tree::Simple::Visitor::FindByPath'; +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'))) { + tests join q{ }, + grep { $_ ne 't/aggregate.t' } + map { glob } qw[t/*.t t/aggregate/*.t]; +} +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 ($^O eq 'darwin') { + my $osx_ver = `/usr/bin/sw_vers -productVersion`; + chomp $osx_ver; + + # TAR on 10.4 wants COPY_EXTENDED_ATTRIBUTES_DISABLE + # On 10.5 (Leopard) it wants COPYFILE_DISABLE + my $attr = $osx_ver eq '10.5' ? 'COPYFILE_DISABLE' : 'COPY_EXTENDED_ATTRIBUTES_DISABLE'; + + makemaker_args(dist => { PREOP => qq{\@if [ "\$\$$attr" != "true" ]; then}. + qq{ echo "You must set the ENV variable $attr to true,"; }. + ' echo "to avoid getting resource forks in your dist."; exit 255; fi' }); + } +} + +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; } - - require Cwd; - require File::Spec; - require CPAN; - - # Save this 'cause CPAN will chdir all over the place. - my $cwd = Cwd::cwd(); - my $makefile = File::Spec->rel2abs($0); - - CPAN::Shell->install('Module::Build::Compat') - or die " *** Cannot install without Module::Build. Exiting ...\n"; - - chdir $cwd or die "Cannot chdir() back to $cwd: $!"; } - eval "use Module::Build::Compat 0.02; 1" or die $@; - use lib '_build/lib'; - Module::Build::Compat->run_build_pl(args => \@ARGV); - require Module::Build; - Module::Build::Compat->write_makefile(build_class => 'Module::Build'); + $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: + + This library is for running Catalyst applications. + + For development and use of catalyst.pl and myapp_create.pl, make sure + you also install the development tools package Catalyst::Devel. + + perl -MCPANPLUS -e 'install Catalyst::Devel' # or + perl -MCPAN -e 'install Catalyst::Devel' + + To get some commonly used plugins, as well as the TT view and DBIC + model, install Task::Catalyst in the same way. + + 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; +}