mirror of
https://github.com/danog/PHP-Parser.git
synced 2024-12-12 17:37:21 +01:00
1c11626f0a
Rather than automatically deriving getType() from the class name.
72 lines
1.7 KiB
PHP
72 lines
1.7 KiB
PHP
<?php declare(strict_types=1);
|
|
|
|
namespace PhpParser\Node\Stmt;
|
|
|
|
use PhpParser\Node;
|
|
|
|
class Property extends Node\Stmt
|
|
{
|
|
/** @var int Modifiers */
|
|
public $flags;
|
|
/** @var PropertyProperty[] Properties */
|
|
public $props;
|
|
|
|
/**
|
|
* Constructs a class property list node.
|
|
*
|
|
* @param int $flags Modifiers
|
|
* @param PropertyProperty[] $props Properties
|
|
* @param array $attributes Additional attributes
|
|
*/
|
|
public function __construct(int $flags, array $props, array $attributes = []) {
|
|
parent::__construct($attributes);
|
|
$this->flags = $flags;
|
|
$this->props = $props;
|
|
}
|
|
|
|
public function getSubNodeNames() : array {
|
|
return ['flags', 'props'];
|
|
}
|
|
|
|
/**
|
|
* Whether the property is explicitly or implicitly public.
|
|
*
|
|
* @return bool
|
|
*/
|
|
public function isPublic() : bool {
|
|
return ($this->flags & Class_::MODIFIER_PUBLIC) !== 0
|
|
|| ($this->flags & Class_::VISIBILITY_MODIFIER_MASK) === 0;
|
|
}
|
|
|
|
/**
|
|
* Whether the property is protected.
|
|
*
|
|
* @return bool
|
|
*/
|
|
public function isProtected() : bool {
|
|
return (bool) ($this->flags & Class_::MODIFIER_PROTECTED);
|
|
}
|
|
|
|
/**
|
|
* Whether the property is private.
|
|
*
|
|
* @return bool
|
|
*/
|
|
public function isPrivate() : bool {
|
|
return (bool) ($this->flags & Class_::MODIFIER_PRIVATE);
|
|
}
|
|
|
|
/**
|
|
* Whether the property is static.
|
|
*
|
|
* @return bool
|
|
*/
|
|
public function isStatic() : bool {
|
|
return (bool) ($this->flags & Class_::MODIFIER_STATIC);
|
|
}
|
|
|
|
function getType() : string {
|
|
return 'Stmt_Property';
|
|
}
|
|
}
|