X-Git-Url: http://git.shadowcat.co.uk/gitweb/gitweb.cgi?a=blobdiff_plain;f=lib%2FCatalyst%2FUtils.pm;h=fffa048ce6dfb6f80284708556f50e62783c2c61;hb=17176f15aa0e2e0323b9d4cc6f32a9b94cfa785e;hp=afa9d32299b085db944798f4f51b7a47d8df04db;hpb=3086ccde3309473379093d25a415cb0d03a08401;p=catagits%2FCatalyst-Runtime.git diff --git a/lib/Catalyst/Utils.pm b/lib/Catalyst/Utils.pm index afa9d32..fffa048 100644 --- a/lib/Catalyst/Utils.pm +++ b/lib/Catalyst/Utils.pm @@ -7,7 +7,7 @@ use Path::Class; use URI; use Carp qw/croak/; use Cwd; -use Class::MOP; +use Class::Load 'is_class_loaded'; use String::RewritePrefix; use Class::Load (); @@ -137,9 +137,8 @@ sub class2tempdir { if ( $create && !-e $tmpdir ) { - eval { $tmpdir->mkpath }; - - if ($@) { + eval { $tmpdir->mkpath; 1 } + or do { # don't load Catalyst::Exception as a BEGIN in Utils, # because Utils often gets loaded before MyApp.pm, and if # Catalyst::Exception is loaded before MyApp.pm, it does @@ -224,7 +223,7 @@ sub home { ( my $path = $inc_entry) =~ s/\.pm$//; my $home = dir($path)->absolute->cleanup; - # return if if it's a valid directory + # return if it's a valid directory return $home->stringify if -d $home; } } @@ -298,7 +297,7 @@ sub ensure_class_loaded { # if it already has symbol table entries. This is to support things like Schema::Loader, which # part-generate classes in memory, but then also load some of their contents from disk. return if !$opts->{ ignore_loaded } - && Class::MOP::is_class_loaded($class); # if a symbol entry exists we don't load again + && is_class_loaded($class); # if a symbol entry exists we don't load again # this hack is so we don't overwrite $@ if the load did not generate an error my $error; @@ -313,7 +312,7 @@ sub ensure_class_loaded { die $error if $error; warn "require $class was successful but the package is not defined." - unless Class::MOP::is_class_loaded($class); + unless is_class_loaded($class); return 1; } @@ -392,17 +391,17 @@ my $_term_width; sub term_width { return $_term_width if $_term_width; - my $width = eval ' - use Term::Size::Any; + my $width; + eval ' + require Term::Size::Any; my ($columns, $rows) = Term::Size::Any::chars; - return $columns; - '; - - if ($@) { + $width = $columns; + 1; + ' or do { $width = $ENV{COLUMNS} if exists($ENV{COLUMNS}) && $ENV{COLUMNS} =~ m/^\d+$/; - } + }; $width = 80 unless ($width && $width >= 80); return $_term_width = $width; @@ -453,10 +452,11 @@ sub build_middleware { $namespace->new(@init_args) : die "Can't load class $namespace"; } else { ## the string is a partial namespace - if(Class::Load::try_load_class("Plack::Middleware::$namespace")) { ## Act like Plack::Builder - return "Plack::Middleware::$namespace"->new(@init_args); - } elsif(Class::Load::try_load_class("$class::$namespace")) { ## Load Middleware from Project namespace - return "$class::$namespace"->new(@init_args); + if(Class::Load::try_load_class($class .'::Middleware::'. $namespace)) { ## Load Middleware from Project namespace + my $ns = $class .'::Middleware::'. $namespace; + return $ns->new(@init_args); + } elsif(Class::Load::try_load_class("Plack::Middleware::$namespace")) { ## Act like Plack::Builder + return "Plack::Middleware::$namespace"->new(@init_args); } }