2017-08-18 22:57:27 +02:00
|
|
|
<?php declare(strict_types=1);
|
2016-12-22 21:13:42 +01:00
|
|
|
|
|
|
|
namespace PhpParser\Node;
|
|
|
|
|
|
|
|
use PhpParser\NodeAbstract;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Represents a non-namespaced name. Namespaced names are represented using Name nodes.
|
|
|
|
*/
|
2022-08-28 22:57:06 +02:00
|
|
|
class Identifier extends NodeAbstract {
|
2024-04-19 14:04:10 +02:00
|
|
|
/**
|
|
|
|
* @psalm-var non-empty-string
|
|
|
|
* @var string Identifier as string
|
|
|
|
*/
|
2023-08-16 21:18:30 +02:00
|
|
|
public string $name;
|
2016-12-22 21:13:42 +01:00
|
|
|
|
2022-09-17 17:12:55 +02:00
|
|
|
/** @var array<string, bool> */
|
2023-08-16 21:18:30 +02:00
|
|
|
private static array $specialClassNames = [
|
2017-08-15 22:56:53 +02:00
|
|
|
'self' => true,
|
|
|
|
'parent' => true,
|
|
|
|
'static' => true,
|
|
|
|
];
|
|
|
|
|
2016-12-22 21:13:42 +01:00
|
|
|
/**
|
|
|
|
* Constructs an identifier node.
|
|
|
|
*
|
2023-09-17 15:59:04 +02:00
|
|
|
* @param string $name Identifier as string
|
2022-09-11 20:51:31 +02:00
|
|
|
* @param array<string, mixed> $attributes Additional attributes
|
2016-12-22 21:13:42 +01:00
|
|
|
*/
|
2017-08-13 14:06:08 +02:00
|
|
|
public function __construct(string $name, array $attributes = []) {
|
2024-04-19 14:04:10 +02:00
|
|
|
if ($name === '') {
|
|
|
|
throw new \InvalidArgumentException('Identifier name cannot be empty');
|
|
|
|
}
|
|
|
|
|
2019-05-12 14:55:21 +02:00
|
|
|
$this->attributes = $attributes;
|
2016-12-22 21:13:42 +01:00
|
|
|
$this->name = $name;
|
|
|
|
}
|
|
|
|
|
2022-08-28 22:57:06 +02:00
|
|
|
public function getSubNodeNames(): array {
|
2017-08-13 14:06:08 +02:00
|
|
|
return ['name'];
|
2016-12-22 21:13:42 +01:00
|
|
|
}
|
|
|
|
|
2017-10-03 20:57:48 +02:00
|
|
|
/**
|
|
|
|
* Get identifier as string.
|
|
|
|
*
|
2024-04-19 14:04:10 +02:00
|
|
|
* @psalm-return non-empty-string
|
2017-10-03 20:57:48 +02:00
|
|
|
* @return string Identifier as string.
|
|
|
|
*/
|
2022-08-28 22:57:06 +02:00
|
|
|
public function toString(): string {
|
2017-10-03 20:57:48 +02:00
|
|
|
return $this->name;
|
|
|
|
}
|
|
|
|
|
2017-08-15 22:48:24 +02:00
|
|
|
/**
|
|
|
|
* Get lowercased identifier as string.
|
|
|
|
*
|
2024-11-05 17:21:40 +01:00
|
|
|
* @psalm-return non-empty-string&lowercase-string
|
2017-08-15 22:48:24 +02:00
|
|
|
* @return string Lowercased identifier as string
|
|
|
|
*/
|
2022-08-28 22:57:06 +02:00
|
|
|
public function toLowerString(): string {
|
2017-08-15 22:48:24 +02:00
|
|
|
return strtolower($this->name);
|
|
|
|
}
|
|
|
|
|
2017-08-15 22:56:53 +02:00
|
|
|
/**
|
|
|
|
* Checks whether the identifier is a special class name (self, parent or static).
|
|
|
|
*
|
|
|
|
* @return bool Whether identifier is a special class name
|
|
|
|
*/
|
2022-08-28 22:57:06 +02:00
|
|
|
public function isSpecialClassName(): bool {
|
2017-08-15 22:56:53 +02:00
|
|
|
return isset(self::$specialClassNames[strtolower($this->name)]);
|
|
|
|
}
|
|
|
|
|
2016-12-22 21:13:42 +01:00
|
|
|
/**
|
|
|
|
* Get identifier as string.
|
|
|
|
*
|
2024-04-19 14:04:10 +02:00
|
|
|
* @psalm-return non-empty-string
|
2017-08-15 22:48:24 +02:00
|
|
|
* @return string Identifier as string
|
2016-12-22 21:13:42 +01:00
|
|
|
*/
|
2022-08-28 22:57:06 +02:00
|
|
|
public function __toString(): string {
|
2016-12-22 21:13:42 +01:00
|
|
|
return $this->name;
|
|
|
|
}
|
2022-08-28 22:57:06 +02:00
|
|
|
|
|
|
|
public function getType(): string {
|
2017-11-12 21:25:57 +01:00
|
|
|
return 'Identifier';
|
|
|
|
}
|
2016-12-22 21:13:42 +01:00
|
|
|
}
|