public function testSetFirst() { $name = new PHPParser_Node_Name('foo'); $name->setFirst('bar'); $this->assertEquals('bar', $name->toString()); $name->setFirst('A\\B'); $this->assertEquals('A\\B', $name->toString()); $name->setFirst('C'); $this->assertEquals('C\\B', $name->toString()); $name->setFirst('D\\E'); $this->assertEquals('D\\E\\B', $name->toString()); }
protected function resolveOtherName(PHPParser_Node_Name $name) { // fully qualified names are already resolved and we can't do anything about unqualified // ones at compiler-time if ($name->isFullyQualified() || $name->isUnqualified()) { return $name; } // resolve aliases for qualified names if ($name->isQualified() && isset($this->aliases[$name->getFirst()])) { $name->setFirst($this->aliases[$name->getFirst()]); // prepend namespace for relative names } elseif (null !== $this->namespace) { $name->prepend($this->namespace); } return new PHPParser_Node_Name_FullyQualified($name->parts, $name->getAttributes()); }
protected function rewriteStaticOtherLookup(PHPParser_Node_Name &$name, $type) { // leave the fully qualified ones alone if (!$name->isFullyQualified()) { // resolve aliases for qualified names if ($name->isQualified() && isset($this->aliases[$name->getFirst()])) { $name->setFirst($this->aliases[$name->getFirst()]); // prepend current namespace for qualified and relative names (and unqualified ones if // the function/constant is not an internal one defined globally. This isn't exactly // PHP's behavior, but proper resolution would require runtime code insertion.) } elseif (null !== $this->namespace && (!$name->isUnqualified() || !isset($this->internals[$type][strtolower($name)])) ) { $name->prepend($this->namespace); } } // finally just replace the namespace separators with underscores $name->set($name->toString('__')); $name->type = PHPParser_Node_Name::NORMAL; }