X-Git-Url: http://git.shadowcat.co.uk/gitweb/gitweb.cgi?p=catagits%2FCatalyst-Runtime.git;a=blobdiff_plain;f=lib%2FCatalyst%2FDispatcher.pm;h=7b21510e4eb9eee5d01f7c2ec78b4d6723ea1d47;hp=e90cdc1c2bd3093a42bdb2d660acae73aee57236;hb=418188af18be72b5da445f9ab4514ea668badb29;hpb=2efad04b4d6590ecf00566d698e94622198909aa diff --git a/lib/Catalyst/Dispatcher.pm b/lib/Catalyst/Dispatcher.pm index e90cdc1..7b21510 100644 --- a/lib/Catalyst/Dispatcher.pm +++ b/lib/Catalyst/Dispatcher.pm @@ -29,7 +29,7 @@ our @POSTLOAD = qw/Default/; # Note - see back-compat methods at end of file. has _tree => (is => 'rw', builder => '_build__tree'); -has _dispatch_types => (is => 'rw', default => sub { [] }, required => 1, lazy => 1); +has dispatch_types => (is => 'rw', default => sub { [] }, required => 1, lazy => 1); has _registered_dispatch_types => (is => 'rw', default => sub { {} }, required => 1, lazy => 1); has _method_action_class => (is => 'rw', default => 'Catalyst::Action'); has _action_hash => (is => 'rw', required => 1, lazy => 1, default => sub { {} }); @@ -131,7 +131,7 @@ sub _command2action { my (@args, @captures); if ( ref( $extra_params[-2] ) eq 'ARRAY' ) { - @captures = @{ pop @extra_params }; + @captures = @{ splice @extra_params, -2, 1 }; } if ( ref( $extra_params[-1] ) eq 'ARRAY' ) { @@ -153,7 +153,7 @@ sub _command2action { $action = $self->_invoke_as_path( $c, "$command", \@args ); } - # go to a component ( "MyApp::*::Foo" or $c->component("...") + # go to a component ( "View::Foo" or $c->component("...") # - a path or an object) unless ($action) { my $method = @extra_params ? $extra_params[0] : "process"; @@ -320,9 +320,9 @@ sub _invoke_as_component { my ( $self, $c, $component_or_class, $method ) = @_; my $component = $self->_find_component($c, $component_or_class); - my $component_class = blessed $component || return 0; + my $component_class = blessed($component) || $component || return 0; - if (my $code = $component_class->can('action_for')) { + if ( blessed $component and my $code = $component_class->can('action_for') ) { my $possible_action = $component->$code($method); return $possible_action if $possible_action; } @@ -335,7 +335,7 @@ sub _invoke_as_component { reverse => "$component_class->$method", class => $component_class, namespace => Catalyst::Utils::class2prefix( - $component_class, $c->config->{case_sensitive} + $component_class, ref($c)->config->{case_sensitive} ), } ); @@ -372,7 +372,7 @@ sub prepare_action { # Check out dispatch types to see if any will handle the path at # this level - foreach my $type ( @{ $self->_dispatch_types } ) { + foreach my $type ( @{ $self->dispatch_types } ) { last DESCEND if $type->match( $c, $path ); } @@ -470,7 +470,7 @@ cannot determine an appropriate URI, this method will return undef. sub uri_for_action { my ( $self, $action, $captures) = @_; $captures ||= []; - foreach my $dispatch_type ( @{ $self->_dispatch_types } ) { + foreach my $dispatch_type ( @{ $self->dispatch_types } ) { my $uri = $dispatch_type->uri_for_action( $action, $captures ); return( $uri eq '' ? '/' : $uri ) if defined($uri); @@ -489,7 +489,7 @@ single action. sub expand_action { my ($self, $action) = @_; - foreach my $dispatch_type (@{ $self->_dispatch_types }) { + foreach my $dispatch_type (@{ $self->dispatch_types }) { my $expanded = $dispatch_type->expand_action($action); return $expanded if $expanded; } @@ -510,7 +510,6 @@ sub register { my $registered = $self->_registered_dispatch_types; - #my $priv = 0; #seems to be unused foreach my $key ( keys %{ $action->attributes } ) { next if $key eq 'Private'; my $class = "Catalyst::DispatchType::$key"; @@ -518,12 +517,12 @@ sub register { # FIXME - Some error checking and re-throwing needed here, as # we eat exceptions loading dispatch types. eval { Class::MOP::load_class($class) }; - push( @{ $self->_dispatch_types }, $class->new ) unless $@; + push( @{ $self->dispatch_types }, $class->new ) unless $@; $registered->{$class} = 1; } } - my @dtypes = @{ $self->_dispatch_types }; + my @dtypes = @{ $self->dispatch_types }; my @normal_dtypes; my @low_precedence_dtypes; @@ -589,8 +588,8 @@ sub _find_or_create_namespace_node { =head2 $self->setup_actions( $class, $context ) -Loads all of the preload dispatch types, registers their actions and then -loads all of the postload dispatch types, and iterates over the tree of +Loads all of the pre-load dispatch types, registers their actions and then +loads all of the post-load dispatch types, and iterates over the tree of actions, displaying the debug information if appropriate. =cut @@ -615,9 +614,12 @@ sub setup_actions { sub _display_action_tables { my ($self, $c) = @_; - my $column_width = Catalyst::Utils::term_width() - 20 - 36 - 12; + my $avail_width = Catalyst::Utils::term_width() - 12; + my $col1_width = ($avail_width * .25) < 20 ? 20 : int($avail_width * .25); + my $col2_width = ($avail_width * .50) < 36 ? 36 : int($avail_width * .50); + my $col3_width = $avail_width - $col1_width - $col2_width; my $privates = Text::SimpleTable->new( - [ 20, 'Private' ], [ 36, 'Class' ], [ $column_width, 'Method' ] + [ $col1_width, 'Private' ], [ $col2_width, 'Class' ], [ $col3_width, 'Method' ] ); my $has_private = 0; @@ -644,7 +646,7 @@ sub _display_action_tables { if $has_private; # List all public actions - $_->list($c) for @{ $self->_dispatch_types }; + $_->list($c) for @{ $self->dispatch_types }; } sub _load_dispatch_types { @@ -659,7 +661,7 @@ sub _load_dispatch_types { eval { Class::MOP::load_class($class) }; Catalyst::Exception->throw( message => qq/Couldn't load "$class"/ ) if $@; - push @{ $self->_dispatch_types }, $class->new; + push @{ $self->dispatch_types }, $class->new; push @loaded, $class; } @@ -681,7 +683,7 @@ sub dispatch_type { # first param is undef because we cannot get the appclass $name = Catalyst::Utils::resolve_namespace(undef, 'Catalyst::DispatchType', $name); - for (@{ $self->_dispatch_types }) { + for (@{ $self->dispatch_types }) { return $_ if ref($_) eq $name; } return undef; @@ -719,7 +721,6 @@ use Moose; # Alias _method_name to method_name, add a before modifier to warn.. foreach my $public_method_name (qw/ tree - dispatch_types registered_dispatch_types method_action_class action_hash @@ -737,7 +738,7 @@ foreach my $public_method_name (qw/ $package_hash{$class}++ || do { warn("Class $class is calling the deprecated method\n" . " Catalyst::Dispatcher::$public_method_name,\n" - . " this will be removed in Catalyst 5.9X\n"); + . " this will be removed in Catalyst 5.9\n"); }; }); }