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\CodeUnitView 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<int> | |
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<int> | |
CodeUnit::__construct | private | function | @psalm-param list<int> $sourceLines |