Browse Source

cleaned up the router.

Taylor Otwell 13 years ago
parent
commit
549d8cc370
1 changed files with 9 additions and 14 deletions
  1. 9 14
      laravel/routing/router.php

+ 9 - 14
laravel/routing/router.php

@@ -59,11 +59,6 @@ class Router {
 			// need to add it to the action array as a "uses" clause, which will
 			// indicate to the route to call the controller when the route is
 			// executed by the application.
-			//
-			// Note that all route actions are converted to arrays. This just
-			// gives us a convenient and consistent way of accessing it since
-			// we can always make an assumption that the action is an array,
-			// and it lets us store the URIs on the action for each route.
 			if (is_string($action))
 			{
 				static::$routes[$uri]['uses'] = $action;
@@ -74,9 +69,6 @@ class Router {
 			// handled by the route instance.
 			else
 			{
-				// PHP 5.3.2 has a bug that causes closures cast as arrays
-				// to yield an empty array. We will work around this by
-				// manually adding the Closure instance to an array.
 				if ($action instanceof Closure) $action = array($action);
 
 				static::$routes[$uri] = (array) $action;
@@ -226,7 +218,7 @@ class Router {
 
 			// We'll generate a default "uses" clause for the route action that
 			// points to the default controller and method for the bundle so
-			// that the route will execute the default controller method.
+			// that the route will execute the default.
 			$action = array('uses' => Bundle::prefix($bundle).'home@index');
 
 			return new Route($method.' '.$uri, $action);
@@ -234,13 +226,13 @@ class Router {
 
 		$directory = Bundle::path($bundle).'controllers/';
 
-		if ( ! is_null($key = static::controller_key($segments, $directory)))
+		if ( ! is_null($key = static::locate($segments, $directory)))
 		{
 			// First, we'll extract the controller name, then, since we need
 			// to extract the method and parameters, we will remove the name
 			// of the controller from the URI. Then we can shift the method
 			// off of the array of segments. Any remaining segments are the
-			// parameters that should be passed to the controller method.
+			// parameters for the method.
 			$controller = implode('.', array_slice($segments, 0, $key));
 
 			$segments = array_slice($segments, $key);
@@ -260,13 +252,13 @@ class Router {
 	}
 
 	/**
-	 * Get the URI index for the controller that should handle the request.
+	 * Locate the URI segment matching a controller name.
 	 *
 	 * @param  string  $directory
 	 * @param  array   $segments
 	 * @return int
 	 */
-	protected static function controller_key($segments, $directory)
+	protected static function locate($segments, $directory)
 	{
 		for ($i = count($segments) - 1; $i >= 0; $i--)
 		{
@@ -301,7 +293,10 @@ class Router {
 		// back on after we know how many replacements we made.
 		$key = str_replace($search, $replace, $key, $count);
 
-		$key .= ($count > 0) ? str_repeat(')?', $count) : '';
+		if ($count > 0)
+		{
+			$key .= str_repeat(')?', $count);
+		}
 
 		// For "regular" parameters, we can just do a simple translate
 		// using the patterns array. There is not need to cap the