Skip to main content
Drupal API
User account menu
  • Log in

Breadcrumb

  1. Drupal Core 11.1.x
  2. ArgumentMetadataFactory.php

class ArgumentMetadataFactory

Builds { @author Iltar van der Berg <kjarli@gmail.com>

Hierarchy

  • class \Symfony\Component\HttpKernel\ControllerMetadata\ArgumentMetadataFactory implements \Symfony\Component\HttpKernel\ControllerMetadata\ArgumentMetadataFactoryInterface

Expanded class hierarchy of ArgumentMetadataFactory

See also

ArgumentMetadata} objects based on the given Controller.

1 file declares its use of ArgumentMetadataFactory
ArgumentResolver.php in vendor/symfony/http-kernel/Controller/ArgumentResolver.php

File

vendor/symfony/http-kernel/ControllerMetadata/ArgumentMetadataFactory.php, line 19

Namespace

Symfony\Component\HttpKernel\ControllerMetadata
View source
final class ArgumentMetadataFactory implements ArgumentMetadataFactoryInterface {
    public function createArgumentMetadata(string|object|array $controller, ?\ReflectionFunctionAbstract $reflector = null) : array {
        $arguments = [];
        $reflector ??= new \ReflectionFunction($controller(...));
        $controllerName = $this->getPrettyName($reflector);
        foreach ($reflector->getParameters() as $param) {
            $attributes = [];
            foreach ($param->getAttributes() as $reflectionAttribute) {
                if (class_exists($reflectionAttribute->getName())) {
                    $attributes[] = $reflectionAttribute->newInstance();
                }
            }
            $arguments[] = new ArgumentMetadata($param->getName(), $this->getType($param), $param->isVariadic(), $param->isDefaultValueAvailable(), $param->isDefaultValueAvailable() ? $param->getDefaultValue() : null, $param->allowsNull(), $attributes, $controllerName);
        }
        return $arguments;
    }
    
    /**
     * Returns an associated type to the given parameter if available.
     */
    private function getType(\ReflectionParameter $parameter) : ?string {
        if (!($type = $parameter->getType())) {
            return null;
        }
        $name = $type instanceof \ReflectionNamedType ? $type->getName() : (string) $type;
        return match (strtolower($name)) {    'self' => $parameter->getDeclaringClass()?->name,
            'parent' => get_parent_class($parameter->getDeclaringClass()?->name ?? '') ?: null,
            default => $name,
        
        };
    }
    private function getPrettyName(\ReflectionFunctionAbstract $r) : string {
        $name = $r->name;
        if ($r instanceof \ReflectionMethod) {
            return $r->class . '::' . $name;
        }
        if ($r->isAnonymous() || !($class = $r->getClosureCalledClass())) {
            return $name;
        }
        return $class->name . '::' . $name;
    }

}

Members

Title Sort descending Modifiers Object type Summary Overriden Title
ArgumentMetadataFactory::createArgumentMetadata public function Overrides ArgumentMetadataFactoryInterface::createArgumentMetadata
ArgumentMetadataFactory::getPrettyName private function
ArgumentMetadataFactory::getType private function Returns an associated type to the given parameter if available.

API Navigation

  • Drupal Core 11.1.x
  • Topics
  • Classes
  • Functions
  • Constants
  • Globals
  • Files
  • Namespaces
  • Deprecated
  • Services
RSS feed
Powered by Drupal