mirror of
https://github.com/rectorphp/rector.git
synced 2025-02-22 18:54:39 +01:00
72 lines
3.1 KiB
PHP
72 lines
3.1 KiB
PHP
<?php
|
|
|
|
declare (strict_types=1);
|
|
namespace Rector\PostRector\DependencyInjection;
|
|
|
|
use PhpParser\Node\Stmt\Class_;
|
|
use PhpParser\Node\Stmt\Property;
|
|
use PHPStan\Type\ObjectType;
|
|
use PHPStan\Type\Type;
|
|
use PHPStan\Type\UnionType;
|
|
use Rector\ChangesReporting\Collector\RectorChangeCollector;
|
|
use Rector\Naming\Naming\PropertyNaming;
|
|
use Rector\NodeNameResolver\NodeNameResolver;
|
|
use Rector\NodeTypeResolver\Node\AttributeKey;
|
|
use Rector\NodeTypeResolver\NodeTypeResolver;
|
|
use Rector\PostRector\Collector\PropertyToAddCollector;
|
|
final class PropertyAdder
|
|
{
|
|
/**
|
|
* @var \Rector\NodeTypeResolver\NodeTypeResolver
|
|
*/
|
|
private $nodeTypeResolver;
|
|
/**
|
|
* @var \Rector\NodeNameResolver\NodeNameResolver
|
|
*/
|
|
private $nodeNameResolver;
|
|
/**
|
|
* @var \Rector\PostRector\Collector\PropertyToAddCollector
|
|
*/
|
|
private $propertyToAddCollector;
|
|
/**
|
|
* @var \Rector\ChangesReporting\Collector\RectorChangeCollector
|
|
*/
|
|
private $rectorChangeCollector;
|
|
/**
|
|
* @var \Rector\Naming\Naming\PropertyNaming
|
|
*/
|
|
private $propertyNaming;
|
|
public function __construct(\Rector\NodeTypeResolver\NodeTypeResolver $nodeTypeResolver, \Rector\NodeNameResolver\NodeNameResolver $nodeNameResolver, \Rector\PostRector\Collector\PropertyToAddCollector $propertyToAddCollector, \Rector\ChangesReporting\Collector\RectorChangeCollector $rectorChangeCollector, \Rector\Naming\Naming\PropertyNaming $propertyNaming)
|
|
{
|
|
$this->nodeTypeResolver = $nodeTypeResolver;
|
|
$this->nodeNameResolver = $nodeNameResolver;
|
|
$this->propertyToAddCollector = $propertyToAddCollector;
|
|
$this->rectorChangeCollector = $rectorChangeCollector;
|
|
$this->propertyNaming = $propertyNaming;
|
|
}
|
|
public function addPropertyToCollector(\PhpParser\Node\Stmt\Property $property) : void
|
|
{
|
|
$classNode = $property->getAttribute(\Rector\NodeTypeResolver\Node\AttributeKey::CLASS_NODE);
|
|
if (!$classNode instanceof \PhpParser\Node\Stmt\Class_) {
|
|
return;
|
|
}
|
|
$propertyType = $this->nodeTypeResolver->resolve($property);
|
|
// use first type - hard assumption @todo improve
|
|
if ($propertyType instanceof \PHPStan\Type\UnionType) {
|
|
$propertyType = $propertyType->getTypes()[0];
|
|
}
|
|
$propertyName = $this->nodeNameResolver->getName($property);
|
|
$this->addConstructorDependencyToClass($classNode, $propertyType, $propertyName, $property->flags);
|
|
}
|
|
public function addConstructorDependencyToClass(\PhpParser\Node\Stmt\Class_ $class, \PHPStan\Type\Type $propertyType, string $propertyName, int $propertyFlags = 0) : void
|
|
{
|
|
$this->propertyToAddCollector->addPropertyToClass($class, $propertyName, $propertyType, $propertyFlags);
|
|
$this->rectorChangeCollector->notifyNodeFileInfo($class);
|
|
}
|
|
public function addServiceConstructorDependencyToClass(\PhpParser\Node\Stmt\Class_ $class, \PHPStan\Type\ObjectType $objectType) : void
|
|
{
|
|
$propertyName = $this->propertyNaming->fqnToVariableName($objectType);
|
|
$this->addConstructorDependencyToClass($class, $objectType, $propertyName);
|
|
}
|
|
}
|