|
NAMEMojolicious::Routes::Pattern - Route patternSYNOPSISuse Mojolicious::Routes::Pattern; # Create pattern my $pattern = Mojolicious::Routes::Pattern->new('/test/:name'); # Match routes my $captures = $pattern->match('/test/sebastian'); say $captures->{name}; DESCRIPTIONMojolicious::Routes::Pattern is the core of Mojolicious::Routes.ATTRIBUTESMojolicious::Routes::Pattern implements the following attributes.constraintsmy $constraints = $pattern->constraints; $pattern = $pattern->constraints({foo => qr/\w+/}); Regular expression constraints. defaultsmy $defaults = $pattern->defaults; $pattern = $pattern->defaults({foo => 'bar'}); Default parameters. placeholder_startmy $start = $pattern->placeholder_start; $pattern = $pattern->placeholder_start(':'); Character indicating a placeholder, defaults to ":". placeholdersmy $placeholders = $pattern->placeholders; $pattern = $pattern->placeholders(['foo', 'bar']); Placeholder names. quote_endmy $end = $pattern->quote_end; $pattern = $pattern->quote_end('}'); Character indicating the end of a quoted placeholder, defaults to ">". quote_startmy $start = $pattern->quote_start; $pattern = $pattern->quote_start('{'); Character indicating the start of a quoted placeholder, defaults to "<". regexmy $regex = $pattern->regex; $pattern = $pattern->regex($regex); Pattern in compiled regular expression form. relaxed_startmy $start = $pattern->relaxed_start; $pattern = $pattern->relaxed_start('*'); Character indicating a relaxed placeholder, defaults to "#". treemy $tree = $pattern->tree; $pattern = $pattern->tree([['text', '/foo']]); Pattern in parsed form. Note that this structure should only be used very carefully since it is very dynamic. type_startmy $start = $pattern->type_start; $pattern = $pattern->type_start('|'); Character indicating the start of a placeholder type, defaults to ":". typesmy $types = $pattern->types; $pattern = $pattern->types({int => qr/[0-9]+/}); Placeholder types. unparsedmy $unparsed = $pattern->unparsed; $pattern = $pattern->unparsed('/:foo/:bar'); Raw unparsed pattern. wildcard_startmy $start = $pattern->wildcard_start; $pattern = $pattern->wildcard_start('*'); Character indicating the start of a wildcard placeholder, defaults to "*". METHODSMojolicious::Routes::Pattern inherits all methods from Mojo::Base and implements the following new ones.matchmy $captures = $pattern->match('/foo/bar'); my $captures = $pattern->match('/foo/bar', 1); Match pattern against entire path, format detection is disabled by default. match_partialmy $captures = $pattern->match_partial(\$path); my $captures = $pattern->match_partial(\$path, 1); Match pattern against path and remove matching parts, format detection is disabled by default. newmy $pattern = Mojolicious::Routes::Pattern->new; my $pattern = Mojolicious::Routes::Pattern->new('/users/:id'); my $pattern = Mojolicious::Routes::Pattern->new('/user/:id', id => qr/\d+/); my $pattern = Mojolicious::Routes::Pattern->new(format => ['json', 'yaml']); Construct a new Mojolicious::Routes::Pattern object and "parse" pattern if necessary. parse$pattern = $pattern->parse('/user/:id'); $pattern = $pattern->parse('/user/:id', id=> qr/\d+/); $pattern = $pattern->parse(format => ['json', 'yaml']); Parse pattern. rendermy $path = $pattern->render({id => 24}); my $path = $pattern->render({id => 24}, 1); Render pattern into a path with parameters, format rendering is disabled by default. SEE ALSOMojolicious, Mojolicious::Guides, <https://mojolicious.org>.
Visit the GSP FreeBSD Man Page Interface. |