=head1 METHODS
-=over 4
+=head2 $self->list($c)
-=item $self->list($c)
+Output a table of all regex actions, and their private equivalent.
=cut
if ( @{ $self->{compiled} } );
}
-=item $self->match( $c, $path )
+=head2 $self->match( $c, $path )
+
+Check path against compiled regexes, and set action to any matching
+action. Returns 1 on success and 0 on failure.
=cut
foreach my $compiled ( @{ $self->{compiled} || [] } ) {
if ( my @snippets = ( $path =~ $compiled->{re} ) ) {
+ next unless $compiled->{action}->match($c);
$c->req->action( $compiled->{path} );
$c->req->match($path);
$c->req->snippets( \@snippets );
return 0;
}
-=item $self->register( $c, $action )
+=head2 $self->register( $c, $action )
+
+Registers one or more regex actions for an action object.\
+Also registers them as literal paths.
+
+Returns 1 on if any regexps were registered.
=cut
sub register {
my ( $self, $c, $action ) = @_;
my $attrs = $action->attributes;
- my @register = map { @{ $_ || [] } } @{$attrs}{ 'Regex', 'Regexp' };
- foreach
- my $r ( map { @{ $_ || [] } } @{$attrs}{ 'LocalRegex', 'LocalRegexp' } )
- {
- unless ( $r =~ s/^\^// ) { $r = "(?:.*?)$r"; }
- push( @register, '^' . $action->namespace . '/' . $r );
- }
+ my @register = @{ $attrs->{'Regex'} || [] };
foreach my $r (@register) {
$self->register_path( $c, $r, $action );
$self->register_regex( $c, $r, $action );
}
+
return 1 if @register;
return 0;
}
-=item $self->register_regex($c, $re, $action)
+=head2 $self->register_regex($c, $re, $action)
+
+Register an individual regex on the action. Usually called from the
+register action.
=cut
);
}
-=back
-
=head1 AUTHOR
Matt S Trout