File "Function_.php"
Full Path: /var/www/html/back/vendor/phpdocumentor/reflection/src/phpDocumentor/Reflection/Php/Function_.php
File size: 3.07 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;
use phpDocumentor\Reflection\Type;
use phpDocumentor\Reflection\Types\Mixed_;
/**
* Descriptor representing a function
*
* @api
*/
// @codingStandardsIgnoreStart
final class Function_ implements Element, MetaDataContainerInterface, AttributeContainer
// // @codingStandardsIgnoreEnd
{
use MetadataContainer;
use HasAttributes;
/** @var Argument[] */
private array $arguments = [];
private readonly Location $location;
private readonly Location $endLocation;
private readonly Type $returnType;
/**
* Initializes the object.
*/
public function __construct(
/** @var Fqsen Full Qualified Structural Element Name */
private readonly Fqsen $fqsen,
private readonly DocBlock|null $docBlock = null,
Location|null $location = null,
Location|null $endLocation = null,
Type|null $returnType = null,
private readonly bool $hasReturnByReference = false,
) {
if ($location === null) {
$location = new Location(-1);
}
if ($endLocation === null) {
$endLocation = new Location(-1);
}
if ($returnType === null) {
$returnType = new Mixed_();
}
$this->location = $location;
$this->endLocation = $endLocation;
$this->returnType = $returnType;
}
/**
* Returns the arguments of this function.
*
* @return Argument[]
*/
public function getArguments(): array
{
return $this->arguments;
}
/**
* Add an argument to the function.
*/
public function addArgument(Argument $argument): void
{
$this->arguments[] = $argument;
}
/**
* 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();
}
/**
* Returns the DocBlock of the element if available
*/
public function getDocBlock(): DocBlock|null
{
return $this->docBlock;
}
public function getLocation(): Location
{
return $this->location;
}
public function getEndLocation(): Location
{
return $this->endLocation;
}
public function getReturnType(): Type
{
return $this->returnType;
}
public function getHasReturnByReference(): bool
{
return $this->hasReturnByReference;
}
}