2017-08-18 22:57:27 +02:00
|
|
|
<?php declare(strict_types=1);
|
2014-02-06 14:44:16 +01:00
|
|
|
|
|
|
|
namespace PhpParser\Node\Stmt;
|
|
|
|
|
|
|
|
use PhpParser\Node;
|
2019-01-05 12:06:18 +01:00
|
|
|
use PhpParser\Node\Identifier;
|
|
|
|
use PhpParser\Node\Name;
|
|
|
|
use PhpParser\Node\NullableType;
|
2019-10-25 21:35:43 +02:00
|
|
|
use PhpParser\Node\UnionType;
|
2014-02-06 14:44:16 +01:00
|
|
|
|
|
|
|
class Property extends Node\Stmt
|
|
|
|
{
|
2015-02-28 18:44:28 +01:00
|
|
|
/** @var int Modifiers */
|
2016-07-25 13:33:19 +02:00
|
|
|
public $flags;
|
2015-02-28 18:44:28 +01:00
|
|
|
/** @var PropertyProperty[] Properties */
|
|
|
|
public $props;
|
2019-10-25 21:35:43 +02:00
|
|
|
/** @var null|Identifier|Name|NullableType|UnionType Type declaration */
|
2019-01-05 12:06:18 +01:00
|
|
|
public $type;
|
2020-09-13 21:01:17 +02:00
|
|
|
/** @var Node\AttributeGroup[] PHP attribute groups */
|
|
|
|
public $attrGroups;
|
2015-02-28 18:44:28 +01:00
|
|
|
|
2014-02-06 14:44:16 +01:00
|
|
|
/**
|
|
|
|
* Constructs a class property list node.
|
|
|
|
*
|
2019-10-25 21:35:43 +02:00
|
|
|
* @param int $flags Modifiers
|
|
|
|
* @param PropertyProperty[] $props Properties
|
|
|
|
* @param array $attributes Additional attributes
|
|
|
|
* @param null|string|Identifier|Name|NullableType|UnionType $type Type declaration
|
2020-09-13 21:01:17 +02:00
|
|
|
* @param Node\AttributeGroup[] $attrGroups PHP attribute groups
|
2014-02-06 14:44:16 +01:00
|
|
|
*/
|
2020-09-13 21:01:17 +02:00
|
|
|
public function __construct(int $flags, array $props, array $attributes = [], $type = null, array $attrGroups = []) {
|
2019-05-12 14:55:21 +02:00
|
|
|
$this->attributes = $attributes;
|
2016-07-25 13:33:19 +02:00
|
|
|
$this->flags = $flags;
|
2015-02-28 18:44:28 +01:00
|
|
|
$this->props = $props;
|
2019-01-05 12:06:18 +01:00
|
|
|
$this->type = \is_string($type) ? new Identifier($type) : $type;
|
2020-09-13 21:01:17 +02:00
|
|
|
$this->attrGroups = $attrGroups;
|
2015-02-28 18:44:28 +01:00
|
|
|
}
|
|
|
|
|
2017-04-28 21:40:59 +02:00
|
|
|
public function getSubNodeNames() : array {
|
2020-09-13 21:01:17 +02:00
|
|
|
return ['attrGroups', 'flags', 'type', 'props'];
|
2014-02-06 14:44:16 +01:00
|
|
|
}
|
|
|
|
|
2017-01-24 08:38:55 +01:00
|
|
|
/**
|
2017-01-26 00:16:54 +01:00
|
|
|
* Whether the property is explicitly or implicitly public.
|
|
|
|
*
|
2017-01-24 08:38:55 +01:00
|
|
|
* @return bool
|
|
|
|
*/
|
2017-04-28 21:40:59 +02:00
|
|
|
public function isPublic() : bool {
|
2016-07-25 13:33:19 +02:00
|
|
|
return ($this->flags & Class_::MODIFIER_PUBLIC) !== 0
|
2017-04-19 11:20:05 +02:00
|
|
|
|| ($this->flags & Class_::VISIBILITY_MODIFIER_MASK) === 0;
|
2014-02-06 14:44:16 +01:00
|
|
|
}
|
|
|
|
|
2017-01-24 08:38:55 +01:00
|
|
|
/**
|
2017-01-26 00:16:54 +01:00
|
|
|
* Whether the property is protected.
|
|
|
|
*
|
2017-01-24 08:38:55 +01:00
|
|
|
* @return bool
|
|
|
|
*/
|
2017-04-28 21:40:59 +02:00
|
|
|
public function isProtected() : bool {
|
2016-07-25 13:33:19 +02:00
|
|
|
return (bool) ($this->flags & Class_::MODIFIER_PROTECTED);
|
2014-02-06 14:44:16 +01:00
|
|
|
}
|
|
|
|
|
2017-01-24 08:38:55 +01:00
|
|
|
/**
|
2017-01-26 00:16:54 +01:00
|
|
|
* Whether the property is private.
|
|
|
|
*
|
2017-01-24 08:38:55 +01:00
|
|
|
* @return bool
|
|
|
|
*/
|
2017-04-28 21:40:59 +02:00
|
|
|
public function isPrivate() : bool {
|
2016-07-25 13:33:19 +02:00
|
|
|
return (bool) ($this->flags & Class_::MODIFIER_PRIVATE);
|
2014-02-06 14:44:16 +01:00
|
|
|
}
|
|
|
|
|
2017-01-24 08:38:55 +01:00
|
|
|
/**
|
2017-01-26 00:16:54 +01:00
|
|
|
* Whether the property is static.
|
|
|
|
*
|
2017-01-24 08:38:55 +01:00
|
|
|
* @return bool
|
|
|
|
*/
|
2017-04-28 21:40:59 +02:00
|
|
|
public function isStatic() : bool {
|
2016-07-25 13:33:19 +02:00
|
|
|
return (bool) ($this->flags & Class_::MODIFIER_STATIC);
|
2014-02-06 14:44:16 +01:00
|
|
|
}
|
2019-01-05 12:06:18 +01:00
|
|
|
|
2021-07-21 12:43:29 +02:00
|
|
|
/**
|
|
|
|
* Whether the property is readonly.
|
|
|
|
*
|
|
|
|
* @return bool
|
|
|
|
*/
|
|
|
|
public function isReadonly() : bool {
|
|
|
|
return (bool) ($this->flags & Class_::MODIFIER_READONLY);
|
|
|
|
}
|
|
|
|
|
2018-01-10 18:57:48 +01:00
|
|
|
public function getType() : string {
|
2017-11-12 21:25:57 +01:00
|
|
|
return 'Stmt_Property';
|
|
|
|
}
|
2014-11-13 20:18:49 +01:00
|
|
|
}
|