$parts, ), $line, $docComment ); } /** * Gets the first part of the name, i.e. everything before the first namespace separator. * * @return string First part of the name */ public function getFirst() { return $this->parts[0]; } /** * Gets the last part of the name, i.e. everything after the last namespace separator. * * @return string Last part of the name */ public function getLast() { return $this->parts[count($this->parts) - 1]; } /** * Returns a string representation of the name by imploding the namespace parts with a separator. * * @param string $separator The separator to use (defaults to the namespace separator \) * * @return string String representation */ public function toString($separator = '\\') { return implode($separator, $this->parts); } /** * Returns a string representation of the name by imploding the namespace parts with the * namespace separator. * * @return string String representation */ public function __toString() { return implode('\\', $this->parts); } /** * Sets the whole name. * * @param string|array|self $name The name to set the whole name to */ public function set($name) { $this->parts = $this->prepareName($name); } /** * Prepends a name to this name. * * @param string|array|self $name Name to prepend */ public function prepend($name) { $this->parts = array_merge($this->prepareName($name), $this->parts); } /** * Appends a name to this name. * * @param string|array|self $name Name to append */ public function append($name) { $this->parts = array_merge($this->prepareName($name), $name->parts); } /** * Sets the first part of the name. * * @param string|array|self $name The name to set the first part to */ public function setFirst($name) { $this->parts = array_merge($this->prepareName($name), array_slice($this->parts, 1)); } /** * Sets the last part of the name. * * @param string|array|self $name The name to set the last part to */ public function setLast($name) { $this->parts = array_merge($this->prepareName($name), array_slice($this->parts, 0, -1)); } /** * Prepares a (string, array or Name node) name for use in name changing methods by converting * it to an array. * * @param string|array|self $name Name to prepare * * @return array Prepared name */ protected function prepareName($name) { if (is_string($name)) { return explode('\\', $name); } elseif ($name instanceof self) { return $name->parts; } elseif (!is_array($name)) { throw new InvalidArgumentException( 'When changing a name you need to pass either a string, an array or a Name node' ); } } }