manpagez: man pages & more
man Mojolicious::Routes::Match(3)
Home | html | info | man
Mojolicious::Routes::Match(3)



NAME

       Mojolicious::Routes::Match - Find routes


SYNOPSIS

         use Mojolicious::Controller;
         use Mojolicious::Routes;
         use Mojolicious::Routes::Match;

         # Routes
         my $r = Mojolicious::Routes->new;
         $r->get('/user/:id');
         $r->put('/user/:id');

         # Match
         my $c = Mojolicious::Controller->new;
         my $match = Mojolicious::Routes::Match->new(root => $r);
         $match->find($c => {method => 'PUT', path => '/user/23'});
         say $match->stack->[0]{id};

         # Render
         say $match->path_for->{path};
         say $match->path_for(id => 24)->{path};


DESCRIPTION

       Mojolicious::Routes::Match finds routes in Mojolicious::Routes
       structures.


ATTRIBUTES

       Mojolicious::Routes::Match implements the following attributes.

   endpoint
         my $route = $match->endpoint;
         $match    = $match->endpoint(Mojolicious::Routes::Route->new);

       The route endpoint that matched, usually a Mojolicious::Routes::Route
       object.

   position
         my $position = $match->position;
         $match       = $match->position(2);

       Current position on the "stack", defaults to 0.

   root
         my $root = $match->root;
         $match   = $match->root(Mojolicious::Routes->new);

       The root of the route structure, usually a Mojolicious::Routes object.

   stack
         my $stack = $match->stack;
         $match    = $match->stack([{action => 'foo'}, {action => 'bar'}]);

       Captured parameters with nesting history.


METHODS

       Mojolicious::Routes::Match inherits all methods from Mojo::Base and
       implements the following new ones.

   find
         $match->find(Mojolicious::Controller->new, {method => 'GET', path => '/'});

       Match controller and options against "root" to find an appropriate
       "endpoint".

   path_for
         my $info = $match->path_for;
         my $info = $match->path_for(foo => 'bar');
         my $info = $match->path_for({foo => 'bar'});
         my $info = $match->path_for('named');
         my $info = $match->path_for('named', foo => 'bar');
         my $info = $match->path_for('named', {foo => 'bar'});

       Render matching route with parameters into path.


SEE ALSO

       Mojolicious(3), Mojolicious::Guides(3), <https://mojolicious.org>.



perl v5.32.1                      2021-12-08     Mojolicious::Routes::Match(3)

mojolicious 9.260.0 - Generated Mon May 30 16:19:04 CDT 2022
© manpagez.com 2000-2025
Individual documents may contain additional copyright information.