X-Git-Url: http://git.shadowcat.co.uk/gitweb/gitweb.cgi?a=blobdiff_plain;f=lib%2FCatalyst%2FUtils.pm;h=456497f89404ccee0461e1aa7c4090c4e2e4f199;hb=837844227499d9317fbb8aad7b433fcb159b4b3a;hp=dae3439adbc32bbabc20db027de10e9d259d2a22;hpb=51f412bddb6f0739274077c7c305fa09e20ccc13;p=catagits%2FCatalyst-Runtime.git diff --git a/lib/Catalyst/Utils.pm b/lib/Catalyst/Utils.pm index dae3439..456497f 100644 --- a/lib/Catalyst/Utils.pm +++ b/lib/Catalyst/Utils.pm @@ -28,22 +28,22 @@ See L. sub appprefix { my $class = shift; - $class =~ s/\:\:/_/g; + $class =~ s/::/_/g; $class = lc($class); return $class; } =head2 class2appclass($class); - MyApp::C::Foo::Bar becomes MyApp - My::App::C::Foo::Bar becomes My::App + MyApp::Controller::Foo::Bar becomes MyApp + My::App::Controller::Foo::Bar becomes My::App =cut sub class2appclass { my $class = shift || ''; my $appname = ''; - if ( $class =~ /^(.*)::([MVC]|Model|View|Controller)?::.*$/ ) { + if ( $class =~ /^(.+?)::([MVC]|Model|View|Controller)::.+$/ ) { $appname = $1; } return $appname; @@ -51,15 +51,15 @@ sub class2appclass { =head2 class2classprefix($class); - MyApp::C::Foo::Bar becomes MyApp::C - My::App::C::Foo::Bar becomes My::App::C + MyApp::Controller::Foo::Bar becomes MyApp::Controller + My::App::Controller::Foo::Bar becomes My::App::Controller =cut sub class2classprefix { my $class = shift || ''; my $prefix; - if ( $class =~ /^(.*::[MVC]|Model|View|Controller)?::.*$/ ) { + if ( $class =~ /^(.+?::([MVC]|Model|View|Controller))::.+$/ ) { $prefix = $1; } return $prefix; @@ -67,14 +67,14 @@ sub class2classprefix { =head2 class2classsuffix($class); - MyApp::C::Foo::Bar becomes C::Foo::Bar + MyApp::Controller::Foo::Bar becomes Controller::Foo::Bar =cut sub class2classsuffix { my $class = shift || ''; my $prefix = class2appclass($class) || ''; - $class =~ s/$prefix\:\://; + $class =~ s/$prefix\:://; return $class; } @@ -89,7 +89,7 @@ Returns the environment name for class. sub class2env { my $class = shift || ''; - $class =~ s/\:\:/_/g; + $class =~ s/::/_/g; return uc($class); } @@ -97,7 +97,7 @@ sub class2env { Returns the uri prefix for a class. If case is false the prefix is converted to lowercase. - My::App::C::Foo::Bar becomes foo/bar + My::App::Controller::Foo::Bar becomes foo/bar =cut @@ -105,9 +105,9 @@ sub class2prefix { my $class = shift || ''; my $case = shift || 0; my $prefix; - if ( $class =~ /^.*::([MVC]|Model|View|Controller)?::(.*)$/ ) { + if ( $class =~ /^.+?::([MVC]|Model|View|Controller)::(.+)$/ ) { $prefix = $case ? $2 : lc $2; - $prefix =~ s/\:\:/\//g; + $prefix =~ s{::}{/}g; } return $prefix; } @@ -165,8 +165,18 @@ sub home { $home = $home->parent while $home =~ /b?lib$/; # only return the dir if it has a Makefile.PL or Build.PL - return $home->stringify - if $home->file("Makefile.PL") or -f $home->file("Build.PL"); + if (-f $home->file("Makefile.PL") or -f $home->file("Build.PL")) { + + # clean up relative path: + # MyApp/script/.. -> MyApp + + my ($lastdir) = $home->dir_list( -1, 1 ); + if ( $lastdir eq '..' ) { + $home = dir($home)->parent->parent; + } + + return $home->stringify; + } } { @@ -189,7 +199,7 @@ sub home { Returns a prefixed action. - MyApp::C::Foo::Bar, yada becomes foo/bar/yada + MyApp::Controller::Foo::Bar, yada becomes foo/bar/yada =cut @@ -230,8 +240,10 @@ Loads the class unless it already has been loaded. sub ensure_class_loaded { my $class = shift; + my $opts = shift; - return if Class::Inspector->loaded( $class ); # if a symbol entry exists we don't load again + return if !$opts->{ ignore_loaded } + && Class::Inspector->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; @@ -260,17 +272,17 @@ sub merge_hashes { return $lefthash unless defined $righthash; my %merged = %$lefthash; - for my $key ( keys %$righthash ) { - my $right_ref = ( ref $righthash->{ $key } || '' ) eq 'HASH'; - my $left_ref = ( ( exists $lefthash->{ $key } && ref $lefthash->{ $key } ) || '' ) eq 'HASH'; - if( $right_ref and $left_ref ) { + for my $key ( keys %$righthash ) { + my $right_ref = ( ref $righthash->{ $key } || '' ) eq 'HASH'; + my $left_ref = ( ( exists $lefthash->{ $key } && ref $lefthash->{ $key } ) || '' ) eq 'HASH'; + if( $right_ref and $left_ref ) { $merged{ $key } = merge_hashes( $lefthash->{ $key }, $righthash->{ $key } - ); + ); } else { $merged{ $key } = $righthash->{ $key }; - } + } } return \%merged;