mirror of
https://github.com/nikic/PHP-Parser.git
synced 2025-01-17 23:28:15 +01:00
56 lines
1.3 KiB
PHP
56 lines
1.3 KiB
PHP
<?php
|
|
|
|
namespace PhpParser\Builder;
|
|
|
|
use PhpParser;
|
|
use PhpParser\Node\Name;
|
|
use PhpParser\Node\Stmt;
|
|
|
|
class Trait_ extends Declaration
|
|
{
|
|
protected $name;
|
|
protected $properties = array();
|
|
protected $methods = array();
|
|
|
|
/**
|
|
* Creates an interface builder.
|
|
*
|
|
* @param string $name Name of the interface
|
|
*/
|
|
public function __construct($name) {
|
|
$this->name = $name;
|
|
}
|
|
|
|
/**
|
|
* Adds a statement.
|
|
*
|
|
* @param Stmt|PhpParser\Builder $stmt The statement to add
|
|
*
|
|
* @return $this The builder instance (for fluid interface)
|
|
*/
|
|
public function addStmt($stmt) {
|
|
$stmt = $this->normalizeNode($stmt);
|
|
|
|
if ($stmt instanceof Stmt\Property) {
|
|
$this->properties[] = $stmt;
|
|
} else if ($stmt instanceof Stmt\ClassMethod) {
|
|
$this->methods[] = $stmt;
|
|
} else {
|
|
throw new \LogicException(sprintf('Unexpected node of type "%s"', $stmt->getType()));
|
|
}
|
|
|
|
return $this;
|
|
}
|
|
|
|
/**
|
|
* Returns the built trait node.
|
|
*
|
|
* @return Stmt\Trait_ The built interface node
|
|
*/
|
|
public function getNode() {
|
|
return new Stmt\Trait_(
|
|
$this->name, array_merge($this->properties, $this->methods), $this->attributes
|
|
);
|
|
}
|
|
}
|