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

Breadcrumb

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

class CodeUnit

@psalm-immutable

Hierarchy

  • class \SebastianBergmann\CodeUnit\CodeUnit

Expanded class hierarchy of CodeUnit

1 file declares its use of CodeUnit
ExcludeList.php in vendor/phpunit/phpunit/src/Util/ExcludeList.php

File

vendor/sebastian/code-unit/src/CodeUnit.php, line 25

Namespace

SebastianBergmann\CodeUnit
View source
abstract class CodeUnit {
    private readonly string $name;
    private readonly string $sourceFileName;
    
    /**
     * @psalm-var list<int>
     */
    private readonly array $sourceLines;
    
    /**
     * @psalm-param class-string $className
     *
     * @throws InvalidCodeUnitException
     * @throws ReflectionException
     */
    public static function forClass(string $className) : ClassUnit {
        self::ensureUserDefinedClass($className);
        $reflector = self::reflectorForClass($className);
        return new ClassUnit($className, $reflector->getFileName(), range($reflector->getStartLine(), $reflector->getEndLine()));
    }
    
    /**
     * @psalm-param class-string $className
     *
     * @throws InvalidCodeUnitException
     * @throws ReflectionException
     */
    public static function forClassMethod(string $className, string $methodName) : ClassMethodUnit {
        self::ensureUserDefinedClass($className);
        $reflector = self::reflectorForClassMethod($className, $methodName);
        return new ClassMethodUnit($className . '::' . $methodName, $reflector->getFileName(), range($reflector->getStartLine(), $reflector->getEndLine()));
    }
    
    /**
     * @throws InvalidCodeUnitException
     */
    public static function forFileWithAbsolutePath(string $path) : FileUnit {
        self::ensureFileExistsAndIsReadable($path);
        return new FileUnit($path, $path, range(1, count(file($path))));
    }
    
    /**
     * @psalm-param class-string $interfaceName
     *
     * @throws InvalidCodeUnitException
     * @throws ReflectionException
     */
    public static function forInterface(string $interfaceName) : InterfaceUnit {
        self::ensureUserDefinedInterface($interfaceName);
        $reflector = self::reflectorForClass($interfaceName);
        return new InterfaceUnit($interfaceName, $reflector->getFileName(), range($reflector->getStartLine(), $reflector->getEndLine()));
    }
    
    /**
     * @psalm-param class-string $interfaceName
     *
     * @throws InvalidCodeUnitException
     * @throws ReflectionException
     */
    public static function forInterfaceMethod(string $interfaceName, string $methodName) : InterfaceMethodUnit {
        self::ensureUserDefinedInterface($interfaceName);
        $reflector = self::reflectorForClassMethod($interfaceName, $methodName);
        return new InterfaceMethodUnit($interfaceName . '::' . $methodName, $reflector->getFileName(), range($reflector->getStartLine(), $reflector->getEndLine()));
    }
    
    /**
     * @psalm-param class-string $traitName
     *
     * @throws InvalidCodeUnitException
     * @throws ReflectionException
     */
    public static function forTrait(string $traitName) : TraitUnit {
        self::ensureUserDefinedTrait($traitName);
        $reflector = self::reflectorForClass($traitName);
        return new TraitUnit($traitName, $reflector->getFileName(), range($reflector->getStartLine(), $reflector->getEndLine()));
    }
    
    /**
     * @psalm-param class-string $traitName
     *
     * @throws InvalidCodeUnitException
     * @throws ReflectionException
     */
    public static function forTraitMethod(string $traitName, string $methodName) : TraitMethodUnit {
        self::ensureUserDefinedTrait($traitName);
        $reflector = self::reflectorForClassMethod($traitName, $methodName);
        return new TraitMethodUnit($traitName . '::' . $methodName, $reflector->getFileName(), range($reflector->getStartLine(), $reflector->getEndLine()));
    }
    
    /**
     * @psalm-param callable-string $functionName
     *
     * @throws InvalidCodeUnitException
     * @throws ReflectionException
     */
    public static function forFunction(string $functionName) : FunctionUnit {
        $reflector = self::reflectorForFunction($functionName);
        if (!$reflector->isUserDefined()) {
            throw new InvalidCodeUnitException(sprintf('"%s" is not a user-defined function', $functionName));
        }
        return new FunctionUnit($functionName, $reflector->getFileName(), range($reflector->getStartLine(), $reflector->getEndLine()));
    }
    
    /**
     * @psalm-param list<int> $sourceLines
     */
    private function __construct(string $name, string $sourceFileName, array $sourceLines) {
        $this->name = $name;
        $this->sourceFileName = $sourceFileName;
        $this->sourceLines = $sourceLines;
    }
    public function name() : string {
        return $this->name;
    }
    public function sourceFileName() : string {
        return $this->sourceFileName;
    }
    
    /**
     * @psalm-return list<int>
     */
    public function sourceLines() : array {
        return $this->sourceLines;
    }
    public function isClass() : bool {
        return false;
    }
    public function isClassMethod() : bool {
        return false;
    }
    public function isInterface() : bool {
        return false;
    }
    public function isInterfaceMethod() : bool {
        return false;
    }
    public function isTrait() : bool {
        return false;
    }
    public function isTraitMethod() : bool {
        return false;
    }
    public function isFunction() : bool {
        return false;
    }
    public function isFile() : bool {
        return false;
    }
    
    /**
     * @throws InvalidCodeUnitException
     */
    private static function ensureFileExistsAndIsReadable(string $path) : void {
        if (!(file_exists($path) && is_readable($path))) {
            throw new InvalidCodeUnitException(sprintf('File "%s" does not exist or is not readable', $path));
        }
    }
    
