Jelajahi Sumber

[HttpKernel] made a small internal refactoring to ease extensibility

Fabien Potencier 13 tahun lalu
induk
melakukan
54999ef02d

+ 15 - 6
src/Symfony/Component/HttpKernel/Controller/ControllerResolver.php

@@ -93,22 +93,23 @@ class ControllerResolver implements ControllerResolverInterface
      */
      */
     public function getArguments(Request $request, $controller)
     public function getArguments(Request $request, $controller)
     {
     {
-        $attributes = $request->attributes->all();
-
         if (is_array($controller)) {
         if (is_array($controller)) {
             $r = new \ReflectionMethod($controller[0], $controller[1]);
             $r = new \ReflectionMethod($controller[0], $controller[1]);
-            $repr = sprintf('%s::%s()', get_class($controller[0]), $controller[1]);
         } elseif (is_object($controller)) {
         } elseif (is_object($controller)) {
             $r = new \ReflectionObject($controller);
             $r = new \ReflectionObject($controller);
             $r = $r->getMethod('__invoke');
             $r = $r->getMethod('__invoke');
-            $repr = get_class($controller);
         } else {
         } else {
             $r = new \ReflectionFunction($controller);
             $r = new \ReflectionFunction($controller);
-            $repr = $controller;
         }
         }
 
 
+        return $this->doGetArguments($request, $controller, $r->getParameters());
+    }
+
+    protected function doGetArguments(Request $request, $controller, array $parameters)
+    {
+        $attributes = $request->attributes->all();
         $arguments = array();
         $arguments = array();
-        foreach ($r->getParameters() as $param) {
+        foreach ($parameters as $param) {
             if (array_key_exists($param->getName(), $attributes)) {
             if (array_key_exists($param->getName(), $attributes)) {
                 $arguments[] = $attributes[$param->getName()];
                 $arguments[] = $attributes[$param->getName()];
             } elseif ($param->getClass() && $param->getClass()->isInstance($request)) {
             } elseif ($param->getClass() && $param->getClass()->isInstance($request)) {
@@ -116,6 +117,14 @@ class ControllerResolver implements ControllerResolverInterface
             } elseif ($param->isDefaultValueAvailable()) {
             } elseif ($param->isDefaultValueAvailable()) {
                 $arguments[] = $param->getDefaultValue();
                 $arguments[] = $param->getDefaultValue();
             } else {
             } else {
+                if (is_array($controller)) {
+                    $repr = sprintf('%s::%s()', get_class($controller[0]), $controller[1]);
+                } elseif (is_object($controller)) {
+                    $repr = get_class($controller);
+                } else {
+                    $repr = $controller;
+                }
+
                 throw new \RuntimeException(sprintf('Controller "%s" requires that you provide a value for the "$%s" argument (because there is no default value or because there is a non optional argument after this one).', $repr, $param->getName()));
                 throw new \RuntimeException(sprintf('Controller "%s" requires that you provide a value for the "$%s" argument (because there is no default value or because there is a non optional argument after this one).', $repr, $param->getName()));
             }
             }
         }
         }