TaoLer/vendor/php-di/phpdoc-reader
2022-08-02 21:13:36 +08:00
..
.github/workflows 1.9.20 2022-08-02 21:13:36 +08:00
src/PhpDocReader 1.9.20 2022-08-02 21:13:36 +08:00
.gitattributes 1.9.20 2022-08-02 21:13:36 +08:00
.gitignore 1.9.20 2022-08-02 21:13:36 +08:00
.phpcs.xml.dist 1.9.20 2022-08-02 21:13:36 +08:00
composer.json 1.9.20 2022-08-02 21:13:36 +08:00
LICENSE 1.9.20 2022-08-02 21:13:36 +08:00
README.md 1.9.20 2022-08-02 21:13:36 +08:00

PhpDocReader

This project is used by:

Fork the README to add your project here.

Features

PhpDocReader parses @var and @param values in PHP docblocks:


use My\Cache\Backend;

class Cache
{
    /**
     * @var Backend
     */
    protected $backend;

    /**
     * @param Backend $backend
     */
    public function __construct($backend)
    {
    }
}

It supports namespaced class names with the same resolution rules as PHP:

  • fully qualified name (starting with \)
  • imported class name (eg. use My\Cache\Backend;)
  • relative class name (from the current namespace, like SubNamespace\MyClass)
  • aliased class name (eg. use My\Cache\Backend as FooBar;)

Primitive types (@var string) are ignored (returns null), only valid class names are returned.

Usage

$reader = new PhpDocReader();

// Read a property type (@var phpdoc)
$property = new ReflectionProperty($className, $propertyName);
$propertyClass = $reader->getPropertyClass($property);

// Read a parameter type (@param phpdoc)
$parameter = new ReflectionParameter(array($className, $methodName), $parameterName);
$parameterClass = $reader->getParameterClass($parameter);