[Routing] Compiler: remove lazy quantifiers with no effect
This commit is contained in:
parent
8232aa150b
commit
a196ca03a5
@ -51,7 +51,7 @@ class RouteCompiler implements RouteCompilerInterface
|
|||||||
// Use the character following the variable as the separator when available
|
// Use the character following the variable as the separator when available
|
||||||
// Use the character preceding the variable otherwise
|
// Use the character preceding the variable otherwise
|
||||||
$separator = $pos !== $len ? $pattern[$pos] : $match[0][0][0];
|
$separator = $pos !== $len ? $pattern[$pos] : $match[0][0][0];
|
||||||
$regexp = sprintf('[^%s]+?', preg_quote($separator, self::REGEX_DELIMITER));
|
$regexp = sprintf('[^%s]+', preg_quote($separator, self::REGEX_DELIMITER));
|
||||||
}
|
}
|
||||||
|
|
||||||
$tokens[] = array('variable', $match[0][0][0], $regexp, $var);
|
$tokens[] = array('variable', $match[0][0][0], $regexp, $var);
|
||||||
|
@ -7,17 +7,17 @@ RewriteCond %{REQUEST_URI} ^/foo/(baz|symfony)$
|
|||||||
RewriteRule .* app.php [QSA,L,E=_ROUTING__route:foo,E=_ROUTING_bar:%1,E=_ROUTING_def:test]
|
RewriteRule .* app.php [QSA,L,E=_ROUTING__route:foo,E=_ROUTING_bar:%1,E=_ROUTING_def:test]
|
||||||
|
|
||||||
# bar
|
# bar
|
||||||
RewriteCond %{REQUEST_URI} ^/bar/([^/]+?)$
|
RewriteCond %{REQUEST_URI} ^/bar/([^/]+)$
|
||||||
RewriteCond %{REQUEST_METHOD} !^(GET|HEAD)$ [NC]
|
RewriteCond %{REQUEST_METHOD} !^(GET|HEAD)$ [NC]
|
||||||
RewriteRule .* - [S=1,E=_ROUTING__allow_GET:1,E=_ROUTING__allow_HEAD:1]
|
RewriteRule .* - [S=1,E=_ROUTING__allow_GET:1,E=_ROUTING__allow_HEAD:1]
|
||||||
RewriteCond %{REQUEST_URI} ^/bar/([^/]+?)$
|
RewriteCond %{REQUEST_URI} ^/bar/([^/]+)$
|
||||||
RewriteRule .* app.php [QSA,L,E=_ROUTING__route:bar,E=_ROUTING_foo:%1]
|
RewriteRule .* app.php [QSA,L,E=_ROUTING__route:bar,E=_ROUTING_foo:%1]
|
||||||
|
|
||||||
# baragain
|
# baragain
|
||||||
RewriteCond %{REQUEST_URI} ^/baragain/([^/]+?)$
|
RewriteCond %{REQUEST_URI} ^/baragain/([^/]+)$
|
||||||
RewriteCond %{REQUEST_METHOD} !^(GET|POST|HEAD)$ [NC]
|
RewriteCond %{REQUEST_METHOD} !^(GET|POST|HEAD)$ [NC]
|
||||||
RewriteRule .* - [S=1,E=_ROUTING__allow_GET:1,E=_ROUTING__allow_POST:1,E=_ROUTING__allow_HEAD:1]
|
RewriteRule .* - [S=1,E=_ROUTING__allow_GET:1,E=_ROUTING__allow_POST:1,E=_ROUTING__allow_HEAD:1]
|
||||||
RewriteCond %{REQUEST_URI} ^/baragain/([^/]+?)$
|
RewriteCond %{REQUEST_URI} ^/baragain/([^/]+)$
|
||||||
RewriteRule .* app.php [QSA,L,E=_ROUTING__route:baragain,E=_ROUTING_foo:%1]
|
RewriteRule .* app.php [QSA,L,E=_ROUTING__route:baragain,E=_ROUTING_foo:%1]
|
||||||
|
|
||||||
# baz
|
# baz
|
||||||
@ -35,25 +35,25 @@ RewriteCond %{REQUEST_URI} ^/test/baz3/$
|
|||||||
RewriteRule .* app.php [QSA,L,E=_ROUTING__route:baz3]
|
RewriteRule .* app.php [QSA,L,E=_ROUTING__route:baz3]
|
||||||
|
|
||||||
# baz4
|
# baz4
|
||||||
RewriteCond %{REQUEST_URI} ^/test/([^/]+?)$
|
RewriteCond %{REQUEST_URI} ^/test/([^/]+)$
|
||||||
RewriteRule .* $0/ [QSA,L,R=301]
|
RewriteRule .* $0/ [QSA,L,R=301]
|
||||||
RewriteCond %{REQUEST_URI} ^/test/([^/]+?)/$
|
RewriteCond %{REQUEST_URI} ^/test/([^/]+)/$
|
||||||
RewriteRule .* app.php [QSA,L,E=_ROUTING__route:baz4,E=_ROUTING_foo:%1]
|
RewriteRule .* app.php [QSA,L,E=_ROUTING__route:baz4,E=_ROUTING_foo:%1]
|
||||||
|
|
||||||
# baz5
|
# baz5
|
||||||
RewriteCond %{REQUEST_URI} ^/test/([^/]+?)/$
|
RewriteCond %{REQUEST_URI} ^/test/([^/]+)/$
|
||||||
RewriteCond %{REQUEST_METHOD} !^(GET|HEAD)$ [NC]
|
RewriteCond %{REQUEST_METHOD} !^(GET|HEAD)$ [NC]
|
||||||
RewriteRule .* - [S=2,E=_ROUTING__allow_GET:1,E=_ROUTING__allow_HEAD:1]
|
RewriteRule .* - [S=2,E=_ROUTING__allow_GET:1,E=_ROUTING__allow_HEAD:1]
|
||||||
RewriteCond %{REQUEST_URI} ^/test/([^/]+?)$
|
RewriteCond %{REQUEST_URI} ^/test/([^/]+)$
|
||||||
RewriteRule .* $0/ [QSA,L,R=301]
|
RewriteRule .* $0/ [QSA,L,R=301]
|
||||||
RewriteCond %{REQUEST_URI} ^/test/([^/]+?)/$
|
RewriteCond %{REQUEST_URI} ^/test/([^/]+)/$
|
||||||
RewriteRule .* app.php [QSA,L,E=_ROUTING__route:baz5,E=_ROUTING_foo:%1]
|
RewriteRule .* app.php [QSA,L,E=_ROUTING__route:baz5,E=_ROUTING_foo:%1]
|
||||||
|
|
||||||
# baz5unsafe
|
# baz5unsafe
|
||||||
RewriteCond %{REQUEST_URI} ^/testunsafe/([^/]+?)/$
|
RewriteCond %{REQUEST_URI} ^/testunsafe/([^/]+)/$
|
||||||
RewriteCond %{REQUEST_METHOD} !^(POST)$ [NC]
|
RewriteCond %{REQUEST_METHOD} !^(POST)$ [NC]
|
||||||
RewriteRule .* - [S=1,E=_ROUTING__allow_POST:1]
|
RewriteRule .* - [S=1,E=_ROUTING__allow_POST:1]
|
||||||
RewriteCond %{REQUEST_URI} ^/testunsafe/([^/]+?)/$
|
RewriteCond %{REQUEST_URI} ^/testunsafe/([^/]+)/$
|
||||||
RewriteRule .* app.php [QSA,L,E=_ROUTING__route:baz5unsafe,E=_ROUTING_foo:%1]
|
RewriteRule .* app.php [QSA,L,E=_ROUTING__route:baz5unsafe,E=_ROUTING_foo:%1]
|
||||||
|
|
||||||
# baz6
|
# baz6
|
||||||
|
@ -31,7 +31,7 @@ class ProjectUrlMatcher extends Symfony\Component\Routing\Matcher\UrlMatcher
|
|||||||
}
|
}
|
||||||
|
|
||||||
// bar
|
// bar
|
||||||
if (0 === strpos($pathinfo, '/bar') && preg_match('#^/bar/(?<foo>[^/]+?)$#s', $pathinfo, $matches)) {
|
if (0 === strpos($pathinfo, '/bar') && preg_match('#^/bar/(?<foo>[^/]+)$#s', $pathinfo, $matches)) {
|
||||||
if (!in_array($this->context->getMethod(), array('GET', 'HEAD'))) {
|
if (!in_array($this->context->getMethod(), array('GET', 'HEAD'))) {
|
||||||
$allow = array_merge($allow, array('GET', 'HEAD'));
|
$allow = array_merge($allow, array('GET', 'HEAD'));
|
||||||
goto not_bar;
|
goto not_bar;
|
||||||
@ -42,7 +42,7 @@ class ProjectUrlMatcher extends Symfony\Component\Routing\Matcher\UrlMatcher
|
|||||||
not_bar:
|
not_bar:
|
||||||
|
|
||||||
// barhead
|
// barhead
|
||||||
if (0 === strpos($pathinfo, '/barhead') && preg_match('#^/barhead/(?<foo>[^/]+?)$#s', $pathinfo, $matches)) {
|
if (0 === strpos($pathinfo, '/barhead') && preg_match('#^/barhead/(?<foo>[^/]+)$#s', $pathinfo, $matches)) {
|
||||||
if (!in_array($this->context->getMethod(), array('GET', 'HEAD'))) {
|
if (!in_array($this->context->getMethod(), array('GET', 'HEAD'))) {
|
||||||
$allow = array_merge($allow, array('GET', 'HEAD'));
|
$allow = array_merge($allow, array('GET', 'HEAD'));
|
||||||
goto not_barhead;
|
goto not_barhead;
|
||||||
@ -68,13 +68,13 @@ class ProjectUrlMatcher extends Symfony\Component\Routing\Matcher\UrlMatcher
|
|||||||
}
|
}
|
||||||
|
|
||||||
// baz4
|
// baz4
|
||||||
if (0 === strpos($pathinfo, '/test') && preg_match('#^/test/(?<foo>[^/]+?)/$#s', $pathinfo, $matches)) {
|
if (0 === strpos($pathinfo, '/test') && preg_match('#^/test/(?<foo>[^/]+)/$#s', $pathinfo, $matches)) {
|
||||||
$matches['_route'] = 'baz4';
|
$matches['_route'] = 'baz4';
|
||||||
return $matches;
|
return $matches;
|
||||||
}
|
}
|
||||||
|
|
||||||
// baz5
|
// baz5
|
||||||
if (0 === strpos($pathinfo, '/test') && preg_match('#^/test/(?<foo>[^/]+?)/$#s', $pathinfo, $matches)) {
|
if (0 === strpos($pathinfo, '/test') && preg_match('#^/test/(?<foo>[^/]+)/$#s', $pathinfo, $matches)) {
|
||||||
if ($this->context->getMethod() != 'POST') {
|
if ($this->context->getMethod() != 'POST') {
|
||||||
$allow[] = 'POST';
|
$allow[] = 'POST';
|
||||||
goto not_baz5;
|
goto not_baz5;
|
||||||
@ -85,7 +85,7 @@ class ProjectUrlMatcher extends Symfony\Component\Routing\Matcher\UrlMatcher
|
|||||||
not_baz5:
|
not_baz5:
|
||||||
|
|
||||||
// baz.baz6
|
// baz.baz6
|
||||||
if (0 === strpos($pathinfo, '/test') && preg_match('#^/test/(?<foo>[^/]+?)/$#s', $pathinfo, $matches)) {
|
if (0 === strpos($pathinfo, '/test') && preg_match('#^/test/(?<foo>[^/]+)/$#s', $pathinfo, $matches)) {
|
||||||
if ($this->context->getMethod() != 'PUT') {
|
if ($this->context->getMethod() != 'PUT') {
|
||||||
$allow[] = 'PUT';
|
$allow[] = 'PUT';
|
||||||
goto not_bazbaz6;
|
goto not_bazbaz6;
|
||||||
@ -114,13 +114,13 @@ class ProjectUrlMatcher extends Symfony\Component\Routing\Matcher\UrlMatcher
|
|||||||
if (0 === strpos($pathinfo, '/a')) {
|
if (0 === strpos($pathinfo, '/a')) {
|
||||||
if (0 === strpos($pathinfo, '/a/b\'b')) {
|
if (0 === strpos($pathinfo, '/a/b\'b')) {
|
||||||
// foo1
|
// foo1
|
||||||
if (preg_match('#^/a/b\'b/(?<foo>[^/]+?)$#s', $pathinfo, $matches)) {
|
if (preg_match('#^/a/b\'b/(?<foo>[^/]+)$#s', $pathinfo, $matches)) {
|
||||||
$matches['_route'] = 'foo1';
|
$matches['_route'] = 'foo1';
|
||||||
return $matches;
|
return $matches;
|
||||||
}
|
}
|
||||||
|
|
||||||
// bar1
|
// bar1
|
||||||
if (preg_match('#^/a/b\'b/(?<bar>[^/]+?)$#s', $pathinfo, $matches)) {
|
if (preg_match('#^/a/b\'b/(?<bar>[^/]+)$#s', $pathinfo, $matches)) {
|
||||||
$matches['_route'] = 'bar1';
|
$matches['_route'] = 'bar1';
|
||||||
return $matches;
|
return $matches;
|
||||||
}
|
}
|
||||||
@ -135,13 +135,13 @@ class ProjectUrlMatcher extends Symfony\Component\Routing\Matcher\UrlMatcher
|
|||||||
|
|
||||||
if (0 === strpos($pathinfo, '/a/b\'b')) {
|
if (0 === strpos($pathinfo, '/a/b\'b')) {
|
||||||
// foo2
|
// foo2
|
||||||
if (preg_match('#^/a/b\'b/(?<foo1>[^/]+?)$#s', $pathinfo, $matches)) {
|
if (preg_match('#^/a/b\'b/(?<foo1>[^/]+)$#s', $pathinfo, $matches)) {
|
||||||
$matches['_route'] = 'foo2';
|
$matches['_route'] = 'foo2';
|
||||||
return $matches;
|
return $matches;
|
||||||
}
|
}
|
||||||
|
|
||||||
// bar2
|
// bar2
|
||||||
if (preg_match('#^/a/b\'b/(?<bar1>[^/]+?)$#s', $pathinfo, $matches)) {
|
if (preg_match('#^/a/b\'b/(?<bar1>[^/]+)$#s', $pathinfo, $matches)) {
|
||||||
$matches['_route'] = 'bar2';
|
$matches['_route'] = 'bar2';
|
||||||
return $matches;
|
return $matches;
|
||||||
}
|
}
|
||||||
@ -152,7 +152,7 @@ class ProjectUrlMatcher extends Symfony\Component\Routing\Matcher\UrlMatcher
|
|||||||
|
|
||||||
if (0 === strpos($pathinfo, '/multi')) {
|
if (0 === strpos($pathinfo, '/multi')) {
|
||||||
// helloWorld
|
// helloWorld
|
||||||
if (0 === strpos($pathinfo, '/multi/hello') && preg_match('#^/multi/hello(?:/(?<who>[^/]+?))?$#s', $pathinfo, $matches)) {
|
if (0 === strpos($pathinfo, '/multi/hello') && preg_match('#^/multi/hello(?:/(?<who>[^/]+))?$#s', $pathinfo, $matches)) {
|
||||||
return array_merge($this->mergeDefaults($matches, array ( 'who' => 'World!',)), array('_route' => 'helloWorld'));
|
return array_merge($this->mergeDefaults($matches, array ( 'who' => 'World!',)), array('_route' => 'helloWorld'));
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -169,13 +169,13 @@ class ProjectUrlMatcher extends Symfony\Component\Routing\Matcher\UrlMatcher
|
|||||||
}
|
}
|
||||||
|
|
||||||
// foo3
|
// foo3
|
||||||
if (preg_match('#^/(?<_locale>[^/]+?)/b/(?<foo>[^/]+?)$#s', $pathinfo, $matches)) {
|
if (preg_match('#^/(?<_locale>[^/]+)/b/(?<foo>[^/]+)$#s', $pathinfo, $matches)) {
|
||||||
$matches['_route'] = 'foo3';
|
$matches['_route'] = 'foo3';
|
||||||
return $matches;
|
return $matches;
|
||||||
}
|
}
|
||||||
|
|
||||||
// bar3
|
// bar3
|
||||||
if (preg_match('#^/(?<_locale>[^/]+?)/b/(?<bar>[^/]+?)$#s', $pathinfo, $matches)) {
|
if (preg_match('#^/(?<_locale>[^/]+)/b/(?<bar>[^/]+)$#s', $pathinfo, $matches)) {
|
||||||
$matches['_route'] = 'bar3';
|
$matches['_route'] = 'bar3';
|
||||||
return $matches;
|
return $matches;
|
||||||
}
|
}
|
||||||
@ -186,7 +186,7 @@ class ProjectUrlMatcher extends Symfony\Component\Routing\Matcher\UrlMatcher
|
|||||||
}
|
}
|
||||||
|
|
||||||
// foo4
|
// foo4
|
||||||
if (0 === strpos($pathinfo, '/aba') && preg_match('#^/aba/(?<foo>[^/]+?)$#s', $pathinfo, $matches)) {
|
if (0 === strpos($pathinfo, '/aba') && preg_match('#^/aba/(?<foo>[^/]+)$#s', $pathinfo, $matches)) {
|
||||||
$matches['_route'] = 'foo4';
|
$matches['_route'] = 'foo4';
|
||||||
return $matches;
|
return $matches;
|
||||||
}
|
}
|
||||||
@ -199,13 +199,13 @@ class ProjectUrlMatcher extends Symfony\Component\Routing\Matcher\UrlMatcher
|
|||||||
|
|
||||||
if (0 === strpos($pathinfo, '/a/b')) {
|
if (0 === strpos($pathinfo, '/a/b')) {
|
||||||
// b
|
// b
|
||||||
if (preg_match('#^/a/b/(?<var>[^/]+?)$#s', $pathinfo, $matches)) {
|
if (preg_match('#^/a/b/(?<var>[^/]+)$#s', $pathinfo, $matches)) {
|
||||||
$matches['_route'] = 'b';
|
$matches['_route'] = 'b';
|
||||||
return $matches;
|
return $matches;
|
||||||
}
|
}
|
||||||
|
|
||||||
// c
|
// c
|
||||||
if (0 === strpos($pathinfo, '/a/b/c') && preg_match('#^/a/b/c/(?<var>[^/]+?)$#s', $pathinfo, $matches)) {
|
if (0 === strpos($pathinfo, '/a/b/c') && preg_match('#^/a/b/c/(?<var>[^/]+)$#s', $pathinfo, $matches)) {
|
||||||
$matches['_route'] = 'c';
|
$matches['_route'] = 'c';
|
||||||
return $matches;
|
return $matches;
|
||||||
}
|
}
|
||||||
|
@ -31,7 +31,7 @@ class ProjectUrlMatcher extends Symfony\Component\Routing\Tests\Fixtures\Redirec
|
|||||||
}
|
}
|
||||||
|
|
||||||
// bar
|
// bar
|
||||||
if (0 === strpos($pathinfo, '/bar') && preg_match('#^/bar/(?<foo>[^/]+?)$#s', $pathinfo, $matches)) {
|
if (0 === strpos($pathinfo, '/bar') && preg_match('#^/bar/(?<foo>[^/]+)$#s', $pathinfo, $matches)) {
|
||||||
if (!in_array($this->context->getMethod(), array('GET', 'HEAD'))) {
|
if (!in_array($this->context->getMethod(), array('GET', 'HEAD'))) {
|
||||||
$allow = array_merge($allow, array('GET', 'HEAD'));
|
$allow = array_merge($allow, array('GET', 'HEAD'));
|
||||||
goto not_bar;
|
goto not_bar;
|
||||||
@ -42,7 +42,7 @@ class ProjectUrlMatcher extends Symfony\Component\Routing\Tests\Fixtures\Redirec
|
|||||||
not_bar:
|
not_bar:
|
||||||
|
|
||||||
// barhead
|
// barhead
|
||||||
if (0 === strpos($pathinfo, '/barhead') && preg_match('#^/barhead/(?<foo>[^/]+?)$#s', $pathinfo, $matches)) {
|
if (0 === strpos($pathinfo, '/barhead') && preg_match('#^/barhead/(?<foo>[^/]+)$#s', $pathinfo, $matches)) {
|
||||||
if (!in_array($this->context->getMethod(), array('GET', 'HEAD'))) {
|
if (!in_array($this->context->getMethod(), array('GET', 'HEAD'))) {
|
||||||
$allow = array_merge($allow, array('GET', 'HEAD'));
|
$allow = array_merge($allow, array('GET', 'HEAD'));
|
||||||
goto not_barhead;
|
goto not_barhead;
|
||||||
@ -71,7 +71,7 @@ class ProjectUrlMatcher extends Symfony\Component\Routing\Tests\Fixtures\Redirec
|
|||||||
}
|
}
|
||||||
|
|
||||||
// baz4
|
// baz4
|
||||||
if (0 === strpos($pathinfo, '/test') && preg_match('#^/test/(?<foo>[^/]+?)/?$#s', $pathinfo, $matches)) {
|
if (0 === strpos($pathinfo, '/test') && preg_match('#^/test/(?<foo>[^/]+)/?$#s', $pathinfo, $matches)) {
|
||||||
if (substr($pathinfo, -1) !== '/') {
|
if (substr($pathinfo, -1) !== '/') {
|
||||||
return $this->redirect($pathinfo.'/', 'baz4');
|
return $this->redirect($pathinfo.'/', 'baz4');
|
||||||
}
|
}
|
||||||
@ -80,7 +80,7 @@ class ProjectUrlMatcher extends Symfony\Component\Routing\Tests\Fixtures\Redirec
|
|||||||
}
|
}
|
||||||
|
|
||||||
// baz5
|
// baz5
|
||||||
if (0 === strpos($pathinfo, '/test') && preg_match('#^/test/(?<foo>[^/]+?)/$#s', $pathinfo, $matches)) {
|
if (0 === strpos($pathinfo, '/test') && preg_match('#^/test/(?<foo>[^/]+)/$#s', $pathinfo, $matches)) {
|
||||||
if ($this->context->getMethod() != 'POST') {
|
if ($this->context->getMethod() != 'POST') {
|
||||||
$allow[] = 'POST';
|
$allow[] = 'POST';
|
||||||
goto not_baz5;
|
goto not_baz5;
|
||||||
@ -91,7 +91,7 @@ class ProjectUrlMatcher extends Symfony\Component\Routing\Tests\Fixtures\Redirec
|
|||||||
not_baz5:
|
not_baz5:
|
||||||
|
|
||||||
// baz.baz6
|
// baz.baz6
|
||||||
if (0 === strpos($pathinfo, '/test') && preg_match('#^/test/(?<foo>[^/]+?)/$#s', $pathinfo, $matches)) {
|
if (0 === strpos($pathinfo, '/test') && preg_match('#^/test/(?<foo>[^/]+)/$#s', $pathinfo, $matches)) {
|
||||||
if ($this->context->getMethod() != 'PUT') {
|
if ($this->context->getMethod() != 'PUT') {
|
||||||
$allow[] = 'PUT';
|
$allow[] = 'PUT';
|
||||||
goto not_bazbaz6;
|
goto not_bazbaz6;
|
||||||
@ -120,13 +120,13 @@ class ProjectUrlMatcher extends Symfony\Component\Routing\Tests\Fixtures\Redirec
|
|||||||
if (0 === strpos($pathinfo, '/a')) {
|
if (0 === strpos($pathinfo, '/a')) {
|
||||||
if (0 === strpos($pathinfo, '/a/b\'b')) {
|
if (0 === strpos($pathinfo, '/a/b\'b')) {
|
||||||
// foo1
|
// foo1
|
||||||
if (preg_match('#^/a/b\'b/(?<foo>[^/]+?)$#s', $pathinfo, $matches)) {
|
if (preg_match('#^/a/b\'b/(?<foo>[^/]+)$#s', $pathinfo, $matches)) {
|
||||||
$matches['_route'] = 'foo1';
|
$matches['_route'] = 'foo1';
|
||||||
return $matches;
|
return $matches;
|
||||||
}
|
}
|
||||||
|
|
||||||
// bar1
|
// bar1
|
||||||
if (preg_match('#^/a/b\'b/(?<bar>[^/]+?)$#s', $pathinfo, $matches)) {
|
if (preg_match('#^/a/b\'b/(?<bar>[^/]+)$#s', $pathinfo, $matches)) {
|
||||||
$matches['_route'] = 'bar1';
|
$matches['_route'] = 'bar1';
|
||||||
return $matches;
|
return $matches;
|
||||||
}
|
}
|
||||||
@ -141,13 +141,13 @@ class ProjectUrlMatcher extends Symfony\Component\Routing\Tests\Fixtures\Redirec
|
|||||||
|
|
||||||
if (0 === strpos($pathinfo, '/a/b\'b')) {
|
if (0 === strpos($pathinfo, '/a/b\'b')) {
|
||||||
// foo2
|
// foo2
|
||||||
if (preg_match('#^/a/b\'b/(?<foo1>[^/]+?)$#s', $pathinfo, $matches)) {
|
if (preg_match('#^/a/b\'b/(?<foo1>[^/]+)$#s', $pathinfo, $matches)) {
|
||||||
$matches['_route'] = 'foo2';
|
$matches['_route'] = 'foo2';
|
||||||
return $matches;
|
return $matches;
|
||||||
}
|
}
|
||||||
|
|
||||||
// bar2
|
// bar2
|
||||||
if (preg_match('#^/a/b\'b/(?<bar1>[^/]+?)$#s', $pathinfo, $matches)) {
|
if (preg_match('#^/a/b\'b/(?<bar1>[^/]+)$#s', $pathinfo, $matches)) {
|
||||||
$matches['_route'] = 'bar2';
|
$matches['_route'] = 'bar2';
|
||||||
return $matches;
|
return $matches;
|
||||||
}
|
}
|
||||||
@ -158,7 +158,7 @@ class ProjectUrlMatcher extends Symfony\Component\Routing\Tests\Fixtures\Redirec
|
|||||||
|
|
||||||
if (0 === strpos($pathinfo, '/multi')) {
|
if (0 === strpos($pathinfo, '/multi')) {
|
||||||
// helloWorld
|
// helloWorld
|
||||||
if (0 === strpos($pathinfo, '/multi/hello') && preg_match('#^/multi/hello(?:/(?<who>[^/]+?))?$#s', $pathinfo, $matches)) {
|
if (0 === strpos($pathinfo, '/multi/hello') && preg_match('#^/multi/hello(?:/(?<who>[^/]+))?$#s', $pathinfo, $matches)) {
|
||||||
return array_merge($this->mergeDefaults($matches, array ( 'who' => 'World!',)), array('_route' => 'helloWorld'));
|
return array_merge($this->mergeDefaults($matches, array ( 'who' => 'World!',)), array('_route' => 'helloWorld'));
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -178,13 +178,13 @@ class ProjectUrlMatcher extends Symfony\Component\Routing\Tests\Fixtures\Redirec
|
|||||||
}
|
}
|
||||||
|
|
||||||
// foo3
|
// foo3
|
||||||
if (preg_match('#^/(?<_locale>[^/]+?)/b/(?<foo>[^/]+?)$#s', $pathinfo, $matches)) {
|
if (preg_match('#^/(?<_locale>[^/]+)/b/(?<foo>[^/]+)$#s', $pathinfo, $matches)) {
|
||||||
$matches['_route'] = 'foo3';
|
$matches['_route'] = 'foo3';
|
||||||
return $matches;
|
return $matches;
|
||||||
}
|
}
|
||||||
|
|
||||||
// bar3
|
// bar3
|
||||||
if (preg_match('#^/(?<_locale>[^/]+?)/b/(?<bar>[^/]+?)$#s', $pathinfo, $matches)) {
|
if (preg_match('#^/(?<_locale>[^/]+)/b/(?<bar>[^/]+)$#s', $pathinfo, $matches)) {
|
||||||
$matches['_route'] = 'bar3';
|
$matches['_route'] = 'bar3';
|
||||||
return $matches;
|
return $matches;
|
||||||
}
|
}
|
||||||
@ -195,7 +195,7 @@ class ProjectUrlMatcher extends Symfony\Component\Routing\Tests\Fixtures\Redirec
|
|||||||
}
|
}
|
||||||
|
|
||||||
// foo4
|
// foo4
|
||||||
if (0 === strpos($pathinfo, '/aba') && preg_match('#^/aba/(?<foo>[^/]+?)$#s', $pathinfo, $matches)) {
|
if (0 === strpos($pathinfo, '/aba') && preg_match('#^/aba/(?<foo>[^/]+)$#s', $pathinfo, $matches)) {
|
||||||
$matches['_route'] = 'foo4';
|
$matches['_route'] = 'foo4';
|
||||||
return $matches;
|
return $matches;
|
||||||
}
|
}
|
||||||
@ -208,13 +208,13 @@ class ProjectUrlMatcher extends Symfony\Component\Routing\Tests\Fixtures\Redirec
|
|||||||
|
|
||||||
if (0 === strpos($pathinfo, '/a/b')) {
|
if (0 === strpos($pathinfo, '/a/b')) {
|
||||||
// b
|
// b
|
||||||
if (preg_match('#^/a/b/(?<var>[^/]+?)$#s', $pathinfo, $matches)) {
|
if (preg_match('#^/a/b/(?<var>[^/]+)$#s', $pathinfo, $matches)) {
|
||||||
$matches['_route'] = 'b';
|
$matches['_route'] = 'b';
|
||||||
return $matches;
|
return $matches;
|
||||||
}
|
}
|
||||||
|
|
||||||
// c
|
// c
|
||||||
if (0 === strpos($pathinfo, '/a/b/c') && preg_match('#^/a/b/c/(?<var>[^/]+?)$#s', $pathinfo, $matches)) {
|
if (0 === strpos($pathinfo, '/a/b/c') && preg_match('#^/a/b/c/(?<var>[^/]+)$#s', $pathinfo, $matches)) {
|
||||||
$matches['_route'] = 'c';
|
$matches['_route'] = 'c';
|
||||||
return $matches;
|
return $matches;
|
||||||
}
|
}
|
||||||
|
@ -32,7 +32,7 @@ class ProjectUrlMatcher extends Symfony\Component\Routing\Matcher\UrlMatcher
|
|||||||
}
|
}
|
||||||
|
|
||||||
// dynamic
|
// dynamic
|
||||||
if (preg_match('#^/rootprefix/(?<var>[^/]+?)$#s', $pathinfo, $matches)) {
|
if (preg_match('#^/rootprefix/(?<var>[^/]+)$#s', $pathinfo, $matches)) {
|
||||||
$matches['_route'] = 'dynamic';
|
$matches['_route'] = 'dynamic';
|
||||||
return $matches;
|
return $matches;
|
||||||
}
|
}
|
||||||
|
@ -43,51 +43,51 @@ class RouteCompilerTest extends \PHPUnit_Framework_TestCase
|
|||||||
array(
|
array(
|
||||||
'Route with a variable',
|
'Route with a variable',
|
||||||
array('/foo/{bar}'),
|
array('/foo/{bar}'),
|
||||||
'/foo', '#^/foo/(?<bar>[^/]+?)$#s', array('bar'), array(
|
'/foo', '#^/foo/(?<bar>[^/]+)$#s', array('bar'), array(
|
||||||
array('variable', '/', '[^/]+?', 'bar'),
|
array('variable', '/', '[^/]+', 'bar'),
|
||||||
array('text', '/foo'),
|
array('text', '/foo'),
|
||||||
)),
|
)),
|
||||||
|
|
||||||
array(
|
array(
|
||||||
'Route with a variable that has a default value',
|
'Route with a variable that has a default value',
|
||||||
array('/foo/{bar}', array('bar' => 'bar')),
|
array('/foo/{bar}', array('bar' => 'bar')),
|
||||||
'/foo', '#^/foo(?:/(?<bar>[^/]+?))?$#s', array('bar'), array(
|
'/foo', '#^/foo(?:/(?<bar>[^/]+))?$#s', array('bar'), array(
|
||||||
array('variable', '/', '[^/]+?', 'bar'),
|
array('variable', '/', '[^/]+', 'bar'),
|
||||||
array('text', '/foo'),
|
array('text', '/foo'),
|
||||||
)),
|
)),
|
||||||
|
|
||||||
array(
|
array(
|
||||||
'Route with several variables',
|
'Route with several variables',
|
||||||
array('/foo/{bar}/{foobar}'),
|
array('/foo/{bar}/{foobar}'),
|
||||||
'/foo', '#^/foo/(?<bar>[^/]+?)/(?<foobar>[^/]+?)$#s', array('bar', 'foobar'), array(
|
'/foo', '#^/foo/(?<bar>[^/]+)/(?<foobar>[^/]+)$#s', array('bar', 'foobar'), array(
|
||||||
array('variable', '/', '[^/]+?', 'foobar'),
|
array('variable', '/', '[^/]+', 'foobar'),
|
||||||
array('variable', '/', '[^/]+?', 'bar'),
|
array('variable', '/', '[^/]+', 'bar'),
|
||||||
array('text', '/foo'),
|
array('text', '/foo'),
|
||||||
)),
|
)),
|
||||||
|
|
||||||
array(
|
array(
|
||||||
'Route with several variables that have default values',
|
'Route with several variables that have default values',
|
||||||
array('/foo/{bar}/{foobar}', array('bar' => 'bar', 'foobar' => '')),
|
array('/foo/{bar}/{foobar}', array('bar' => 'bar', 'foobar' => '')),
|
||||||
'/foo', '#^/foo(?:/(?<bar>[^/]+?)(?:/(?<foobar>[^/]+?))?)?$#s', array('bar', 'foobar'), array(
|
'/foo', '#^/foo(?:/(?<bar>[^/]+)(?:/(?<foobar>[^/]+))?)?$#s', array('bar', 'foobar'), array(
|
||||||
array('variable', '/', '[^/]+?', 'foobar'),
|
array('variable', '/', '[^/]+', 'foobar'),
|
||||||
array('variable', '/', '[^/]+?', 'bar'),
|
array('variable', '/', '[^/]+', 'bar'),
|
||||||
array('text', '/foo'),
|
array('text', '/foo'),
|
||||||
)),
|
)),
|
||||||
|
|
||||||
array(
|
array(
|
||||||
'Route with several variables but some of them have no default values',
|
'Route with several variables but some of them have no default values',
|
||||||
array('/foo/{bar}/{foobar}', array('bar' => 'bar')),
|
array('/foo/{bar}/{foobar}', array('bar' => 'bar')),
|
||||||
'/foo', '#^/foo/(?<bar>[^/]+?)/(?<foobar>[^/]+?)$#s', array('bar', 'foobar'), array(
|
'/foo', '#^/foo/(?<bar>[^/]+)/(?<foobar>[^/]+)$#s', array('bar', 'foobar'), array(
|
||||||
array('variable', '/', '[^/]+?', 'foobar'),
|
array('variable', '/', '[^/]+', 'foobar'),
|
||||||
array('variable', '/', '[^/]+?', 'bar'),
|
array('variable', '/', '[^/]+', 'bar'),
|
||||||
array('text', '/foo'),
|
array('text', '/foo'),
|
||||||
)),
|
)),
|
||||||
|
|
||||||
array(
|
array(
|
||||||
'Route with an optional variable as the first segment',
|
'Route with an optional variable as the first segment',
|
||||||
array('/{bar}', array('bar' => 'bar')),
|
array('/{bar}', array('bar' => 'bar')),
|
||||||
'', '#^/(?<bar>[^/]+?)?$#s', array('bar'), array(
|
'', '#^/(?<bar>[^/]+)?$#s', array('bar'), array(
|
||||||
array('variable', '/', '[^/]+?', 'bar'),
|
array('variable', '/', '[^/]+', 'bar'),
|
||||||
)),
|
)),
|
||||||
|
|
||||||
array(
|
array(
|
||||||
@ -100,8 +100,8 @@ class RouteCompilerTest extends \PHPUnit_Framework_TestCase
|
|||||||
array(
|
array(
|
||||||
'Route with a variable in last position',
|
'Route with a variable in last position',
|
||||||
array('/foo-{bar}'),
|
array('/foo-{bar}'),
|
||||||
'/foo', '#^/foo\-(?<bar>[^\-]+?)$#s', array('bar'), array(
|
'/foo', '#^/foo\-(?<bar>[^\-]+)$#s', array('bar'), array(
|
||||||
array('variable', '-', '[^\-]+?', 'bar'),
|
array('variable', '-', '[^\-]+', 'bar'),
|
||||||
array('text', '/foo'),
|
array('text', '/foo'),
|
||||||
)),
|
)),
|
||||||
|
|
||||||
|
Reference in New Issue
Block a user