remove FUNCTION_NODE attribute

This commit is contained in:
TomasVotruba 2021-03-17 23:20:49 +01:00
parent de02a85e3f
commit 3746f24cf4
13 changed files with 84 additions and 70 deletions

View File

@ -41,7 +41,6 @@ expectedArguments(
\Rector\NodeTypeResolver\Node\AttributeKey::ORIGINAL_NAME, \Rector\NodeTypeResolver\Node\AttributeKey::ORIGINAL_NAME,
\Rector\NodeTypeResolver\Node\AttributeKey::COMMENTS, \Rector\NodeTypeResolver\Node\AttributeKey::COMMENTS,
\Rector\NodeTypeResolver\Node\AttributeKey::VIRTUAL_NODE, \Rector\NodeTypeResolver\Node\AttributeKey::VIRTUAL_NODE,
\Rector\NodeTypeResolver\Node\AttributeKey::CLOSURE_NODE,
\Rector\NodeTypeResolver\Node\AttributeKey::PARAMETER_POSITION, \Rector\NodeTypeResolver\Node\AttributeKey::PARAMETER_POSITION,
\Rector\NodeTypeResolver\Node\AttributeKey::ARGUMENT_POSITION, \Rector\NodeTypeResolver\Node\AttributeKey::ARGUMENT_POSITION,
\Rector\NodeTypeResolver\Node\AttributeKey::IS_FIRST_LEVEL_STATEMENT, \Rector\NodeTypeResolver\Node\AttributeKey::IS_FIRST_LEVEL_STATEMENT,
@ -72,7 +71,6 @@ expectedArguments(
\Rector\NodeTypeResolver\Node\AttributeKey::ORIGINAL_NAME, \Rector\NodeTypeResolver\Node\AttributeKey::ORIGINAL_NAME,
\Rector\NodeTypeResolver\Node\AttributeKey::COMMENTS, \Rector\NodeTypeResolver\Node\AttributeKey::COMMENTS,
\Rector\NodeTypeResolver\Node\AttributeKey::VIRTUAL_NODE, \Rector\NodeTypeResolver\Node\AttributeKey::VIRTUAL_NODE,
\Rector\NodeTypeResolver\Node\AttributeKey::CLOSURE_NODE,
\Rector\NodeTypeResolver\Node\AttributeKey::PARAMETER_POSITION, \Rector\NodeTypeResolver\Node\AttributeKey::PARAMETER_POSITION,
\Rector\NodeTypeResolver\Node\AttributeKey::ARGUMENT_POSITION, \Rector\NodeTypeResolver\Node\AttributeKey::ARGUMENT_POSITION,
\Rector\NodeTypeResolver\Node\AttributeKey::IS_FIRST_LEVEL_STATEMENT, \Rector\NodeTypeResolver\Node\AttributeKey::IS_FIRST_LEVEL_STATEMENT,

View File

@ -11,7 +11,6 @@ use PhpParser\Node\Stmt\ClassMethod;
use PhpParser\Node\Stmt\Function_; use PhpParser\Node\Stmt\Function_;
use PhpParser\Node\Stmt\Namespace_; use PhpParser\Node\Stmt\Namespace_;
use Rector\Core\PhpParser\Node\BetterNodeFinder; use Rector\Core\PhpParser\Node\BetterNodeFinder;
use Rector\NodeTypeResolver\Node\AttributeKey;
final class ParentScopeFinder final class ParentScopeFinder
{ {
@ -30,10 +29,12 @@ final class ParentScopeFinder
*/ */
public function find(Node $node): ?Node public function find(Node $node): ?Node
{ {
return $node->getAttribute(AttributeKey::CLOSURE_NODE) ?? return $this->betterNodeFinder->findParentTypes($node, [
$node->getAttribute(AttributeKey::FUNCTION_NODE) ?? Closure::class,
$node->getAttribute(AttributeKey::METHOD_NODE) ?? Function_::class,
$node->getAttribute(AttributeKey::CLASS_NODE) ?? ClassMethod::class,
$this->betterNodeFinder->findParentType($node, Namespace_::class); Class_::class,
Namespace_::class,
]);
} }
} }

View File

@ -4,7 +4,6 @@ declare(strict_types=1);
namespace Rector\NodeTypeResolver\Node; namespace Rector\NodeTypeResolver\Node;
use PhpParser\Node\Expr\Closure;
use PhpParser\Node\Stmt\ClassLike; use PhpParser\Node\Stmt\ClassLike;
use PHPStan\Analyser\Scope; use PHPStan\Analyser\Scope;
use Rector\BetterPhpDocParser\PhpDocInfo\PhpDocInfo; use Rector\BetterPhpDocParser\PhpDocInfo\PhpDocInfo;
@ -47,11 +46,6 @@ final class AttributeKey
*/ */
public const METHOD_NODE = 'methodNode'; public const METHOD_NODE = 'methodNode';
/**
* @var string
*/
public const FUNCTION_NODE = 'functionNode';
/** /**
* Internal php-parser name. * Internal php-parser name.
* Do not change this even if you want! * Do not change this even if you want!
@ -170,11 +164,6 @@ final class AttributeKey
*/ */
public const DO_NOT_CHANGE = 'do_not_change'; public const DO_NOT_CHANGE = 'do_not_change';
/**
* @var string
*/
public const CLOSURE_NODE = Closure::class;
/** /**
* @var string * @var string
*/ */

View File

@ -74,8 +74,6 @@ final class FunctionMethodAndClassNodeVisitor extends NodeVisitorAbstract
{ {
$this->processClass($node); $this->processClass($node);
$this->processMethod($node); $this->processMethod($node);
$this->processFunction($node);
$this->processClosure($node);
return $node; return $node;
} }
@ -123,24 +121,6 @@ final class FunctionMethodAndClassNodeVisitor extends NodeVisitorAbstract
$node->setAttribute(AttributeKey::METHOD_NODE, $this->classMethod); $node->setAttribute(AttributeKey::METHOD_NODE, $this->classMethod);
} }
private function processFunction(Node $node): void
{
if ($node instanceof Function_) {
$this->function = $node;
}
$node->setAttribute(AttributeKey::FUNCTION_NODE, $this->function);
}
private function processClosure(Node $node): void
{
if ($node instanceof Closure) {
$this->closure = $node;
}
$node->setAttribute(AttributeKey::CLOSURE_NODE, $this->closure);
}
private function setClassNodeAndName(?ClassLike $classLike): void private function setClassNodeAndName(?ClassLike $classLike): void
{ {
$this->classLike = $classLike; $this->classLike = $classLike;

View File

@ -70,8 +70,7 @@ final class InvertedIfFactory
private function getNextReturnExpr(If_ $if): ?Node private function getNextReturnExpr(If_ $if): ?Node
{ {
/** @var Closure|null $closure */ $closure = $this->betterNodeFinder->findParentType($if, Closure::class);
$closure = $if->getAttribute(AttributeKey::CLOSURE_NODE);
if ($closure instanceof Closure) { if ($closure instanceof Closure) {
return null; return null;
} }

View File

@ -10,9 +10,9 @@ use PhpParser\Node\FunctionLike;
use PhpParser\Node\Stmt\ClassMethod; use PhpParser\Node\Stmt\ClassMethod;
use PhpParser\Node\Stmt\Foreach_; use PhpParser\Node\Stmt\Foreach_;
use PhpParser\Node\Stmt\Function_; use PhpParser\Node\Stmt\Function_;
use Rector\Core\PhpParser\Node\BetterNodeFinder;
use Rector\Naming\ValueObject\VariableAndCallForeach; use Rector\Naming\ValueObject\VariableAndCallForeach;
use Rector\NodeNameResolver\NodeNameResolver; use Rector\NodeNameResolver\NodeNameResolver;
use Rector\NodeTypeResolver\Node\AttributeKey;
final class ForeachMatcher final class ForeachMatcher
{ {
@ -26,10 +26,19 @@ final class ForeachMatcher
*/ */
private $callMatcher; private $callMatcher;
public function __construct(NodeNameResolver $nodeNameResolver, CallMatcher $callMatcher) /**
{ * @var BetterNodeFinder
*/
private $betterNodeFinder;
public function __construct(
NodeNameResolver $nodeNameResolver,
CallMatcher $callMatcher,
BetterNodeFinder $betterNodeFinder
) {
$this->nodeNameResolver = $nodeNameResolver; $this->nodeNameResolver = $nodeNameResolver;
$this->callMatcher = $callMatcher; $this->callMatcher = $callMatcher;
$this->betterNodeFinder = $betterNodeFinder;
} }
public function match(Foreach_ $foreach): ?VariableAndCallForeach public function match(Foreach_ $foreach): ?VariableAndCallForeach
@ -61,8 +70,9 @@ final class ForeachMatcher
*/ */
private function getFunctionLike(Foreach_ $foreach): ?FunctionLike private function getFunctionLike(Foreach_ $foreach): ?FunctionLike
{ {
return $foreach->getAttribute(AttributeKey::CLOSURE_NODE) ?? return $this->betterNodeFinder->findParentTypes(
$foreach->getAttribute(AttributeKey::METHOD_NODE) ?? $foreach,
$foreach->getAttribute(AttributeKey::FUNCTION_NODE); [Closure::class, ClassMethod::class, Function_::class]
);
} }
} }

View File

@ -10,9 +10,9 @@ use PhpParser\Node\Expr\Variable;
use PhpParser\Node\FunctionLike; use PhpParser\Node\FunctionLike;
use PhpParser\Node\Stmt\ClassMethod; use PhpParser\Node\Stmt\ClassMethod;
use PhpParser\Node\Stmt\Function_; use PhpParser\Node\Stmt\Function_;
use Rector\Core\PhpParser\Node\BetterNodeFinder;
use Rector\Naming\ValueObject\VariableAndCallAssign; use Rector\Naming\ValueObject\VariableAndCallAssign;
use Rector\NodeNameResolver\NodeNameResolver; use Rector\NodeNameResolver\NodeNameResolver;
use Rector\NodeTypeResolver\Node\AttributeKey;
final class VariableAndCallAssignMatcher final class VariableAndCallAssignMatcher
{ {
@ -26,10 +26,19 @@ final class VariableAndCallAssignMatcher
*/ */
private $nodeNameResolver; private $nodeNameResolver;
public function __construct(CallMatcher $callMatcher, NodeNameResolver $nodeNameResolver) /**
{ * @var BetterNodeFinder
*/
private $betterNodeFinder;
public function __construct(
CallMatcher $callMatcher,
NodeNameResolver $nodeNameResolver,
BetterNodeFinder $betterNodeFinder
) {
$this->callMatcher = $callMatcher; $this->callMatcher = $callMatcher;
$this->nodeNameResolver = $nodeNameResolver; $this->nodeNameResolver = $nodeNameResolver;
$this->betterNodeFinder = $betterNodeFinder;
} }
public function match(Assign $assign): ?VariableAndCallAssign public function match(Assign $assign): ?VariableAndCallAssign
@ -61,8 +70,9 @@ final class VariableAndCallAssignMatcher
*/ */
private function getFunctionLike(Assign $assign): ?FunctionLike private function getFunctionLike(Assign $assign): ?FunctionLike
{ {
return $assign->getAttribute(AttributeKey::CLOSURE_NODE) ?? return $this->betterNodeFinder->findParentTypes(
$assign->getAttribute(AttributeKey::METHOD_NODE) ?? $assign,
$assign->getAttribute(AttributeKey::FUNCTION_NODE); [Closure::class, ClassMethod::class, Function_::class]
);
} }
} }

View File

@ -14,6 +14,7 @@ use PhpParser\Node\Stmt\ClassMethod;
use PhpParser\Node\Stmt\Function_; use PhpParser\Node\Stmt\Function_;
use Rector\BetterPhpDocParser\PhpDocInfo\PhpDocInfo; use Rector\BetterPhpDocParser\PhpDocInfo\PhpDocInfo;
use Rector\BetterPhpDocParser\PhpDocInfo\PhpDocInfoFactory; use Rector\BetterPhpDocParser\PhpDocInfo\PhpDocInfoFactory;
use Rector\Core\PhpParser\Node\BetterNodeFinder;
use Rector\Naming\PhpDoc\VarTagValueNodeRenamer; use Rector\Naming\PhpDoc\VarTagValueNodeRenamer;
use Rector\NodeNameResolver\NodeNameResolver; use Rector\NodeNameResolver\NodeNameResolver;
use Rector\NodeTypeResolver\Node\AttributeKey; use Rector\NodeTypeResolver\Node\AttributeKey;
@ -41,16 +42,23 @@ final class VariableRenamer
*/ */
private $phpDocInfoFactory; private $phpDocInfoFactory;
/**
* @var BetterNodeFinder
*/
private $betterNodeFinder;
public function __construct( public function __construct(
SimpleCallableNodeTraverser $simpleCallableNodeTraverser, SimpleCallableNodeTraverser $simpleCallableNodeTraverser,
NodeNameResolver $nodeNameResolver, NodeNameResolver $nodeNameResolver,
VarTagValueNodeRenamer $varTagValueNodeRenamer, VarTagValueNodeRenamer $varTagValueNodeRenamer,
PhpDocInfoFactory $phpDocInfoFactory PhpDocInfoFactory $phpDocInfoFactory,
BetterNodeFinder $betterNodeFinder
) { ) {
$this->simpleCallableNodeTraverser = $simpleCallableNodeTraverser; $this->simpleCallableNodeTraverser = $simpleCallableNodeTraverser;
$this->nodeNameResolver = $nodeNameResolver; $this->nodeNameResolver = $nodeNameResolver;
$this->varTagValueNodeRenamer = $varTagValueNodeRenamer; $this->varTagValueNodeRenamer = $varTagValueNodeRenamer;
$this->phpDocInfoFactory = $phpDocInfoFactory; $this->phpDocInfoFactory = $phpDocInfoFactory;
$this->betterNodeFinder = $betterNodeFinder;
} }
/** /**
@ -103,7 +111,7 @@ final class VariableRenamer
private function isParamInParentFunction(Variable $variable): bool private function isParamInParentFunction(Variable $variable): bool
{ {
$closure = $variable->getAttribute(AttributeKey::CLOSURE_NODE); $closure = $this->betterNodeFinder->findParentType($variable, Closure::class);
if (! $closure instanceof Closure) { if (! $closure instanceof Closure) {
return false; return false;
} }

View File

@ -9,6 +9,7 @@ use PhpParser\Node\Expr\Closure;
use PhpParser\Node\Expr\New_; use PhpParser\Node\Expr\New_;
use PhpParser\Node\Stmt\ClassMethod; use PhpParser\Node\Stmt\ClassMethod;
use Rector\Core\Exception\ShouldNotHappenException; use Rector\Core\Exception\ShouldNotHappenException;
use Rector\Core\PhpParser\Node\BetterNodeFinder;
use Rector\NodeNestingScope\ParentScopeFinder; use Rector\NodeNestingScope\ParentScopeFinder;
use Rector\NodeTypeResolver\Node\AttributeKey; use Rector\NodeTypeResolver\Node\AttributeKey;
@ -19,9 +20,15 @@ final class FunctionLikeFirstLevelStatementResolver
*/ */
private $parentScopeFinder; private $parentScopeFinder;
public function __construct(ParentScopeFinder $parentScopeFinder) /**
* @var BetterNodeFinder
*/
private $betterNodeFinder;
public function __construct(ParentScopeFinder $parentScopeFinder, BetterNodeFinder $betterNodeFinder)
{ {
$this->parentScopeFinder = $parentScopeFinder; $this->parentScopeFinder = $parentScopeFinder;
$this->betterNodeFinder = $betterNodeFinder;
} }
public function resolveFirstLevelStatement(Node $node): Node public function resolveFirstLevelStatement(Node $node): Node
@ -57,7 +64,7 @@ final class FunctionLikeFirstLevelStatementResolver
*/ */
private function matchMultiplierClosure(Node $node): ?Closure private function matchMultiplierClosure(Node $node): ?Closure
{ {
$closure = $node->getAttribute(AttributeKey::CLOSURE_NODE); $closure = $this->betterNodeFinder->findParentType($node, Closure::class);
if (! $closure instanceof Closure) { if (! $closure instanceof Closure) {
return null; return null;
} }

View File

@ -15,6 +15,7 @@ use PHPStan\Reflection\ReflectionProvider;
use PHPStan\Type\ObjectType; use PHPStan\Type\ObjectType;
use Rector\Core\NodeManipulator\ClassMethodManipulator; use Rector\Core\NodeManipulator\ClassMethodManipulator;
use Rector\Core\Rector\AbstractRector; use Rector\Core\Rector\AbstractRector;
use Rector\NodeCollector\ScopeResolver\ParentClassScopeResolver;
use Rector\NodeCollector\StaticAnalyzer; use Rector\NodeCollector\StaticAnalyzer;
use ReflectionMethod; use ReflectionMethod;
use Symplify\RuleDocGenerator\ValueObject\CodeSample\CodeSample; use Symplify\RuleDocGenerator\ValueObject\CodeSample\CodeSample;
@ -46,7 +47,7 @@ final class StaticCallOnNonStaticToInstanceCallRector extends AbstractRector
private $reflectionProvider; private $reflectionProvider;
/** /**
* @var \Rector\NodeCollector\ScopeResolver\ParentClassScopeResolver * @var ParentClassScopeResolver
*/ */
private $parentClassScopeResolver; private $parentClassScopeResolver;
@ -54,7 +55,7 @@ final class StaticCallOnNonStaticToInstanceCallRector extends AbstractRector
ClassMethodManipulator $classMethodManipulator, ClassMethodManipulator $classMethodManipulator,
StaticAnalyzer $staticAnalyzer, StaticAnalyzer $staticAnalyzer,
ReflectionProvider $reflectionProvider, ReflectionProvider $reflectionProvider,
\Rector\NodeCollector\ScopeResolver\ParentClassScopeResolver $parentClassScopeResolver ParentClassScopeResolver $parentClassScopeResolver
) { ) {
$this->classMethodManipulator = $classMethodManipulator; $this->classMethodManipulator = $classMethodManipulator;
$this->staticAnalyzer = $staticAnalyzer; $this->staticAnalyzer = $staticAnalyzer;

View File

@ -108,15 +108,17 @@ CODE_SAMPLE
return; return;
} }
$classMethodOrFunctionNode = $funcCall->getAttribute(AttributeKey::METHOD_NODE) ?: /** @var ClassMethod|Function_|null $classMethodOrFunction */
$funcCall->getAttribute(AttributeKey::FUNCTION_NODE); $classMethodOrFunction = $this->betterNodeFinder->findParentTypes(
$funcCall,
if ($classMethodOrFunctionNode === null) { [ClassMethod::class, Function_::class]
);
if ($classMethodOrFunction === null) {
return; return;
} }
// dummy approach, improve when needed // dummy approach, improve when needed
$this->replaceGetNameOrGetValue($classMethodOrFunctionNode, $assign->var); $this->replaceGetNameOrGetValue($classMethodOrFunction, $assign->var);
} }
/** /**

View File

@ -6,11 +6,13 @@ namespace Rector\TypeDeclaration\TypeInferer\ParamTypeInferer;
use PhpParser\Node\FunctionLike; use PhpParser\Node\FunctionLike;
use PhpParser\Node\Param; use PhpParser\Node\Param;
use PhpParser\Node\Stmt\ClassMethod;
use PhpParser\Node\Stmt\Function_;
use PHPStan\Type\MixedType; use PHPStan\Type\MixedType;
use PHPStan\Type\Type; use PHPStan\Type\Type;
use Rector\BetterPhpDocParser\PhpDocInfo\PhpDocInfoFactory; use Rector\BetterPhpDocParser\PhpDocInfo\PhpDocInfoFactory;
use Rector\Core\PhpParser\Node\BetterNodeFinder;
use Rector\NodeNameResolver\NodeNameResolver; use Rector\NodeNameResolver\NodeNameResolver;
use Rector\NodeTypeResolver\Node\AttributeKey;
use Rector\TypeDeclaration\Contract\TypeInferer\ParamTypeInfererInterface; use Rector\TypeDeclaration\Contract\TypeInferer\ParamTypeInfererInterface;
final class FunctionLikeDocParamTypeInferer implements ParamTypeInfererInterface final class FunctionLikeDocParamTypeInferer implements ParamTypeInfererInterface
@ -25,10 +27,19 @@ final class FunctionLikeDocParamTypeInferer implements ParamTypeInfererInterface
*/ */
private $nodeNameResolver; private $nodeNameResolver;
public function __construct(NodeNameResolver $nodeNameResolver, PhpDocInfoFactory $phpDocInfoFactory) /**
{ * @var BetterNodeFinder
*/
private $betterNodeFinder;
public function __construct(
NodeNameResolver $nodeNameResolver,
PhpDocInfoFactory $phpDocInfoFactory,
BetterNodeFinder $betterNodeFinder
) {
$this->nodeNameResolver = $nodeNameResolver; $this->nodeNameResolver = $nodeNameResolver;
$this->phpDocInfoFactory = $phpDocInfoFactory; $this->phpDocInfoFactory = $phpDocInfoFactory;
$this->betterNodeFinder = $betterNodeFinder;
} }
public function inferParam(Param $param): Type public function inferParam(Param $param): Type
@ -50,7 +61,7 @@ final class FunctionLikeDocParamTypeInferer implements ParamTypeInfererInterface
private function resolveScopeNode(Param $param): ?FunctionLike private function resolveScopeNode(Param $param): ?FunctionLike
{ {
return $param->getAttribute(AttributeKey::METHOD_NODE) ?? $param->getAttribute(AttributeKey::FUNCTION_NODE); return $this->betterNodeFinder->findParentTypes($param, [ClassMethod::class, Function_::class]);
} }
/** /**

View File

@ -6,12 +6,10 @@ namespace Rector\Visibility\Rector\ClassMethod;
use PhpParser\Node; use PhpParser\Node;
use PhpParser\Node\Stmt\ClassMethod; use PhpParser\Node\Stmt\ClassMethod;
use PHPStan\Analyser\Scope;
use Rector\Core\Contract\Rector\ConfigurableRectorInterface; use Rector\Core\Contract\Rector\ConfigurableRectorInterface;
use Rector\Core\Rector\AbstractRector; use Rector\Core\Rector\AbstractRector;
use Rector\Core\ValueObject\Visibility; use Rector\Core\ValueObject\Visibility;
use Rector\NodeCollector\ScopeResolver\ParentClassScopeResolver; use Rector\NodeCollector\ScopeResolver\ParentClassScopeResolver;
use Rector\NodeTypeResolver\Node\AttributeKey;
use Rector\Visibility\ValueObject\ChangeMethodVisibility; use Rector\Visibility\ValueObject\ChangeMethodVisibility;
use Symplify\RuleDocGenerator\ValueObject\CodeSample\ConfiguredCodeSample; use Symplify\RuleDocGenerator\ValueObject\CodeSample\ConfiguredCodeSample;
use Symplify\RuleDocGenerator\ValueObject\RuleDefinition; use Symplify\RuleDocGenerator\ValueObject\RuleDefinition;