X-Git-Url: http://git.shadowcat.co.uk/gitweb/gitweb.cgi?a=blobdiff_plain;f=lib%2FCatalyst.pm;h=dfa002ab323fe85981d83e4e61a330169065ea83;hb=111728e3d4b1ebfa3e80ec469d03616a45571fa1;hp=b9cdcb44836d251e79fc032c81ef011cda48f98a;hpb=424b2705f759cef65acfaf8ea0f43e6bef75b534;p=catagits%2FCatalyst-Runtime.git diff --git a/lib/Catalyst.pm b/lib/Catalyst.pm index b9cdcb4..dfa002a 100644 --- a/lib/Catalyst.pm +++ b/lib/Catalyst.pm @@ -5,7 +5,6 @@ use base 'Catalyst::Base'; use UNIVERSAL::require; use Catalyst::Log; use Text::ASCIITable; -use Text::ASCIITable::Wrap 'wrap'; __PACKAGE__->mk_classdata($_) for qw/dispatcher engine log/; @@ -127,6 +126,7 @@ sub import { my ( $self, @options ) = @_; my $caller = caller(0); + # Prepare inheritance unless ( $caller->isa($self) ) { no strict 'refs'; push @{"$caller\::ISA"}, $self; @@ -140,6 +140,7 @@ sub import { $caller->log( Catalyst::Log->new ); } + # Debug? if ( $ENV{CATALYST_DEBUG} || $ENV{ uc($caller) . '_DEBUG' } ) { no strict 'refs'; *{"$caller\::debug"} = sub { 1 }; @@ -149,50 +150,57 @@ sub import { my $engine = 'Catalyst::Engine::CGI'; my $dispatcher = 'Catalyst::Dispatcher'; + # Detect mod_perl if ( $ENV{MOD_PERL} ) { require mod_perl; if ( $mod_perl::VERSION >= 1.99 ) { - $engine = 'Catalyst::Engine::Apache::MP2'; + $engine = 'Catalyst::Engine::Apache::MP19'; } else { - $engine = 'Catalyst::Engine::Apache::MP1'; + $engine = 'Catalyst::Engine::Apache::MP13'; } } + # Process options my @plugins; foreach (@options) { + if (/^\-Debug$/) { next if $caller->debug; no strict 'refs'; *{"$caller\::debug"} = sub { 1 }; $caller->log->debug('Debug messages enabled'); } + elsif (/^-Dispatcher=(.*)$/) { $dispatcher = "Catalyst::Dispatcher::$1"; } + elsif (/^-Engine=(.*)$/) { $engine = "Catalyst::Engine::$1" } elsif (/^-.*$/) { $caller->log->error(qq/Unknown flag "$_"/) } + else { my $plugin = "Catalyst::Plugin::$_"; $plugin->require; - if ($@) { - $caller->log->error(qq/Couldn't load plugin "$plugin", "$@"/); - } + if ($@) { die qq/Couldn't load plugin "$plugin", "$@"/ } else { push @plugins, $plugin; no strict 'refs'; push @{"$caller\::ISA"}, $plugin; } } + } + + # Plugin table my $t = Text::ASCIITable->new( { hide_HeadRow => 1, hide_HeadLine => 1 } ); $t->setCols('Class'); $t->setColWidth( 'Class', 75, 1 ); - $t->addRow( wrap( $_, 75 ) ) for @plugins; + $t->addRow($_) for @plugins; $caller->log->debug( 'Loaded plugins', $t->draw ) if ( @plugins && $caller->debug );