Mercurial > hg > isophonics-drupal-site
diff vendor/nikic/php-parser/lib/PhpParser/Builder/Class_.php @ 0:4c8ae668cc8c
Initial import (non-working)
author | Chris Cannam |
---|---|
date | Wed, 29 Nov 2017 16:09:58 +0000 |
parents | |
children | 5fb285c0d0e3 |
line wrap: on
line diff
--- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/vendor/nikic/php-parser/lib/PhpParser/Builder/Class_.php Wed Nov 29 16:09:58 2017 +0000 @@ -0,0 +1,121 @@ +<?php + +namespace PhpParser\Builder; + +use PhpParser; +use PhpParser\Node\Name; +use PhpParser\Node\Stmt; + +class Class_ extends Declaration +{ + protected $name; + + protected $extends = null; + protected $implements = array(); + protected $flags = 0; + + protected $uses = array(); + protected $constants = array(); + protected $properties = array(); + protected $methods = array(); + + /** + * Creates a class builder. + * + * @param string $name Name of the class + */ + public function __construct($name) { + $this->name = $name; + } + + /** + * Extends a class. + * + * @param Name|string $class Name of class to extend + * + * @return $this The builder instance (for fluid interface) + */ + public function extend($class) { + $this->extends = $this->normalizeName($class); + + return $this; + } + + /** + * Implements one or more interfaces. + * + * @param Name|string ...$interfaces Names of interfaces to implement + * + * @return $this The builder instance (for fluid interface) + */ + public function implement() { + foreach (func_get_args() as $interface) { + $this->implements[] = $this->normalizeName($interface); + } + + return $this; + } + + /** + * Makes the class abstract. + * + * @return $this The builder instance (for fluid interface) + */ + public function makeAbstract() { + $this->setModifier(Stmt\Class_::MODIFIER_ABSTRACT); + + return $this; + } + + /** + * Makes the class final. + * + * @return $this The builder instance (for fluid interface) + */ + public function makeFinal() { + $this->setModifier(Stmt\Class_::MODIFIER_FINAL); + + return $this; + } + + /** + * 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); + + $targets = array( + 'Stmt_TraitUse' => &$this->uses, + 'Stmt_ClassConst' => &$this->constants, + 'Stmt_Property' => &$this->properties, + 'Stmt_ClassMethod' => &$this->methods, + ); + + $type = $stmt->getType(); + if (!isset($targets[$type])) { + throw new \LogicException(sprintf('Unexpected node of type "%s"', $type)); + } + + $targets[$type][] = $stmt; + + return $this; + } + + /** + * Returns the built class node. + * + * @return Stmt\Class_ The built class node + */ + public function getNode() { + return new Stmt\Class_($this->name, array( + 'flags' => $this->flags, + 'extends' => $this->extends, + 'implements' => $this->implements, + 'stmts' => array_merge($this->uses, $this->constants, $this->properties, $this->methods), + ), $this->attributes); + } +} \ No newline at end of file