NAME
Mojolicious::Routes::Pattern - Routes Pattern
SYNOPSIS
DESCRIPTION
Mojolicious::Routes::Pattern is a container for routes pattern which are used to match paths against.
ATTRIBUTES
Mojolicious::Routes::Pattern implements the following attributes.
defaults
my
$defaults
=
$pattern
->defaults;
$pattern
=
$pattern
->defaults({
foo
=>
'bar'
});
Default parameters.
format
my
$regex
=
$pattern
->
format
;
$pattern
=
$pattern
->
format
(
$regex
);
Compiled regex for format matching. Note that this attribute is EXPERIMENTAL and might change without warning!
pattern
my
$pattern
=
$pattern
->pattern;
$pattern
=
$pattern
->pattern(
'/(foo)/(bar)'
);
Raw unparsed pattern.
quote_end
my
$quote
=
$pattern
->quote_end;
$pattern
=
$pattern
->quote_end(
']'
);
Character indicating the end of a quoted placeholder, defaults to )
.
quote_start
my
$quote
=
$pattern
->quote_start;
$pattern
=
$pattern
->quote_start(
'['
);
Character indicating the start of a quoted placeholder, defaults to (
.
regex
my
$regex
=
$pattern
->regex;
$pattern
=
$pattern
->regex(
$regex
);
Pattern in compiled regex form.
relaxed_start
my
$relaxed
=
$pattern
->relaxed_start;
$pattern
=
$pattern
->relaxed_start(
'*'
);
Character indicating a relaxed placeholder, defaults to .
.
reqs
my
$reqs
=
$pattern
->reqs;
$pattern
=
$pattern
->reqs({
foo
=>
qr/\w+/
});
Regex constraints.
symbol_start
my
$symbol
=
$pattern
->symbol_start;
$pattern
=
$pattern
->symbol_start(
':'
);
Character indicating a placeholder, defaults to :
.
symbols
my
$symbols
=
$pattern
->symbols;
$pattern
=
$pattern
->symbols([
'foo'
,
'bar'
]);
Placeholder names.
tree
my
$tree
=
$pattern
->tree;
$pattern
=
$pattern
->tree([ ... ]);
Pattern in parsed form.
wildcard_start
my
$wildcard
=
$pattern
->wildcard_start;
$pattern
=
$pattern
->wildcard_start(
'*'
);
Character indicating the start of a wildcard placeholder, defaults to *
.
METHODS
Mojolicious::Routes::Pattern inherits all methods from Mojo::Base and implements the following ones.
new
my
$pattern
= Mojolicious::Routes::Pattern->new(
'/:controller/:action'
,
action
=>
qr/\w+/
);
Construct a new pattern object.
match
my
$result
=
$pattern
->match(
'/foo/bar'
);
Match pattern against a path.
parse
$pattern
=
$pattern
->parse(
'/:controller/:action'
,
action
=>
qr/\w+/
);
Parse a raw pattern.
render
my
$path
=
$pattern
->render({
action
=>
'foo'
});
Render pattern into a path with parameters.
shape_match
my
$result
=
$pattern
->shape_match(\
$path
);
Match pattern against a path and remove matching parts.