getAttribute('kind'); if ($kind === Namespace_::KIND_SEMICOLON) { // Save the current namespace for open namespaces $this->setNamespace($last->name); } else { // Clear the current namespace after a braced namespace $this->setNamespace(null); } return $nodes; } // Wrap in current namespace if one is set $currentNamespace = $this->getCurrentNamespace(); if (!$currentNamespace) { return $nodes; } // Mark as re-injected so UseStatementPass knows it can re-inject use statements return [new Namespace_($currentNamespace, $nodes, ['psyshReinjected' => true])]; } /** * Get the current namespace as a Name node. * * This is more complicated than it needs to be, because we're not storing namespace as a Name. * * @return Name|null */ private function getCurrentNamespace(): ?Name { $namespace = $this->cleaner->getNamespace(); return $namespace ? new Name($namespace) : null; } /** * Update the namespace in CodeCleaner and clear aliases. * * @param Name|null $namespace */ private function setNamespace(?Name $namespace) { $this->cleaner->setNamespace($namespace); // Always clear aliases when changing namespace $this->cleaner->setAliasesForNamespace($namespace, []); } /** * @deprecated unused and will be removed in a future version */ protected function getParts(Name $name): array { return \method_exists($name, 'getParts') ? $name->getParts() : $name->parts; } }