From d78fa52ad750e9789b1b7e4226b470f8ef04733f Mon Sep 17 00:00:00 2001 From: "Alexander M. Turek" Date: Tue, 15 Feb 2022 13:00:15 +0100 Subject: [PATCH] Replace TreeWalkerChainIterator with a generator (#9511) --- UPGRADE.md | 4 + lib/Doctrine/ORM/Query/TreeWalkerChain.php | 132 ++++++++++-------- .../ORM/Query/TreeWalkerChainIterator.php | 10 ++ psalm-baseline.xml | 48 ------- 4 files changed, 90 insertions(+), 104 deletions(-) diff --git a/UPGRADE.md b/UPGRADE.md index 7dc16d19e9..db966c5bda 100644 --- a/UPGRADE.md +++ b/UPGRADE.md @@ -1,5 +1,9 @@ # Upgrade to 2.12 +## Deprecate `Doctrine\ORM\Query\TreeWalkerChainIterator` + +This class won't have a replacement. + ## Deprecate `OnClearEventArgs::getEntityClass()` and `OnClearEventArgs::clearsAllEntities()` These methods will be removed in 3.0 along with the ability to partially clear diff --git a/lib/Doctrine/ORM/Query/TreeWalkerChain.php b/lib/Doctrine/ORM/Query/TreeWalkerChain.php index 421ad4f906..4dee17da1e 100644 --- a/lib/Doctrine/ORM/Query/TreeWalkerChain.php +++ b/lib/Doctrine/ORM/Query/TreeWalkerChain.php @@ -4,7 +4,9 @@ namespace Doctrine\ORM\Query; +use Doctrine\ORM\AbstractQuery; use Doctrine\ORM\Mapping\ClassMetadata; +use Generator; use function array_diff; use function array_keys; @@ -19,10 +21,16 @@ class TreeWalkerChain implements TreeWalker /** * The tree walkers. * - * @var TreeWalker[] - * @psalm-var TreeWalkerChainIterator + * @var string[] + * @psalm-var list> */ - private $_walkers; + private $walkers = []; + + /** @var AbstractQuery */ + private $query; + + /** @var ParserResult */ + private $parserResult; /** * The query components of the original query (the "symbol table") that was produced by the Parser. @@ -37,7 +45,7 @@ class TreeWalkerChain implements TreeWalker * token: array * }> */ - private $_queryComponents; + private $queryComponents; /** * Returns the internal queryComponents array. @@ -46,7 +54,7 @@ class TreeWalkerChain implements TreeWalker */ public function getQueryComponents() { - return $this->_queryComponents; + return $this->queryComponents; } /** @@ -62,7 +70,7 @@ public function setQueryComponent($dqlAlias, array $queryComponent) throw QueryException::invalidQueryComponent($dqlAlias); } - $this->_queryComponents[$dqlAlias] = $queryComponent; + $this->queryComponents[$dqlAlias] = $queryComponent; } /** @@ -70,20 +78,22 @@ public function setQueryComponent($dqlAlias, array $queryComponent) */ public function __construct($query, $parserResult, array $queryComponents) { - $this->_queryComponents = $queryComponents; - $this->_walkers = new TreeWalkerChainIterator($this, $query, $parserResult); + $this->query = $query; + $this->parserResult = $parserResult; + $this->queryComponents = $queryComponents; } /** * Adds a tree walker to the chain. * * @param string $walkerClass The class of the walker to instantiate. + * @psalm-param class-string $walkerClass * * @return void */ public function addTreeWalker($walkerClass) { - $this->_walkers[] = $walkerClass; + $this->walkers[] = $walkerClass; } /** @@ -93,10 +103,10 @@ public function addTreeWalker($walkerClass) */ public function walkSelectStatement(AST\SelectStatement $AST) { - foreach ($this->_walkers as $walker) { + foreach ($this->getWalkers() as $walker) { $walker->walkSelectStatement($AST); - $this->_queryComponents = $walker->getQueryComponents(); + $this->queryComponents = $walker->getQueryComponents(); } } @@ -107,7 +117,7 @@ public function walkSelectStatement(AST\SelectStatement $AST) */ public function walkSelectClause($selectClause) { - foreach ($this->_walkers as $walker) { + foreach ($this->getWalkers() as $walker) { $walker->walkSelectClause($selectClause); } } @@ -119,7 +129,7 @@ public function walkSelectClause($selectClause) */ public function walkFromClause($fromClause) { - foreach ($this->_walkers as $walker) { + foreach ($this->getWalkers() as $walker) { $walker->walkFromClause($fromClause); } } @@ -131,7 +141,7 @@ public function walkFromClause($fromClause) */ public function walkFunction($function) { - foreach ($this->_walkers as $walker) { + foreach ($this->getWalkers() as $walker) { $walker->walkFunction($function); } } @@ -143,7 +153,7 @@ public function walkFunction($function) */ public function walkOrderByClause($orderByClause) { - foreach ($this->_walkers as $walker) { + foreach ($this->getWalkers() as $walker) { $walker->walkOrderByClause($orderByClause); } } @@ -155,7 +165,7 @@ public function walkOrderByClause($orderByClause) */ public function walkOrderByItem($orderByItem) { - foreach ($this->_walkers as $walker) { + foreach ($this->getWalkers() as $walker) { $walker->walkOrderByItem($orderByItem); } } @@ -167,7 +177,7 @@ public function walkOrderByItem($orderByItem) */ public function walkHavingClause($havingClause) { - foreach ($this->_walkers as $walker) { + foreach ($this->getWalkers() as $walker) { $walker->walkHavingClause($havingClause); } } @@ -179,7 +189,7 @@ public function walkHavingClause($havingClause) */ public function walkJoin($join) { - foreach ($this->_walkers as $walker) { + foreach ($this->getWalkers() as $walker) { $walker->walkJoin($join); } } @@ -191,7 +201,7 @@ public function walkJoin($join) */ public function walkSelectExpression($selectExpression) { - foreach ($this->_walkers as $walker) { + foreach ($this->getWalkers() as $walker) { $walker->walkSelectExpression($selectExpression); } } @@ -203,7 +213,7 @@ public function walkSelectExpression($selectExpression) */ public function walkQuantifiedExpression($qExpr) { - foreach ($this->_walkers as $walker) { + foreach ($this->getWalkers() as $walker) { $walker->walkQuantifiedExpression($qExpr); } } @@ -215,7 +225,7 @@ public function walkQuantifiedExpression($qExpr) */ public function walkSubselect($subselect) { - foreach ($this->_walkers as $walker) { + foreach ($this->getWalkers() as $walker) { $walker->walkSubselect($subselect); } } @@ -227,7 +237,7 @@ public function walkSubselect($subselect) */ public function walkSubselectFromClause($subselectFromClause) { - foreach ($this->_walkers as $walker) { + foreach ($this->getWalkers() as $walker) { $walker->walkSubselectFromClause($subselectFromClause); } } @@ -239,7 +249,7 @@ public function walkSubselectFromClause($subselectFromClause) */ public function walkSimpleSelectClause($simpleSelectClause) { - foreach ($this->_walkers as $walker) { + foreach ($this->getWalkers() as $walker) { $walker->walkSimpleSelectClause($simpleSelectClause); } } @@ -251,7 +261,7 @@ public function walkSimpleSelectClause($simpleSelectClause) */ public function walkSimpleSelectExpression($simpleSelectExpression) { - foreach ($this->_walkers as $walker) { + foreach ($this->getWalkers() as $walker) { $walker->walkSimpleSelectExpression($simpleSelectExpression); } } @@ -263,7 +273,7 @@ public function walkSimpleSelectExpression($simpleSelectExpression) */ public function walkAggregateExpression($aggExpression) { - foreach ($this->_walkers as $walker) { + foreach ($this->getWalkers() as $walker) { $walker->walkAggregateExpression($aggExpression); } } @@ -275,7 +285,7 @@ public function walkAggregateExpression($aggExpression) */ public function walkGroupByClause($groupByClause) { - foreach ($this->_walkers as $walker) { + foreach ($this->getWalkers() as $walker) { $walker->walkGroupByClause($groupByClause); } } @@ -287,7 +297,7 @@ public function walkGroupByClause($groupByClause) */ public function walkGroupByItem($groupByItem) { - foreach ($this->_walkers as $walker) { + foreach ($this->getWalkers() as $walker) { $walker->walkGroupByItem($groupByItem); } } @@ -299,7 +309,7 @@ public function walkGroupByItem($groupByItem) */ public function walkUpdateStatement(AST\UpdateStatement $AST) { - foreach ($this->_walkers as $walker) { + foreach ($this->getWalkers() as $walker) { $walker->walkUpdateStatement($AST); } } @@ -311,7 +321,7 @@ public function walkUpdateStatement(AST\UpdateStatement $AST) */ public function walkDeleteStatement(AST\DeleteStatement $AST) { - foreach ($this->_walkers as $walker) { + foreach ($this->getWalkers() as $walker) { $walker->walkDeleteStatement($AST); } } @@ -323,7 +333,7 @@ public function walkDeleteStatement(AST\DeleteStatement $AST) */ public function walkDeleteClause(AST\DeleteClause $deleteClause) { - foreach ($this->_walkers as $walker) { + foreach ($this->getWalkers() as $walker) { $walker->walkDeleteClause($deleteClause); } } @@ -335,7 +345,7 @@ public function walkDeleteClause(AST\DeleteClause $deleteClause) */ public function walkUpdateClause($updateClause) { - foreach ($this->_walkers as $walker) { + foreach ($this->getWalkers() as $walker) { $walker->walkUpdateClause($updateClause); } } @@ -347,7 +357,7 @@ public function walkUpdateClause($updateClause) */ public function walkUpdateItem($updateItem) { - foreach ($this->_walkers as $walker) { + foreach ($this->getWalkers() as $walker) { $walker->walkUpdateItem($updateItem); } } @@ -359,7 +369,7 @@ public function walkUpdateItem($updateItem) */ public function walkWhereClause($whereClause) { - foreach ($this->_walkers as $walker) { + foreach ($this->getWalkers() as $walker) { $walker->walkWhereClause($whereClause); } } @@ -371,7 +381,7 @@ public function walkWhereClause($whereClause) */ public function walkConditionalExpression($condExpr) { - foreach ($this->_walkers as $walker) { + foreach ($this->getWalkers() as $walker) { $walker->walkConditionalExpression($condExpr); } } @@ -383,7 +393,7 @@ public function walkConditionalExpression($condExpr) */ public function walkConditionalTerm($condTerm) { - foreach ($this->_walkers as $walker) { + foreach ($this->getWalkers() as $walker) { $walker->walkConditionalTerm($condTerm); } } @@ -395,7 +405,7 @@ public function walkConditionalTerm($condTerm) */ public function walkConditionalFactor($factor) { - foreach ($this->_walkers as $walker) { + foreach ($this->getWalkers() as $walker) { $walker->walkConditionalFactor($factor); } } @@ -407,7 +417,7 @@ public function walkConditionalFactor($factor) */ public function walkConditionalPrimary($condPrimary) { - foreach ($this->_walkers as $walker) { + foreach ($this->getWalkers() as $walker) { $walker->walkConditionalPrimary($condPrimary); } } @@ -419,7 +429,7 @@ public function walkConditionalPrimary($condPrimary) */ public function walkExistsExpression($existsExpr) { - foreach ($this->_walkers as $walker) { + foreach ($this->getWalkers() as $walker) { $walker->walkExistsExpression($existsExpr); } } @@ -431,7 +441,7 @@ public function walkExistsExpression($existsExpr) */ public function walkCollectionMemberExpression($collMemberExpr) { - foreach ($this->_walkers as $walker) { + foreach ($this->getWalkers() as $walker) { $walker->walkCollectionMemberExpression($collMemberExpr); } } @@ -443,7 +453,7 @@ public function walkCollectionMemberExpression($collMemberExpr) */ public function walkEmptyCollectionComparisonExpression($emptyCollCompExpr) { - foreach ($this->_walkers as $walker) { + foreach ($this->getWalkers() as $walker) { $walker->walkEmptyCollectionComparisonExpression($emptyCollCompExpr); } } @@ -455,7 +465,7 @@ public function walkEmptyCollectionComparisonExpression($emptyCollCompExpr) */ public function walkNullComparisonExpression($nullCompExpr) { - foreach ($this->_walkers as $walker) { + foreach ($this->getWalkers() as $walker) { $walker->walkNullComparisonExpression($nullCompExpr); } } @@ -467,7 +477,7 @@ public function walkNullComparisonExpression($nullCompExpr) */ public function walkInExpression($inExpr) { - foreach ($this->_walkers as $walker) { + foreach ($this->getWalkers() as $walker) { $walker->walkInExpression($inExpr); } } @@ -479,7 +489,7 @@ public function walkInExpression($inExpr) */ public function walkInstanceOfExpression($instanceOfExpr) { - foreach ($this->_walkers as $walker) { + foreach ($this->getWalkers() as $walker) { $walker->walkInstanceOfExpression($instanceOfExpr); } } @@ -491,7 +501,7 @@ public function walkInstanceOfExpression($instanceOfExpr) */ public function walkLiteral($literal) { - foreach ($this->_walkers as $walker) { + foreach ($this->getWalkers() as $walker) { $walker->walkLiteral($literal); } } @@ -503,7 +513,7 @@ public function walkLiteral($literal) */ public function walkBetweenExpression($betweenExpr) { - foreach ($this->_walkers as $walker) { + foreach ($this->getWalkers() as $walker) { $walker->walkBetweenExpression($betweenExpr); } } @@ -515,7 +525,7 @@ public function walkBetweenExpression($betweenExpr) */ public function walkLikeExpression($likeExpr) { - foreach ($this->_walkers as $walker) { + foreach ($this->getWalkers() as $walker) { $walker->walkLikeExpression($likeExpr); } } @@ -527,7 +537,7 @@ public function walkLikeExpression($likeExpr) */ public function walkStateFieldPathExpression($stateFieldPathExpression) { - foreach ($this->_walkers as $walker) { + foreach ($this->getWalkers() as $walker) { $walker->walkStateFieldPathExpression($stateFieldPathExpression); } } @@ -539,7 +549,7 @@ public function walkStateFieldPathExpression($stateFieldPathExpression) */ public function walkComparisonExpression($compExpr) { - foreach ($this->_walkers as $walker) { + foreach ($this->getWalkers() as $walker) { $walker->walkComparisonExpression($compExpr); } } @@ -551,7 +561,7 @@ public function walkComparisonExpression($compExpr) */ public function walkInputParameter($inputParam) { - foreach ($this->_walkers as $walker) { + foreach ($this->getWalkers() as $walker) { $walker->walkInputParameter($inputParam); } } @@ -563,7 +573,7 @@ public function walkInputParameter($inputParam) */ public function walkArithmeticExpression($arithmeticExpr) { - foreach ($this->_walkers as $walker) { + foreach ($this->getWalkers() as $walker) { $walker->walkArithmeticExpression($arithmeticExpr); } } @@ -575,7 +585,7 @@ public function walkArithmeticExpression($arithmeticExpr) */ public function walkArithmeticTerm($term) { - foreach ($this->_walkers as $walker) { + foreach ($this->getWalkers() as $walker) { $walker->walkArithmeticTerm($term); } } @@ -587,7 +597,7 @@ public function walkArithmeticTerm($term) */ public function walkStringPrimary($stringPrimary) { - foreach ($this->_walkers as $walker) { + foreach ($this->getWalkers() as $walker) { $walker->walkStringPrimary($stringPrimary); } } @@ -599,7 +609,7 @@ public function walkStringPrimary($stringPrimary) */ public function walkArithmeticFactor($factor) { - foreach ($this->_walkers as $walker) { + foreach ($this->getWalkers() as $walker) { $walker->walkArithmeticFactor($factor); } } @@ -611,7 +621,7 @@ public function walkArithmeticFactor($factor) */ public function walkSimpleArithmeticExpression($simpleArithmeticExpr) { - foreach ($this->_walkers as $walker) { + foreach ($this->getWalkers() as $walker) { $walker->walkSimpleArithmeticExpression($simpleArithmeticExpr); } } @@ -623,7 +633,7 @@ public function walkSimpleArithmeticExpression($simpleArithmeticExpr) */ public function walkPathExpression($pathExpr) { - foreach ($this->_walkers as $walker) { + foreach ($this->getWalkers() as $walker) { $walker->walkPathExpression($pathExpr); } } @@ -635,7 +645,7 @@ public function walkPathExpression($pathExpr) */ public function walkResultVariable($resultVariable) { - foreach ($this->_walkers as $walker) { + foreach ($this->getWalkers() as $walker) { $walker->walkResultVariable($resultVariable); } } @@ -648,4 +658,14 @@ public function walkResultVariable($resultVariable) public function getExecutor($AST) { } + + /** + * @psalm-return Generator + */ + private function getWalkers(): Generator + { + foreach ($this->walkers as $walkerClass) { + yield new $walkerClass($this->query, $this->parserResult, $this->queryComponents); + } + } } diff --git a/lib/Doctrine/ORM/Query/TreeWalkerChainIterator.php b/lib/Doctrine/ORM/Query/TreeWalkerChainIterator.php index d480d35938..117628724b 100644 --- a/lib/Doctrine/ORM/Query/TreeWalkerChainIterator.php +++ b/lib/Doctrine/ORM/Query/TreeWalkerChainIterator.php @@ -5,6 +5,7 @@ namespace Doctrine\ORM\Query; use ArrayAccess; +use Doctrine\Deprecations\Deprecation; use Doctrine\ORM\AbstractQuery; use Iterator; use ReturnTypeWillChange; @@ -14,6 +15,8 @@ use function reset; /** + * @deprecated This class will be removed in 3.0 without replacement. + * * @template-implements Iterator * @template-implements ArrayAccess */ @@ -34,6 +37,13 @@ class TreeWalkerChainIterator implements Iterator, ArrayAccess */ public function __construct(TreeWalkerChain $treeWalkerChain, $query, $parserResult) { + Deprecation::trigger( + 'doctrine/orm', + 'https://github.com/doctrine/orm/pull/9511', + '%s is deprecated and will be removed without replacement.', + self::class + ); + $this->treeWalkerChain = $treeWalkerChain; $this->query = $query; $this->parserResult = $parserResult; diff --git a/psalm-baseline.xml b/psalm-baseline.xml index 8a0b37a0ef..f927695797 100644 --- a/psalm-baseline.xml +++ b/psalm-baseline.xml @@ -2700,54 +2700,6 @@ $condPrimary - - walkAggregateExpression - walkArithmeticExpression - walkArithmeticFactor - walkArithmeticTerm - walkBetweenExpression - walkCollectionMemberExpression - walkComparisonExpression - walkConditionalExpression - walkConditionalFactor - walkConditionalPrimary - walkConditionalTerm - walkDeleteClause - walkDeleteStatement - walkEmptyCollectionComparisonExpression - walkExistsExpression - walkFromClause - walkFunction - walkGroupByClause - walkGroupByItem - walkHavingClause - walkInExpression - walkInputParameter - walkInstanceOfExpression - walkJoin - walkLikeExpression - walkLiteral - walkNullComparisonExpression - walkOrderByClause - walkOrderByItem - walkPathExpression - walkQuantifiedExpression - walkResultVariable - walkSelectClause - walkSelectExpression - walkSelectStatement - walkSimpleArithmeticExpression - walkSimpleSelectClause - walkSimpleSelectExpression - walkStateFieldPathExpression - walkStringPrimary - walkSubselect - walkSubselectFromClause - walkUpdateClause - walkUpdateItem - walkUpdateStatement - walkWhereClause -