rector/rules/Naming/AssignVariableNameResolver/PropertyFetchAssignVariableNameResolver.php
Tomas Votruba 503a6059f8 Updated Rector to commit a8922f7431c9c9188be501107ee7819e0130da4c
a8922f7431 skip temporarily match + throws downagrade in symfony/console, very unlikely to run
2023-06-11 23:01:39 +00:00

48 lines
1.4 KiB
PHP

<?php
declare (strict_types=1);
namespace Rector\Naming\AssignVariableNameResolver;
use PhpParser\Node;
use PhpParser\Node\Expr\PropertyFetch;
use Rector\Core\Exception\NotImplementedYetException;
use Rector\Naming\Contract\AssignVariableNameResolverInterface;
use Rector\NodeNameResolver\NodeNameResolver;
/**
* @implements AssignVariableNameResolverInterface<PropertyFetch>
*/
final class PropertyFetchAssignVariableNameResolver implements AssignVariableNameResolverInterface
{
/**
* @readonly
* @var \Rector\NodeNameResolver\NodeNameResolver
*/
private $nodeNameResolver;
public function __construct(NodeNameResolver $nodeNameResolver)
{
$this->nodeNameResolver = $nodeNameResolver;
}
public function match(Node $node) : bool
{
return $node instanceof PropertyFetch;
}
/**
* @param PropertyFetch $node
*/
public function resolve(Node $node) : string
{
$varName = $this->nodeNameResolver->getName($node->var);
if (!\is_string($varName)) {
throw new NotImplementedYetException();
}
$propertyName = $this->nodeNameResolver->getName($node->name);
if (!\is_string($propertyName)) {
throw new NotImplementedYetException();
}
if ($varName === 'this') {
return $propertyName;
}
return $varName . \ucfirst($propertyName);
}
}