diff --git a/rules/Php71/NodeAnalyzer/CountableAnalyzer.php b/rules/Php71/NodeAnalyzer/CountableAnalyzer.php index 06cf4d1447c..4f3a4651e51 100644 --- a/rules/Php71/NodeAnalyzer/CountableAnalyzer.php +++ b/rules/Php71/NodeAnalyzer/CountableAnalyzer.php @@ -19,7 +19,7 @@ use PHPStan\Type\Type; use PHPStan\Type\TypeWithClassName; use PHPStan\Type\UnionType; use Rector\Core\NodeAnalyzer\PropertyFetchAnalyzer; -use Rector\Core\PhpParser\AstResolver; +use Rector\Core\PhpParser\ClassLikeAstResolver; use Rector\Core\Reflection\ReflectionResolver; use Rector\NodeNameResolver\NodeNameResolver; use Rector\NodeTypeResolver\NodeTypeResolver; @@ -58,10 +58,10 @@ final class CountableAnalyzer private $reflectionResolver; /** * @readonly - * @var \Rector\Core\PhpParser\AstResolver + * @var \Rector\Core\PhpParser\ClassLikeAstResolver */ - private $astResolver; - public function __construct(NodeTypeResolver $nodeTypeResolver, NodeNameResolver $nodeNameResolver, ReflectionProvider $reflectionProvider, PropertyFetchAnalyzer $propertyFetchAnalyzer, ConstructorAssignDetector $constructorAssignDetector, ReflectionResolver $reflectionResolver, AstResolver $astResolver) + private $classLikeAstResolver; + public function __construct(NodeTypeResolver $nodeTypeResolver, NodeNameResolver $nodeNameResolver, ReflectionProvider $reflectionProvider, PropertyFetchAnalyzer $propertyFetchAnalyzer, ConstructorAssignDetector $constructorAssignDetector, ReflectionResolver $reflectionResolver, ClassLikeAstResolver $classLikeAstResolver) { $this->nodeTypeResolver = $nodeTypeResolver; $this->nodeNameResolver = $nodeNameResolver; @@ -69,7 +69,7 @@ final class CountableAnalyzer $this->propertyFetchAnalyzer = $propertyFetchAnalyzer; $this->constructorAssignDetector = $constructorAssignDetector; $this->reflectionResolver = $reflectionResolver; - $this->astResolver = $astResolver; + $this->classLikeAstResolver = $classLikeAstResolver; } public function isCastableArrayType(Expr $expr, ArrayType $arrayType, Scope $scope) : bool { @@ -134,7 +134,7 @@ final class CountableAnalyzer if (!$classReflection instanceof ClassReflection) { return \false; } - $classLike = $this->astResolver->resolveClassFromName($classReflection->getName()); + $classLike = $this->classLikeAstResolver->resolveClassFromClassReflection($classReflection); if (!$classLike instanceof ClassLike) { return \false; } diff --git a/rules/Php80/NodeAnalyzer/PhpAttributeAnalyzer.php b/rules/Php80/NodeAnalyzer/PhpAttributeAnalyzer.php index 8a8cc8ef9a5..4cbb25b5256 100644 --- a/rules/Php80/NodeAnalyzer/PhpAttributeAnalyzer.php +++ b/rules/Php80/NodeAnalyzer/PhpAttributeAnalyzer.php @@ -14,16 +14,16 @@ use PhpParser\Node\Stmt\ClassLike; use PhpParser\Node\Stmt\ClassMethod; use PhpParser\Node\Stmt\Property; use PHPStan\Reflection\ReflectionProvider; -use Rector\Core\PhpParser\AstResolver; +use Rector\Core\PhpParser\ClassLikeAstResolver; use Rector\NodeNameResolver\NodeNameResolver; use Rector\PhpAttribute\Enum\DocTagNodeState; final class PhpAttributeAnalyzer { /** * @readonly - * @var \Rector\Core\PhpParser\AstResolver + * @var \Rector\Core\PhpParser\ClassLikeAstResolver */ - private $astResolver; + private $classLikeAstResolver; /** * @readonly * @var \Rector\NodeNameResolver\NodeNameResolver @@ -34,9 +34,9 @@ final class PhpAttributeAnalyzer * @var \PHPStan\Reflection\ReflectionProvider */ private $reflectionProvider; - public function __construct(AstResolver $astResolver, NodeNameResolver $nodeNameResolver, ReflectionProvider $reflectionProvider) + public function __construct(ClassLikeAstResolver $classLikeAstResolver, NodeNameResolver $nodeNameResolver, ReflectionProvider $reflectionProvider) { - $this->astResolver = $astResolver; + $this->classLikeAstResolver = $classLikeAstResolver; $this->nodeNameResolver = $nodeNameResolver; $this->reflectionProvider = $reflectionProvider; } @@ -64,8 +64,7 @@ final class PhpAttributeAnalyzer $classReflection = $this->reflectionProvider->getClass($className); $ancestorClassReflections = \array_merge($classReflection->getParents(), $classReflection->getInterfaces()); foreach ($ancestorClassReflections as $ancestorClassReflection) { - $ancestorClassName = $ancestorClassReflection->getName(); - $resolvedClass = $this->astResolver->resolveClassFromName($ancestorClassName); + $resolvedClass = $this->classLikeAstResolver->resolveClassFromClassReflection($ancestorClassReflection); if (!$resolvedClass instanceof Class_) { continue; } diff --git a/rules/Privatization/Guard/ParentPropertyLookupGuard.php b/rules/Privatization/Guard/ParentPropertyLookupGuard.php index 618c4573fa7..d6a871f5b94 100644 --- a/rules/Privatization/Guard/ParentPropertyLookupGuard.php +++ b/rules/Privatization/Guard/ParentPropertyLookupGuard.php @@ -14,7 +14,7 @@ use PHPStan\Reflection\ClassReflection; use Rector\Core\Enum\ObjectReference; use Rector\Core\NodeAnalyzer\PropertyFetchAnalyzer; use Rector\Core\NodeManipulator\PropertyManipulator; -use Rector\Core\PhpParser\AstResolver; +use Rector\Core\PhpParser\ClassLikeAstResolver; use Rector\Core\PhpParser\Node\BetterNodeFinder; use Rector\Core\Util\Reflection\PrivatesAccessor; use Rector\NodeNameResolver\NodeNameResolver; @@ -37,9 +37,9 @@ final class ParentPropertyLookupGuard private $propertyFetchAnalyzer; /** * @readonly - * @var \Rector\Core\PhpParser\AstResolver + * @var \Rector\Core\PhpParser\ClassLikeAstResolver */ - private $astResolver; + private $classLikeAstResolver; /** * @readonly * @var \Rector\Core\NodeManipulator\PropertyManipulator @@ -50,12 +50,12 @@ final class ParentPropertyLookupGuard * @var \Rector\Core\Util\Reflection\PrivatesAccessor */ private $privatesAccessor; - public function __construct(BetterNodeFinder $betterNodeFinder, NodeNameResolver $nodeNameResolver, PropertyFetchAnalyzer $propertyFetchAnalyzer, AstResolver $astResolver, PropertyManipulator $propertyManipulator, PrivatesAccessor $privatesAccessor) + public function __construct(BetterNodeFinder $betterNodeFinder, NodeNameResolver $nodeNameResolver, PropertyFetchAnalyzer $propertyFetchAnalyzer, ClassLikeAstResolver $classLikeAstResolver, PropertyManipulator $propertyManipulator, PrivatesAccessor $privatesAccessor) { $this->betterNodeFinder = $betterNodeFinder; $this->nodeNameResolver = $nodeNameResolver; $this->propertyFetchAnalyzer = $propertyFetchAnalyzer; - $this->astResolver = $astResolver; + $this->classLikeAstResolver = $classLikeAstResolver; $this->propertyManipulator = $propertyManipulator; $this->privatesAccessor = $privatesAccessor; } @@ -87,7 +87,7 @@ final class ParentPropertyLookupGuard } private function isFoundInParentClassMethods(ClassReflection $parentClassReflection, string $propertyName, string $className) : bool { - $classLike = $this->astResolver->resolveClassFromName($parentClassReflection->getName()); + $classLike = $this->classLikeAstResolver->resolveClassFromClassReflection($parentClassReflection); if (!$classLike instanceof Class_) { return \false; } diff --git a/src/Application/VersionResolver.php b/src/Application/VersionResolver.php index e6db31a4ce3..aa2da2977be 100644 --- a/src/Application/VersionResolver.php +++ b/src/Application/VersionResolver.php @@ -19,12 +19,12 @@ final class VersionResolver * @api * @var string */ - public const PACKAGE_VERSION = '8585ff77542ad3ff7cd55226e23378ee866865aa'; + public const PACKAGE_VERSION = '8550c092de01d1167d95922a77490c282f3154d5'; /** * @api * @var string */ - public const RELEASE_DATE = '2023-06-18 02:16:03'; + public const RELEASE_DATE = '2023-06-18 02:33:10'; /** * @var int */ diff --git a/src/NodeManipulator/PropertyManipulator.php b/src/NodeManipulator/PropertyManipulator.php index 28b2779df62..50531cc9e22 100644 --- a/src/NodeManipulator/PropertyManipulator.php +++ b/src/NodeManipulator/PropertyManipulator.php @@ -27,7 +27,7 @@ use PHPStan\Type\ObjectType; use Rector\BetterPhpDocParser\PhpDocInfo\PhpDocInfo; use Rector\BetterPhpDocParser\PhpDocInfo\PhpDocInfoFactory; use Rector\Core\NodeAnalyzer\PropertyFetchAnalyzer; -use Rector\Core\PhpParser\AstResolver; +use Rector\Core\PhpParser\ClassLikeAstResolver; use Rector\Core\PhpParser\Node\BetterNodeFinder; use Rector\Core\PhpParser\NodeFinder\PropertyFetchFinder; use Rector\Core\Reflection\ReflectionResolver; @@ -110,9 +110,9 @@ final class PropertyManipulator private $constructorAssignDetector; /** * @readonly - * @var \Rector\Core\PhpParser\AstResolver + * @var \Rector\Core\PhpParser\ClassLikeAstResolver */ - private $astResolver; + private $classLikeAstResolver; /** * @readonly * @var \Rector\Core\NodeAnalyzer\PropertyFetchAnalyzer @@ -127,7 +127,7 @@ final class PropertyManipulator * @var string[]|class-string