1
0
Fork 0

Remove more PhpParser\Node references

pull/357/head
Rob Lourens 2017-05-19 14:40:38 -07:00
parent 442fc7ea02
commit b4e77f2e9c
7 changed files with 15 additions and 59 deletions

View File

@ -158,7 +158,6 @@ class CompletionProvider
$node->parent->memberName === $node)
) {
// Find variables, parameters and use statements in the scope
// If there was only a $ typed, $node will be instanceof Node\Error
$namePrefix = $node->getName() ?? '';
foreach ($this->suggestVariablesAtNode($node, $namePrefix) as $var) {
$item = new CompletionItem;
@ -334,9 +333,9 @@ class CompletionProvider
* and at each level walk all previous siblings and their children to search for definitions
* of that variable
*
* @param Node $node
* @param Tolerant\Node $node
* @param string $namePrefix Prefix to filter
* @return array <Node\Expr\Variable|Node\Param|Node\Expr\ClosureUse>
* @return array <Tolerant\Node\Expr\Variable|Tolerant\Node\Param|Tolerant\Node\Expr\ClosureUse>
*/
private function suggestVariablesAtNode(Tolerant\Node $node, string $namePrefix = ''): array
{
@ -394,7 +393,7 @@ class CompletionProvider
*
* @param Node $node
* @param string $namePrefix Prefix to filter
* @return Node\Expr\Variable[]
* @return Tolerant\Node\Expression\Variable[]
*/
private function findVariableDefinitionsInNode(Tolerant\Node $node, string $namePrefix = ''): array
{

View File

@ -472,8 +472,8 @@ class DefinitionResolver
/**
* Returns the assignment or parameter node where a variable was defined
*
* @param Node\Expr\Variable|Node\Expr\ClosureUse $var The variable access
* @return Node\Expr\Assign|Node\Expr\AssignOp|Node\Param|Node\Expr\ClosureUse|null
* @param Tolerant\Node\Expression\Variable | Tolerant\Node\Expression\ClosureUse $var The variable access
* @return Tolerant\Node\Expression\Assign | Tolerant\Node\Expression\AssignOp|Node\Param | Tolerant\Node\Expression\ClosureUse|null
*/
public function resolveVariableToNode($var)
{

View File

@ -7,24 +7,6 @@ use Microsoft\PhpParser as Tolerant;
class FqnUtilities
{
/**
* Returns the fully qualified name (FQN) that is defined by a node
* Returns null if the node does not declare any symbol that can be referenced by an FQN
*
* @param Node | Tolerant\Node $node
* @return string|null
*/
public static function getDefinedFqn($node)
{
if ($node instanceof Node) {
return DefinitionResolver::getDefinedFqn($node);
} elseif ($node instanceof Tolerant\Node) {
return DefinitionResolver::getDefinedFqn($node);
}
throw new \TypeError("Unspported Node class");
}
/**
* Returns all possible FQNs in a type
*

View File

@ -22,21 +22,17 @@ class Location
/**
* Returns the location of the node
*
* @param Node | Tolerant\Node $node
* @param Tolerant\Node $node
* @return self
*/
public static function fromNode($node)
{
if ($node instanceof Node) {
return new self($node->getAttribute('ownerDocument')->getUri(), Range::fromNode($node));
} else {
$range = Tolerant\PositionUtilities::getRangeFromPosition($node->getStart(), $node->getWidth(), $node->getFileContents());
return new self($node->getUri(), new Range(
new Position($range->start->line, $range->start->character),
new Position($range->end->line, $range->end->character)
));
}
}
public function __construct(string $uri = null, Range $range = null)
{

View File

@ -208,7 +208,7 @@ class TextDocument
}
} else {
// Definition with a global FQN
$fqn = FqnUtilities::getDefinedFqn($node);
$fqn = DefinitionResolver::getDefinedFqn($node);
// var_dump($fqn);
// Wait until indexing finished
if (!$this->index->isComplete()) {
@ -255,7 +255,7 @@ class TextDocument
return [];
}
// Handle definition nodes
$fqn = FqnUtilities::getDefinedFqn($node);
$fqn = DefinitionResolver::getDefinedFqn($node);
while (true) {
if ($fqn) {
$def = $this->index->getDefinition($fqn);
@ -296,7 +296,7 @@ class TextDocument
if ($node === null) {
return new Hover([]);
}
$definedFqn = FqnUtilities::getDefinedFqn($node);
$definedFqn = DefinitionResolver::getDefinedFqn($node);
while (true) {
if ($definedFqn) {
// Support hover for definitions

View File

@ -93,23 +93,6 @@ function waitForEvent(EmitterInterface $emitter, string $event): Promise
return $p;
}
/**
* Returns the closest node of a specific type
*
* @param Node $node
* @param string $type The node class name
* @return Node|null $type
*/
function getClosestNode(Node $node, string $type)
{
$n = $node;
while ($n = $n->getAttribute('parentNode')) {
if ($n instanceof $type) {
return $n;
}
}
}
/**
* Returns the part of $b that is not overlapped by $a
* Example:

View File

@ -44,12 +44,8 @@ class PhpDocumentTest extends TestCase
}
private function assertQualifiedName($node) {
if ($node instanceof Node) {
$this->assertInstanceOf(Node\Name\FullyQualified::class, $node);
} else {
$this->assertInstanceOf(Tolerant\Node\QualifiedName::class, $node);
}
}
public function testIsVendored()
{