    /**
     * @psalm-param class-string $className
     *
     * @throws InvalidCodeUnitException
     */
    private static function ensureUserDefinedClass(string $className) : void {
        try {
            $reflector = new ReflectionClass($className);
            if ($reflector->isInterface()) {
                throw new InvalidCodeUnitException(sprintf('"%s" is an interface and not a class', $className));
            }
            if ($reflector->isTrait()) {
                throw new InvalidCodeUnitException(sprintf('"%s" is a trait and not a class', $className));
            }
            if (!$reflector->isUserDefined()) {
                throw new InvalidCodeUnitException(sprintf('"%s" is not a user-defined class', $className));
            }
            // @codeCoverageIgnoreStart
        } catch (\ReflectionException $e) {
            throw new ReflectionException($e->getMessage(), $e->getCode(), $e);
        }
        // @codeCoverageIgnoreEnd
    }
    
    /**
     * @psalm-param class-string $interfaceName
     *
     * @throws InvalidCodeUnitException
     */
    private static function ensureUserDefinedInterface(string $interfaceName) : void {
        try {
            $reflector = new ReflectionClass($interfaceName);
            if (!$reflector->isInterface()) {
                throw new InvalidCodeUnitException(sprintf('"%s" is not an interface', $interfaceName));
            }
            if (!$reflector->isUserDefined()) {
                throw new InvalidCodeUnitException(sprintf('"%s" is not a user-defined interface', $interfaceName));
            }
            // @codeCoverageIgnoreStart
        } catch (\ReflectionException $e) {
            throw new ReflectionException($e->getMessage(), $e->getCode(), $e);
        }
        // @codeCoverageIgnoreEnd
    }
    
    /**
     * @psalm-param class-string $traitName
     *
     * @throws InvalidCodeUnitException
     */
    private static function ensureUserDefinedTrait(string $traitName) : void {
        try {
            $reflector = new ReflectionClass($traitName);
            if (!$reflector->isTrait()) {
                throw new InvalidCodeUnitException(sprintf('"%s" is not a trait', $traitName));
            }
            // @codeCoverageIgnoreStart
            if (!$reflector->isUserDefined()) {
                throw new InvalidCodeUnitException(sprintf('"%s" is not a user-defined trait', $traitName));
            }
        } catch (\ReflectionException $e) {
            throw new ReflectionException($e->getMessage(), $e->getCode(), $e);
        }
        // @codeCoverageIgnoreEnd
    }
    
    /**
     * @psalm-param class-string $className
     *
     * @throws ReflectionException
     */
    private static function reflectorForClass(string $className) : ReflectionClass {
        try {
            return new ReflectionClass($className);
            // @codeCoverageIgnoreStart
        } catch (\ReflectionException $e) {
            throw new ReflectionException($e->getMessage(), $e->getCode(), $e);
        }
        // @codeCoverageIgnoreEnd
    }
    
    /**
     * @psalm-param class-string $className
     *
     * @throws ReflectionException
     */
    private static function reflectorForClassMethod(string $className, string $methodName) : ReflectionMethod {
        try {
            return new ReflectionMethod($className, $methodName);
            // @codeCoverageIgnoreStart
        } catch (\ReflectionException $e) {
            throw new ReflectionException($e->getMessage(), $e->getCode(), $e);
        }
        // @codeCoverageIgnoreEnd
    }
    
    /**
     * @psalm-param callable-string $functionName
     *
     * @throws ReflectionException
     */
    private static function reflectorForFunction(string $functionName) : ReflectionFunction {
        try {
            return new ReflectionFunction($functionName);
            // @codeCoverageIgnoreStart
        } catch (\ReflectionException $e) {
            throw new ReflectionException($e->getMessage(), $e->getCode(), $e);
        }
        // @codeCoverageIgnoreEnd
    }

}

Members

Title Sort descending Modifiers Object type Summary Overrides
CodeUnit::$name private property
CodeUnit::$sourceFileName private property
CodeUnit::$sourceLines private property @psalm-var list&lt;int&gt;
CodeUnit::ensureFileExistsAndIsReadable private static function
CodeUnit::ensureUserDefinedClass private static function @psalm-param class-string $className
CodeUnit::ensureUserDefinedInterface private static function @psalm-param class-string $interfaceName
CodeUnit::ensureUserDefinedTrait private static function @psalm-param class-string $traitName
CodeUnit::forClass public static function @psalm-param class-string $className
CodeUnit::forClassMethod public static function @psalm-param class-string $className
CodeUnit::forFileWithAbsolutePath public static function
CodeUnit::forFunction public static function @psalm-param callable-string $functionName
CodeUnit::forInterface public static function @psalm-param class-string $interfaceName
CodeUnit::forInterfaceMethod public static function @psalm-param class-string $interfaceName
CodeUnit::forTrait public static function @psalm-param class-string $traitName
CodeUnit::forTraitMethod public static function @psalm-param class-string $traitName
CodeUnit::isClass public function 1
CodeUnit::isClassMethod public function 1
CodeUnit::isFile public function 1
CodeUnit::isFunction public function 1
CodeUnit::isInterface public function 1
CodeUnit::isInterfaceMethod public function 1
CodeUnit::isTrait public function 1
CodeUnit::isTraitMethod public function 1
CodeUnit::name public function
CodeUnit::reflectorForClass private static function @psalm-param class-string $className
CodeUnit::reflectorForClassMethod private static function @psalm-param class-string $className
CodeUnit::reflectorForFunction private static function @psalm-param callable-string $functionName
CodeUnit::sourceFileName public function
CodeUnit::sourceLines public function @psalm-return list&lt;int&gt;
CodeUnit::__construct private function @psalm-param list&lt;int&gt; $sourceLines
RSS feed
Powered by Drupal