diff --git a/src/Naneau/Obfuscator/Node/Visitor/ScrambleUse.php b/src/Naneau/Obfuscator/Node/Visitor/ScrambleUse.php index 0481ef4..b95bd64 100644 --- a/src/Naneau/Obfuscator/Node/Visitor/ScrambleUse.php +++ b/src/Naneau/Obfuscator/Node/Visitor/ScrambleUse.php @@ -133,6 +133,10 @@ public function enterNode(Node $node) if ($this->isRenamed($name)) { $node->type = $this->getNewName($name); return $node; + } elseif ($this->isRenamed($node->type->getFirst())) { + reset($node->type->parts); + $node->type->parts[key($node->type->parts)] = $this->getNewName($node->type->getFirst()); + return $node; } } diff --git a/tests/before/Namespaces.php b/tests/before/Namespaces.php index 8e025f3..13248d0 100644 --- a/tests/before/Namespaces.php +++ b/tests/before/Namespaces.php @@ -35,4 +35,7 @@ public function __construct() { class classE extends namespaceDAlias\classD implements namespaceDAlias\interfaceA { + public function method(namespaceDAlias\classD $objectD) { + + } } \ No newline at end of file diff --git a/tests/expected/Namespaces.php b/tests/expected/Namespaces.php index 91552d8..dd690db 100644 --- a/tests/expected/Namespaces.php +++ b/tests/expected/Namespaces.php @@ -1,2 +1,2 @@ spa26210 = new spf0f507(); $this->sp2e1034 = new sp63627e\classD(); } } class classE extends sp63627e\classD implements sp63627e\interfaceA { } \ No newline at end of file +namespace namespaceA; class classA { } namespace namespaceC\namespaceD; class classD { } interface interfaceA { } namespace namespaceB; use namespaceA\classA as spf0f507; use namespaceC\namespaceD as sp63627e; class classB { private $spa26210; private $sp2e1034; public function __construct() { $this->spa26210 = new spf0f507(); $this->sp2e1034 = new sp63627e\classD(); } } class classE extends sp63627e\classD implements sp63627e\interfaceA { public function method(sp63627e\classD $spc1ac55) { } } \ No newline at end of file