mirror of
https://github.com/phabelio/PHP-Parser.git
synced 2024-12-02 17:38:19 +01:00
01e85a26c6
We store an Expr\Error for the variable in this case.
50 lines
1.6 KiB
PHP
50 lines
1.6 KiB
PHP
<?php declare(strict_types=1);
|
|
|
|
namespace PhpParser\Node;
|
|
|
|
use PhpParser\NodeAbstract;
|
|
|
|
class Param extends NodeAbstract
|
|
{
|
|
/** @var null|Identifier|Name|NullableType Typehint */
|
|
public $type;
|
|
/** @var bool Whether parameter is passed by reference */
|
|
public $byRef;
|
|
/** @var bool Whether this is a variadic argument */
|
|
public $variadic;
|
|
/** @var Expr\Variable|Expr\Error Parameter variable */
|
|
public $var;
|
|
/** @var null|Expr Default value */
|
|
public $default;
|
|
|
|
/**
|
|
* Constructs a parameter node.
|
|
*
|
|
* @param Expr\Variable|Expr\Error $var Parameter variable
|
|
* @param null|Expr $default Default value
|
|
* @param null|string|Name|NullableType $type Typehint
|
|
* @param bool $byRef Whether is passed by reference
|
|
* @param bool $variadic Whether this is a variadic argument
|
|
* @param array $attributes Additional attributes
|
|
*/
|
|
public function __construct(
|
|
$var, Expr $default = null, $type = null,
|
|
bool $byRef = false, bool $variadic = false, array $attributes = []
|
|
) {
|
|
parent::__construct($attributes);
|
|
$this->type = \is_string($type) ? new Identifier($type) : $type;
|
|
$this->byRef = $byRef;
|
|
$this->variadic = $variadic;
|
|
$this->var = $var;
|
|
$this->default = $default;
|
|
}
|
|
|
|
public function getSubNodeNames() : array {
|
|
return ['type', 'byRef', 'variadic', 'var', 'default'];
|
|
}
|
|
|
|
public function getType() : string {
|
|
return 'Param';
|
|
}
|
|
}
|