mirror of
https://github.com/nikic/PHP-Parser.git
synced 2025-01-17 15:18:17 +01:00
502b090900
Types omitted in two places where we violate them currently: Namespace_::$stmts can be null during parsing, and Enum_::$scalarType can be a complex type for invalid programs.
51 lines
1.2 KiB
PHP
51 lines
1.2 KiB
PHP
<?php declare(strict_types=1);
|
|
|
|
namespace PhpParser\Builder;
|
|
|
|
use PhpParser;
|
|
use PhpParser\BuilderHelpers;
|
|
|
|
abstract class Declaration implements PhpParser\Builder {
|
|
/** @var array<string, mixed> */
|
|
protected array $attributes = [];
|
|
|
|
/**
|
|
* Adds a statement.
|
|
*
|
|
* @param PhpParser\Node\Stmt|PhpParser\Builder $stmt The statement to add
|
|
*
|
|
* @return $this The builder instance (for fluid interface)
|
|
*/
|
|
abstract public function addStmt($stmt);
|
|
|
|
/**
|
|
* Adds multiple statements.
|
|
*
|
|
* @param (PhpParser\Node\Stmt|PhpParser\Builder)[] $stmts The statements to add
|
|
*
|
|
* @return $this The builder instance (for fluid interface)
|
|
*/
|
|
public function addStmts(array $stmts) {
|
|
foreach ($stmts as $stmt) {
|
|
$this->addStmt($stmt);
|
|
}
|
|
|
|
return $this;
|
|
}
|
|
|
|
/**
|
|
* Sets doc comment for the declaration.
|
|
*
|
|
* @param PhpParser\Comment\Doc|string $docComment Doc comment to set
|
|
*
|
|
* @return $this The builder instance (for fluid interface)
|
|
*/
|
|
public function setDocComment($docComment) {
|
|
$this->attributes['comments'] = [
|
|
BuilderHelpers::normalizeDocComment($docComment)
|
|
];
|
|
|
|
return $this;
|
|
}
|
|
}
|