File "Class_.php"
Full Path: /var/www/html/back/vendor/phpdocumentor/reflection/src/phpDocumentor/Reflection/Php/Class_.php
File size: 5.52 KB
MIME-type: text/x-php
Charset: utf-8
<?php
declare(strict_types=1);
/**
* This file is part of phpDocumentor.
*
* For the full copyright and license information, please view the LICENSE
* file that was distributed with this source code.
*
* @link http://phpdoc.org
*/
namespace phpDocumentor\Reflection\Php;
use Override;
use phpDocumentor\Reflection\DocBlock;
use phpDocumentor\Reflection\Element;
use phpDocumentor\Reflection\Fqsen;
use phpDocumentor\Reflection\Location;
use phpDocumentor\Reflection\Metadata\MetaDataContainer as MetaDataContainerInterface;
/**
* Descriptor representing a Class.
*
* @api
*/
// @codingStandardsIgnoreStart
final class Class_ implements Element, MetaDataContainerInterface, AttributeContainer
// @codingStandardsIgnoreEnd
{
use MetadataContainer;
use HasAttributes;
/** @var Fqsen[] References to interfaces that are implemented by this class. */
private array $implements = [];
/** @var Constant[] References to constants defined in this class. */
private array $constants = [];
/** @var Property[] References to properties defined in this class. */
private array $properties = [];
/** @var Method[] References to methods defined in this class. */
private array $methods = [];
/** @var Fqsen[] References to traits consumed by this class */
private array $usedTraits = [];
private readonly Location $location;
private readonly Location $endLocation;
/**
* Initializes a number of properties with the given values. Others are initialized by definition.
*/
public function __construct(
/** @var Fqsen Full Qualified Structural Element Name */
private readonly Fqsen $fqsen,
private readonly DocBlock|null $docBlock = null,
/** @var Fqsen|null The class this class is extending. */
private readonly Fqsen|null $parent = null,
/** @var bool Whether this is an abstract class. */
private readonly bool $abstract = false,
/** @var bool Whether this class is marked as final and can't be subclassed. */
private readonly bool $final = false,
Location|null $location = null,
Location|null $endLocation = null,
private readonly bool $readOnly = false,
) {
if ($location === null) {
$location = new Location(-1);
}
if ($endLocation === null) {
$endLocation = new Location(-1);
}
$this->location = $location;
$this->endLocation = $endLocation;
}
/**
* Returns true when this class is final. Otherwise returns false.
*/
public function isFinal(): bool
{
return $this->final;
}
/**
* Returns true when this class is abstract. Otherwise returns false.
*/
public function isAbstract(): bool
{
return $this->abstract;
}
/**
* Returns true when this class is read-only. Otherwise returns false.
*/
public function isReadOnly(): bool
{
return $this->readOnly;
}
/**
* Returns the superclass this class is extending if available.
*/
public function getParent(): Fqsen|null
{
return $this->parent;
}
/**
* Returns the interfaces this class is implementing.
*
* @return Fqsen[]
*/
public function getInterfaces(): array
{
return $this->implements;
}
/**
* Add a interface Fqsen this class is implementing.
*/
public function addInterface(Fqsen $interface): void
{
$this->implements[(string) $interface] = $interface;
}
/**
* Returns the constants of this class.
*
* @return Constant[]
*/
public function getConstants(): array
{
return $this->constants;
}
/**
* Add Constant to this class.
*/
public function addConstant(Constant $constant): void
{
$this->constants[(string) $constant->getFqsen()] = $constant;
}
/**
* Returns the methods of this class.
*
* @return Method[]
*/
public function getMethods(): array
{
return $this->methods;
}
/**
* Add a method to this class.
*/
public function addMethod(Method $method): void
{
$this->methods[(string) $method->getFqsen()] = $method;
}
/**
* Returns the properties of this class.
*
* @return Property[]
*/
public function getProperties(): array
{
return $this->properties;
}
/**
* Add a property to this class.
*/
public function addProperty(Property $property): void
{
$this->properties[(string) $property->getFqsen()] = $property;
}
/**
* Returns the traits used by this class.
*
* @return Fqsen[]
*/
public function getUsedTraits(): array
{
return $this->usedTraits;
}
/**
* Add trait fqsen used by this class.
*/
public function addUsedTrait(Fqsen $fqsen): void
{
$this->usedTraits[(string) $fqsen] = $fqsen;
}
/**
* Returns the Fqsen of the element.
*/
#[Override]
public function getFqsen(): Fqsen
{
return $this->fqsen;
}
/**
* Returns the name of the element.
*/
#[Override]
public function getName(): string
{
return $this->fqsen->getName();
}
public function getDocBlock(): DocBlock|null
{
return $this->docBlock;
}
public function getLocation(): Location
{
return $this->location;
}
public function getEndLocation(): Location
{
return $this->endLocation;
}
}