Allow getting type from define() node (#363)
* Allow getting type from define() node - fixes #364 * Add test case for DefinitionResolverpull/354/merge v4.4.1
parent
b1cc7bf6b0
commit
08cf1a3fd7
|
@ -725,6 +725,19 @@ class DefinitionResolver
|
|||
*/
|
||||
public function getTypeFromNode(Node $node)
|
||||
{
|
||||
if (
|
||||
$node instanceof Node\Expr\FuncCall
|
||||
&& $node->name instanceof Node\Name
|
||||
&& strtolower((string)$node->name) === 'define'
|
||||
&& isset($node->args[0])
|
||||
&& $node->args[0]->value instanceof Node\Scalar\String_
|
||||
&& isset($node->args[1])
|
||||
) {
|
||||
// constants with define() like
|
||||
// define('TEST_DEFINE_CONSTANT', false);
|
||||
return $this->resolveExpressionNodeToType($node->args[1]->value);
|
||||
}
|
||||
|
||||
if ($node instanceof Node\Param) {
|
||||
// Parameters
|
||||
$docBlock = $node->getAttribute('parentNode')->getAttribute('docBlock');
|
||||
|
@ -882,11 +895,16 @@ class DefinitionResolver
|
|||
}
|
||||
return (string)$class->namespacedName . '::' . $node->name;
|
||||
}
|
||||
} else if ($node instanceof Node\Expr\FuncCall && $node->name instanceof Node\Name && strtolower((string)$node->name) === 'define') {
|
||||
if (!isset($node->args[0]) || !($node->args[0]->value instanceof Node\Scalar\String_)) {
|
||||
return null;
|
||||
}
|
||||
} else if (
|
||||
$node instanceof Node\Expr\FuncCall
|
||||
&& $node->name instanceof Node\Name
|
||||
&& strtolower((string)$node->name) === 'define'
|
||||
&& isset($node->args[0])
|
||||
&& $node->args[0]->value instanceof Node\Scalar\String_
|
||||
&& isset($node->args[1])
|
||||
) {
|
||||
return (string)$node->args[0]->value->value;
|
||||
}
|
||||
return null;
|
||||
}
|
||||
}
|
||||
|
|
|
@ -57,6 +57,7 @@ class SymbolInformation
|
|||
&& strtolower((string)$node->name) === 'define'
|
||||
&& isset($node->args[0])
|
||||
&& $node->args[0]->value instanceof Node\Scalar\String_
|
||||
&& isset($node->args[1])
|
||||
) {
|
||||
// constants with define() like
|
||||
// define('TEST_DEFINE_CONSTANT', false);
|
||||
|
|
|
@ -0,0 +1,64 @@
|
|||
<?php
|
||||
declare(strict_types = 1);
|
||||
|
||||
namespace LanguageServer\Tests;
|
||||
|
||||
use PHPUnit\Framework\TestCase;
|
||||
use LanguageServer\Index\Index;
|
||||
use LanguageServer\{DefinitionResolver, Parser};
|
||||
|
||||
class DefinitionResolverTest extends TestCase
|
||||
{
|
||||
public function testCreateDefinitionFromNode()
|
||||
{
|
||||
$parser = new Parser;
|
||||
$stmts = $parser->parse("<?php\ndefine('TEST_DEFINE', true);");
|
||||
$stmts[0]->setAttribute('ownerDocument', new MockPhpDocument);
|
||||
|
||||
$index = new Index;
|
||||
$definitionResolver = new DefinitionResolver($index);
|
||||
$def = $definitionResolver->createDefinitionFromNode($stmts[0], '\TEST_DEFINE');
|
||||
|
||||
$this->assertInstanceOf(\phpDocumentor\Reflection\Types\Boolean::class, $def->type);
|
||||
}
|
||||
|
||||
public function testGetTypeFromNode()
|
||||
{
|
||||
$parser = new Parser;
|
||||
$stmts = $parser->parse("<?php\ndefine('TEST_DEFINE', true);");
|
||||
$stmts[0]->setAttribute('ownerDocument', new MockPhpDocument);
|
||||
|
||||
$index = new Index;
|
||||
$definitionResolver = new DefinitionResolver($index);
|
||||
$type = $definitionResolver->getTypeFromNode($stmts[0]);
|
||||
|
||||
$this->assertInstanceOf(\phpDocumentor\Reflection\Types\Boolean::class, $type);
|
||||
}
|
||||
|
||||
public function testGetDefinedFqnForIncompleteDefine()
|
||||
{
|
||||
// define('XXX') (only one argument) must not introduce a new symbol
|
||||
$parser = new Parser;
|
||||
$stmts = $parser->parse("<?php\ndefine('TEST_DEFINE');");
|
||||
$stmts[0]->setAttribute('ownerDocument', new MockPhpDocument);
|
||||
|
||||
$index = new Index;
|
||||
$definitionResolver = new DefinitionResolver($index);
|
||||
$fqn = $definitionResolver->getDefinedFqn($stmts[0]);
|
||||
|
||||
$this->assertNull($fqn);
|
||||
}
|
||||
|
||||
public function testGetDefinedFqnForDefine()
|
||||
{
|
||||
$parser = new Parser;
|
||||
$stmts = $parser->parse("<?php\ndefine('TEST_DEFINE', true);");
|
||||
$stmts[0]->setAttribute('ownerDocument', new MockPhpDocument);
|
||||
|
||||
$index = new Index;
|
||||
$definitionResolver = new DefinitionResolver($index);
|
||||
$fqn = $definitionResolver->getDefinedFqn($stmts[0]);
|
||||
|
||||
$this->assertEquals('TEST_DEFINE', $fqn);
|
||||
}
|
||||
}
|
|
@ -0,0 +1,20 @@
|
|||
<?php
|
||||
declare(strict_types = 1);
|
||||
|
||||
namespace LanguageServer\Tests;
|
||||
|
||||
/**
|
||||
* A fake document for tests
|
||||
*/
|
||||
class MockPhpDocument
|
||||
{
|
||||
/**
|
||||
* Returns fake uri
|
||||
*
|
||||
* @return string
|
||||
*/
|
||||
public function getUri()
|
||||
{
|
||||
return 'file:///whatever';
|
||||
}
|
||||
}
|
Loading…
Reference in New Issue