44 lines
1.2 KiB
PHP
44 lines
1.2 KiB
PHP
|
<?php declare(strict_types=1);
|
||
|
|
||
|
namespace PhpParser\Node;
|
||
|
|
||
|
use PhpParser\NodeAbstract;
|
||
|
|
||
|
class ArrayItem extends NodeAbstract {
|
||
|
/** @var null|Expr Key */
|
||
|
public ?Expr $key;
|
||
|
/** @var Expr Value */
|
||
|
public Expr $value;
|
||
|
/** @var bool Whether to assign by reference */
|
||
|
public bool $byRef;
|
||
|
/** @var bool Whether to unpack the argument */
|
||
|
public bool $unpack;
|
||
|
|
||
|
/**
|
||
|
* Constructs an array item node.
|
||
|
*
|
||
|
* @param Expr $value Value
|
||
|
* @param null|Expr $key Key
|
||
|
* @param bool $byRef Whether to assign by reference
|
||
|
* @param array<string, mixed> $attributes Additional attributes
|
||
|
*/
|
||
|
public function __construct(Expr $value, ?Expr $key = null, bool $byRef = false, array $attributes = [], bool $unpack = false) {
|
||
|
$this->attributes = $attributes;
|
||
|
$this->key = $key;
|
||
|
$this->value = $value;
|
||
|
$this->byRef = $byRef;
|
||
|
$this->unpack = $unpack;
|
||
|
}
|
||
|
|
||
|
public function getSubNodeNames(): array {
|
||
|
return ['key', 'value', 'byRef', 'unpack'];
|
||
|
}
|
||
|
|
||
|
public function getType(): string {
|
||
|
return 'ArrayItem';
|
||
|
}
|
||
|
}
|
||
|
|
||
|
// @deprecated compatibility alias
|
||
|
class_alias(ArrayItem::class, Expr\ArrayItem::class);
|