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.
47 lines
1.1 KiB
PHP
47 lines
1.1 KiB
PHP
<?php declare(strict_types=1);
|
|
|
|
namespace PhpParser\Builder;
|
|
|
|
use PhpParser;
|
|
use PhpParser\BuilderHelpers;
|
|
use PhpParser\Node;
|
|
use PhpParser\Node\Stmt;
|
|
|
|
class Namespace_ extends Declaration {
|
|
/** @var Node\Name|null */
|
|
private ?Node\Name $name;
|
|
/** @var Stmt[] */
|
|
private array $stmts = [];
|
|
|
|
/**
|
|
* Creates a namespace builder.
|
|
*
|
|
* @param Node\Name|string|null $name Name of the namespace
|
|
*/
|
|
public function __construct($name) {
|
|
$this->name = null !== $name ? BuilderHelpers::normalizeName($name) : null;
|
|
}
|
|
|
|
/**
|
|
* Adds a statement.
|
|
*
|
|
* @param Node|PhpParser\Builder $stmt The statement to add
|
|
*
|
|
* @return $this The builder instance (for fluid interface)
|
|
*/
|
|
public function addStmt($stmt) {
|
|
$this->stmts[] = BuilderHelpers::normalizeStmt($stmt);
|
|
|
|
return $this;
|
|
}
|
|
|
|
/**
|
|
* Returns the built node.
|
|
*
|
|
* @return Stmt\Namespace_ The built node
|
|
*/
|
|
public function getNode(): Node {
|
|
return new Stmt\Namespace_($this->name, $this->stmts, $this->attributes);
|
|
}
|
|
}
|