use Mojolicious::Routes::Pattern; # Create pattern my $pattern = Mojolicious::Routes::Pattern->new('/test/:name'); # Match routes my $captures = $pattern->match('/test/sebastian'); say $captures->{name};
my $constraints = $pattern->constraints; $pattern = $pattern->constraints({foo => qr/\w+/});
Regular expression constraints.
my $defaults = $pattern->defaults; $pattern = $pattern->defaults({foo => 'bar'});
my $start = $pattern->placeholder_start; $pattern = $pattern->placeholder_start(':');
Character indicating a placeholder, defaults to ":".
my $placeholders = $pattern->placeholders; $pattern = $pattern->placeholders(['foo', 'bar']);
my $end = $pattern->quote_end; $pattern = $pattern->quote_end('}');
Character indicating the end of a quoted placeholder, defaults to ">".
my $start = $pattern->quote_start; $pattern = $pattern->quote_start('{');
Character indicating the start of a quoted placeholder, defaults to "<".
my $regex = $pattern->regex; $pattern = $pattern->regex($regex);
Pattern in compiled regular expression form.
my $start = $pattern->relaxed_start; $pattern = $pattern->relaxed_start('*');
Character indicating a relaxed placeholder, defaults to "#".
my $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.
my $start = $pattern->type_start; $pattern = $pattern->type_start('|');
Character indicating the start of a placeholder type, defaults to ":".
my $types = $pattern->types; $pattern = $pattern->types({int => qr/[0-9]+/});
my $unparsed = $pattern->unparsed; $pattern = $pattern->unparsed('/:foo/:bar');
my $start = $pattern->wildcard_start; $pattern = $pattern->wildcard_start('*');
Character indicating the start of a wildcard placeholder, defaults to "*".
my $captures = $pattern->match('/foo/bar'); my $captures = $pattern->match('/foo/bar', 1);
Match pattern against entire path, format detection is disabled by default.
my $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.
my $pattern = Mojolicious::Routes::Pattern->new; my $pattern = Mojolicious::Routes::Pattern->new('/:action'); my $pattern = Mojolicious::Routes::Pattern->new('/:action', action => qr/\w+/); my $pattern = Mojolicious::Routes::Pattern->new(format => 0);
Construct a new Mojolicious::Routes::Pattern object and ``parse'' pattern if necessary.
$pattern = $pattern->parse('/:action'); $pattern = $pattern->parse('/:action', action => qr/\w+/); $pattern = $pattern->parse(format => 0);
my $path = $pattern->render({action => 'foo'}); my $path = $pattern->render({action => 'foo'}, 1);
Render pattern into a path with parameters, format rendering is disabled by default.