mirror of
https://github.com/nikic/PHP-Parser.git
synced 2025-01-17 07:08:14 +01:00
ab51e9d35a
These just specify a type that is already specified as a real PHP type.
95 lines
3.1 KiB
PHP
95 lines
3.1 KiB
PHP
<?php declare(strict_types=1);
|
|
|
|
namespace PhpParser\Node\Stmt;
|
|
|
|
use PhpParser\Modifiers;
|
|
use PhpParser\Node;
|
|
|
|
class Class_ extends ClassLike {
|
|
/** @deprecated Use Modifiers::PUBLIC instead */
|
|
public const MODIFIER_PUBLIC = 1;
|
|
/** @deprecated Use Modifiers::PROTECTED instead */
|
|
public const MODIFIER_PROTECTED = 2;
|
|
/** @deprecated Use Modifiers::PRIVATE instead */
|
|
public const MODIFIER_PRIVATE = 4;
|
|
/** @deprecated Use Modifiers::STATIC instead */
|
|
public const MODIFIER_STATIC = 8;
|
|
/** @deprecated Use Modifiers::ABSTRACT instead */
|
|
public const MODIFIER_ABSTRACT = 16;
|
|
/** @deprecated Use Modifiers::FINAL instead */
|
|
public const MODIFIER_FINAL = 32;
|
|
/** @deprecated Use Modifiers::READONLY instead */
|
|
public const MODIFIER_READONLY = 64;
|
|
|
|
/** @deprecated Use Modifiers::VISIBILITY_MASK instead */
|
|
public const VISIBILITY_MODIFIER_MASK = 7; // 1 | 2 | 4
|
|
|
|
/** @var int Modifiers */
|
|
public int $flags;
|
|
/** @var null|Node\Name Name of extended class */
|
|
public ?Node\Name $extends;
|
|
/** @var Node\Name[] Names of implemented interfaces */
|
|
public array $implements;
|
|
|
|
/**
|
|
* Constructs a class node.
|
|
*
|
|
* @param string|Node\Identifier|null $name Name
|
|
* @param array{
|
|
* flags?: int,
|
|
* extends?: Node\Name|null,
|
|
* implements?: Node\Name[],
|
|
* stmts?: Node\Stmt[],
|
|
* attrGroups?: Node\AttributeGroup[],
|
|
* } $subNodes Array of the following optional subnodes:
|
|
* 'flags' => 0 : Flags
|
|
* 'extends' => null : Name of extended class
|
|
* 'implements' => array(): Names of implemented interfaces
|
|
* 'stmts' => array(): Statements
|
|
* 'attrGroups' => array(): PHP attribute groups
|
|
* @param array<string, mixed> $attributes Additional attributes
|
|
*/
|
|
public function __construct($name, array $subNodes = [], array $attributes = []) {
|
|
$this->attributes = $attributes;
|
|
$this->flags = $subNodes['flags'] ?? $subNodes['type'] ?? 0;
|
|
$this->name = \is_string($name) ? new Node\Identifier($name) : $name;
|
|
$this->extends = $subNodes['extends'] ?? null;
|
|
$this->implements = $subNodes['implements'] ?? [];
|
|
$this->stmts = $subNodes['stmts'] ?? [];
|
|
$this->attrGroups = $subNodes['attrGroups'] ?? [];
|
|
}
|
|
|
|
public function getSubNodeNames(): array {
|
|
return ['attrGroups', 'flags', 'name', 'extends', 'implements', 'stmts'];
|
|
}
|
|
|
|
/**
|
|
* Whether the class is explicitly abstract.
|
|
*/
|
|
public function isAbstract(): bool {
|
|
return (bool) ($this->flags & Modifiers::ABSTRACT);
|
|
}
|
|
|
|
/**
|
|
* Whether the class is final.
|
|
*/
|
|
public function isFinal(): bool {
|
|
return (bool) ($this->flags & Modifiers::FINAL);
|
|
}
|
|
|
|
public function isReadonly(): bool {
|
|
return (bool) ($this->flags & Modifiers::READONLY);
|
|
}
|
|
|
|
/**
|
|
* Whether the class is anonymous.
|
|
*/
|
|
public function isAnonymous(): bool {
|
|
return null === $this->name;
|
|
}
|
|
|
|
public function getType(): string {
|
|
return 'Stmt_Class';
|
|
}
|
|
}
|