From ce7d7b38538adca866e22bd94078933c5b3999dd Mon Sep 17 00:00:00 2001 From: Markus Staab Date: Mon, 30 Dec 2024 09:44:38 +0100 Subject: [PATCH] PreviousConnectingVisitor: Drop parent attribute --- src/Ast/ExpressionFinder.php | 10 ---------- src/Ast/PreviousConnectingVisitor.php | 23 +++++------------------ 2 files changed, 5 insertions(+), 28 deletions(-) diff --git a/src/Ast/ExpressionFinder.php b/src/Ast/ExpressionFinder.php index d24ec718..492b569e 100644 --- a/src/Ast/ExpressionFinder.php +++ b/src/Ast/ExpressionFinder.php @@ -10,7 +10,6 @@ use PhpParser\Node\Expr\AssignOp; use PhpParser\Node\Expr\MethodCall; use PhpParser\Node\Expr\Variable; -use PhpParser\Node\FunctionLike; use PhpParser\NodeFinder; use PHPStan\ShouldNotHappenException; @@ -147,15 +146,6 @@ private function findFirstPreviousOfNode(Node $node, callable $filter): ?Node return $this->findFirstPreviousOfNode($previousStatement, $filter); } - $parent = $node->getAttribute(PreviousConnectingVisitor::ATTRIBUTE_PARENT); - if ($parent instanceof FunctionLike) { - return null; - } - - if ($parent instanceof Node) { - return $this->findFirstPreviousOfNode($parent, $filter); - } - return null; } diff --git a/src/Ast/PreviousConnectingVisitor.php b/src/Ast/PreviousConnectingVisitor.php index a5657bd0..7f217d86 100644 --- a/src/Ast/PreviousConnectingVisitor.php +++ b/src/Ast/PreviousConnectingVisitor.php @@ -7,19 +7,11 @@ use PhpParser\Node; use PhpParser\NodeVisitorAbstract; use staabm\PHPStanDba\QueryReflection\DIContainerBridge; -use function array_pop; final class PreviousConnectingVisitor extends NodeVisitorAbstract { - public const ATTRIBUTE_PARENT = 'dba-parent'; - public const ATTRIBUTE_PREVIOUS = 'dba-previous'; - /** - * @var list - */ - private array $stack = []; - private ?Node $previous; // a dummy property to force instantiation of DIContainerBridge @@ -33,7 +25,6 @@ public function __construct(DIContainerBridge $dummyParameter) public function beforeTraverse(array $nodes) { - $this->stack = []; $this->previous = null; return null; @@ -41,16 +32,14 @@ public function beforeTraverse(array $nodes) public function enterNode(Node $node) { - if ([] !== $this->stack) { - $node->setAttribute(self::ATTRIBUTE_PARENT, $this->stack[\count($this->stack) - 1]); - } - - if (null !== $this->previous && $this->previous->getAttribute(self::ATTRIBUTE_PARENT) === $node->getAttribute(self::ATTRIBUTE_PARENT)) { + if ( + null !== $this->previous + && ! $this->previous instanceof Node\FunctionLike + && ! $this->previous instanceof Node\Stmt\ClassLike + ) { $node->setAttribute(self::ATTRIBUTE_PREVIOUS, $this->previous); } - $this->stack[] = $node; - return null; } @@ -58,8 +47,6 @@ public function leaveNode(Node $node) { $this->previous = $node; - array_pop($this->stack); - return null; } }