mirror of
https://github.com/phabelio/PHP-Parser.git
synced 2024-12-04 10:28:18 +01:00
caa5c0cc76
Nearly all special errors are now handled gracefully, i.e. the parser will be able to continue after encountering them. In some cases the associated error range has been improved using the new end attribute stack. To achieve this the error handling code has been moved out of the node constructors and into special methods in the parser.
96 lines
3.0 KiB
PHP
96 lines
3.0 KiB
PHP
<?php
|
|
|
|
namespace PhpParser\Node\Stmt;
|
|
|
|
use PhpParser\Node;
|
|
use PhpParser\Node\FunctionLike;
|
|
use PhpParser\Error;
|
|
|
|
class ClassMethod extends Node\Stmt implements FunctionLike
|
|
{
|
|
/** @var int Flags */
|
|
public $flags;
|
|
/** @var bool Whether to return by reference */
|
|
public $byRef;
|
|
/** @var string Name */
|
|
public $name;
|
|
/** @var Node\Param[] Parameters */
|
|
public $params;
|
|
/** @var null|string|Node\Name Return type */
|
|
public $returnType;
|
|
/** @var Node[] Statements */
|
|
public $stmts;
|
|
|
|
/** @deprecated Use $flags instead */
|
|
public $type;
|
|
|
|
/**
|
|
* Constructs a class method node.
|
|
*
|
|
* @param string $name Name
|
|
* @param array $subNodes Array of the following optional subnodes:
|
|
* 'flags => MODIFIER_PUBLIC: Flags
|
|
* 'byRef' => false : Whether to return by reference
|
|
* 'params' => array() : Parameters
|
|
* 'returnType' => null : Return type
|
|
* 'stmts' => array() : Statements
|
|
* @param array $attributes Additional attributes
|
|
*/
|
|
public function __construct($name, array $subNodes = array(), array $attributes = array()) {
|
|
parent::__construct($attributes);
|
|
$this->flags = isset($subNodes['flags']) ? $subNodes['flags']
|
|
: (isset($subNodes['type']) ? $subNodes['type'] : 0);
|
|
$this->type = $this->flags;
|
|
$this->byRef = isset($subNodes['byRef']) ? $subNodes['byRef'] : false;
|
|
$this->name = $name;
|
|
$this->params = isset($subNodes['params']) ? $subNodes['params'] : array();
|
|
$this->returnType = isset($subNodes['returnType']) ? $subNodes['returnType'] : null;
|
|
$this->stmts = array_key_exists('stmts', $subNodes) ? $subNodes['stmts'] : array();
|
|
}
|
|
|
|
public function getSubNodeNames() {
|
|
return array('flags', 'byRef', 'name', 'params', 'returnType', 'stmts');
|
|
}
|
|
|
|
public function returnsByRef() {
|
|
return $this->byRef;
|
|
}
|
|
|
|
public function getParams() {
|
|
return $this->params;
|
|
}
|
|
|
|
public function getReturnType() {
|
|
return $this->returnType;
|
|
}
|
|
|
|
public function getStmts() {
|
|
return $this->stmts;
|
|
}
|
|
|
|
public function isPublic() {
|
|
return ($this->flags & Class_::MODIFIER_PUBLIC) !== 0
|
|
|| ($this->flags & Class_::VISIBILITY_MODIFER_MASK) === 0;
|
|
}
|
|
|
|
public function isProtected() {
|
|
return (bool) ($this->flags & Class_::MODIFIER_PROTECTED);
|
|
}
|
|
|
|
public function isPrivate() {
|
|
return (bool) ($this->flags & Class_::MODIFIER_PRIVATE);
|
|
}
|
|
|
|
public function isAbstract() {
|
|
return (bool) ($this->flags & Class_::MODIFIER_ABSTRACT);
|
|
}
|
|
|
|
public function isFinal() {
|
|
return (bool) ($this->flags & Class_::MODIFIER_FINAL);
|
|
}
|
|
|
|
public function isStatic() {
|
|
return (bool) ($this->flags & Class_::MODIFIER_STATIC);
|
|
}
|
|
}
|