Commit ce5a922b by Taylor Otwell

cleaning up the uri method.

parent f3be544b
...@@ -33,22 +33,14 @@ class URI { ...@@ -33,22 +33,14 @@ class URI {
$uri = static::remove($uri, parse_url(URL::base(), PHP_URL_PATH)); $uri = static::remove($uri, parse_url(URL::base(), PHP_URL_PATH));
// We'll also remove the application's index page as it is not used for at // We'll also remove the application's index page as it is not used for at
// all for routing and is totally unnecessary as far as the framework is // all for routing and is totally unnecessary as far as the routing of
// concerned. It is only in the URI when mod_rewrite is not available. // incoming requests to the framework is concerned.
if (($index = '/'.Config::get('application.index')) !== '/') if (($index = '/'.Config::get('application.index')) !== '/')
{ {
$uri = static::remove($uri, $index); $uri = static::remove($uri, $index);
} }
static::$uri = static::format($uri); static::segments(static::$uri = static::format($uri));
// Cache the URI segments. This allows us to avoid having to explode
// the segments every time the developer requests one of them. The
// extra slashes have already been stripped off of the URI so no
// extraneous elements should be present in the segment array.
$segments = explode('/', trim(static::$uri, '/'));
static::$segments = array_diff($segments, array(''));
return static::$uri; return static::$uri;
} }
...@@ -76,6 +68,19 @@ class URI { ...@@ -76,6 +68,19 @@ class URI {
} }
/** /**
* Set the URI segments for the request.
*
* @param string $uri
* @return void
*/
protected function segments($uri)
{
$segments = explode('/', trim($uri, '/'));
static::$segments = array_diff($segments, array(''));
}
/**
* Remove a given value from the URI. * Remove a given value from the URI.
* *
* @param string $uri * @param string $uri
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment