diff --git a/rules-tests/Php74/Rector/Property/RestoreDefaultNullToNullableTypePropertyRector/Fixture/skip_readonly_phpdoc_class.php.inc b/rules-tests/Php74/Rector/Property/RestoreDefaultNullToNullableTypePropertyRector/Fixture/skip_readonly_phpdoc_class.php.inc new file mode 100644 index 00000000000..846e5ab5a46 --- /dev/null +++ b/rules-tests/Php74/Rector/Property/RestoreDefaultNullToNullableTypePropertyRector/Fixture/skip_readonly_phpdoc_class.php.inc @@ -0,0 +1,11 @@ +isReadonly()) { + if ($this->isReadonlyClass($node)) { return null; } @@ -108,7 +108,7 @@ private function shouldSkip(Property $property, Class_ $class): bool return true; } - if ($this->isReadonly($property)) { + if ($this->isReadonlyProperty($property)) { return true; } @@ -121,7 +121,7 @@ private function shouldSkip(Property $property, Class_ $class): bool return $this->constructorAssignDetector->isPropertyAssigned($class, $propertyName); } - private function isReadonly(Property $property): bool + private function isReadonlyProperty(Property $property): bool { // native readonly if ($property->isReadonly()) { @@ -133,4 +133,17 @@ private function isReadonly(Property $property): bool $tags = $phpDocInfo->getTagsByName('@readonly'); return $tags !== []; } + + private function isReadonlyClass(Class_ $class): bool + { + // native readonly + if ($class->isReadonly()) { + return true; + } + + // @immutable annotation + $phpDocInfo = $this->phpDocInfoFactory->createFromNodeOrEmpty($class); + $tags = $phpDocInfo->getTagsByName('@immutable'); + return $tags !== []; + } }