X-Git-Url: http://www.aleph1.co.uk/gitweb/?a=blobdiff_plain;ds=sidebyside;f=vendor%2Fpsy%2Fpsysh%2Fsrc%2FPsy%2FCodeCleaner%2FNamespaceAwarePass.php;fp=vendor%2Fpsy%2Fpsysh%2Fsrc%2FPsy%2FCodeCleaner%2FNamespaceAwarePass.php;h=5982e4f3a4948f2505df8c9a81251231c19061a4;hb=a2bd1bf0c2c1f1a17d188f4dc0726a45494cefae;hp=0000000000000000000000000000000000000000;hpb=57c063afa3f66b07c4bbddc2d6129a96d90f0aad;p=yaffs-website diff --git a/vendor/psy/psysh/src/Psy/CodeCleaner/NamespaceAwarePass.php b/vendor/psy/psysh/src/Psy/CodeCleaner/NamespaceAwarePass.php new file mode 100644 index 000000000..5982e4f3a --- /dev/null +++ b/vendor/psy/psysh/src/Psy/CodeCleaner/NamespaceAwarePass.php @@ -0,0 +1,71 @@ +namespace = array(); + $this->currentScope = array(); + } + + /** + * TODO: should this be final? Extending classes should be sure to either use + * leaveNode or call parent::enterNode() when overloading. + * + * @param Node $node + */ + public function enterNode(Node $node) + { + if ($node instanceof NamespaceStmt) { + $this->namespace = isset($node->name) ? $node->name->parts : array(); + } + } + + /** + * Get a fully-qualified name (class, function, interface, etc). + * + * @param mixed $name + * + * @return string + */ + protected function getFullyQualifiedName($name) + { + if ($name instanceof FullyQualifiedName) { + return implode('\\', $name->parts); + } elseif ($name instanceof Name) { + $name = $name->parts; + } elseif (!is_array($name)) { + $name = array($name); + } + + return implode('\\', array_merge($this->namespace, $name)); + } +}