mirror of
https://github.com/danog/PHP-Parser.git
synced 2024-12-12 09:29:47 +01:00
63 lines
1.5 KiB
PHP
63 lines
1.5 KiB
PHP
<?php declare(strict_types=1);
|
|
|
|
namespace PhpParser\Node;
|
|
|
|
use PhpParser\NodeAbstract;
|
|
|
|
/**
|
|
* Represents a non-namespaced name. Namespaced names are represented using Name nodes.
|
|
*/
|
|
class Identifier extends NodeAbstract
|
|
{
|
|
/** @var string Identifier as string */
|
|
public $name;
|
|
|
|
private static $specialClassNames = [
|
|
'self' => true,
|
|
'parent' => true,
|
|
'static' => true,
|
|
];
|
|
|
|
/**
|
|
* Constructs an identifier node.
|
|
*
|
|
* @param string $name Identifier as string
|
|
* @param array $attributes Additional attributes
|
|
*/
|
|
public function __construct(string $name, array $attributes = []) {
|
|
parent::__construct($attributes);
|
|
$this->name = $name;
|
|
}
|
|
|
|
public function getSubNodeNames() : array {
|
|
return ['name'];
|
|
}
|
|
|
|
/**
|
|
* Get lowercased identifier as string.
|
|
*
|
|
* @return string Lowercased identifier as string
|
|
*/
|
|
public function toLowerString() : string {
|
|
return strtolower($this->name);
|
|
}
|
|
|
|
/**
|
|
* Checks whether the identifier is a special class name (self, parent or static).
|
|
*
|
|
* @return bool Whether identifier is a special class name
|
|
*/
|
|
public function isSpecialClassName() : bool {
|
|
return isset(self::$specialClassNames[strtolower($this->name)]);
|
|
}
|
|
|
|
/**
|
|
* Get identifier as string.
|
|
*
|
|
* @return string Identifier as string
|
|
*/
|
|
public function __toString() : string {
|
|
return $this->name;
|
|
}
|
|
}
|