X-Git-Url: http://git.shadowcat.co.uk/gitweb/gitweb.cgi?p=catagits%2FCatalyst-Runtime.git;a=blobdiff_plain;f=lib%2FCatalyst.pm;h=de2f188f2b930138b1abcfff7157d7b762f35781;hp=7bf9f6acb2a25363ab6ae58685b98bf748478029;hb=cccc8f68ace5d11c3fdcbfc4e353225b3b574255;hpb=b94b200c22a5c08f9fa18db789914b3bd593f4b5 diff --git a/lib/Catalyst.pm b/lib/Catalyst.pm index 7bf9f6a..de2f188 100644 --- a/lib/Catalyst.pm +++ b/lib/Catalyst.pm @@ -931,6 +931,7 @@ sub uri_for { my $params = ( scalar @args && ref $args[$#args] eq 'HASH' ? pop @args : {} ); + carp "uri_for called with undef argument" if grep { ! defined $_ } @args; s/([^$URI::uric])/$URI::Escape::escapes{$1}/go for @args; unshift(@args, $path); @@ -1353,7 +1354,7 @@ sub finalize { if ($c->debug) { my $elapsed = sprintf '%f', tv_interval($c->stats->getNodeValue); - my $av = sprintf '%.3f', ( $elapsed == 0 ? '??' : ( 1 / $elapsed ) ); + my $av = $elapsed == 0 ? '??' : sprintf '%.3f', 1 / $elapsed; my $t = Text::SimpleTable->new( [ 62, 'Action' ], [ 9, 'Time' ] ); $c->stats->traverse( @@ -1923,13 +1924,8 @@ sub setup_dispatcher { $dispatcher = 'Catalyst::Dispatcher::' . $dispatcher; } - if ( $ENV{CATALYST_DISPATCHER} ) { - $dispatcher = 'Catalyst::Dispatcher::' . $ENV{CATALYST_DISPATCHER}; - } - - if ( $ENV{ uc($class) . '_DISPATCHER' } ) { - $dispatcher = - 'Catalyst::Dispatcher::' . $ENV{ uc($class) . '_DISPATCHER' }; + if ( my $env = Catalyst::Utils::env_value( $class, 'DISPATCHER' ) ) { + $dispatcher = 'Catalyst::Dispatcher::' . $env; } unless ($dispatcher) { @@ -1957,12 +1953,8 @@ sub setup_engine { $engine = 'Catalyst::Engine::' . $engine; } - if ( $ENV{CATALYST_ENGINE} ) { - $engine = 'Catalyst::Engine::' . $ENV{CATALYST_ENGINE}; - } - - if ( $ENV{ uc($class) . '_ENGINE' } ) { - $engine = 'Catalyst::Engine::' . $ENV{ uc($class) . '_ENGINE' }; + if ( my $env = Catalyst::Utils::env_value( $class, 'ENGINE' ) ) { + $engine = 'Catalyst::Engine::' . $env; } if ( $ENV{MOD_PERL} ) { @@ -2077,13 +2069,8 @@ Sets up the home directory. sub setup_home { my ( $class, $home ) = @_; - if ( $ENV{CATALYST_HOME} ) { - $home = $ENV{CATALYST_HOME}; - } - - if ( $ENV{ uc($class) . '_HOME' } ) { - $class =~ s/::/_/g; - $home = $ENV{ uc($class) . '_HOME' }; + if ( my $env = Catalyst::Utils::env_value( $class, 'HOME' ) ) { + $home = $env; } unless ($home) { @@ -2109,14 +2096,8 @@ sub setup_log { $class->log( Catalyst::Log->new ); } - my $app_flag = Catalyst::Utils::class2env($class) . '_DEBUG'; - - if ( - ( defined( $ENV{CATALYST_DEBUG} ) || defined( $ENV{$app_flag} ) ) - ? ( $ENV{CATALYST_DEBUG} || $ENV{$app_flag} ) - : $debug - ) - { + my $env_debug = Catalyst::Utils::env_value( $class, 'DEBUG' ); + if ( defined($env_debug) ? $env_debug : $debug ) { no strict 'refs'; *{"$class\::debug"} = sub { 1 }; $class->log->debug('Debug messages enabled'); @@ -2158,9 +2139,7 @@ the plugin name does not begin with C. my ( $proto, $plugin, $instant ) = @_; my $class = ref $proto || $proto; - unless (Class::Inspector->loaded($plugin)) { - require Class::Inspector->filename($plugin); - } + Catalyst::Utils::ensure_class_loaded( $plugin, { ignore_loaded => 1 } ); $proto->_plugins->{$plugin} = 1; unless ($instant) {