rector/rules/naming/src/PropertyRenamer/PropertyFetchRenamer.php

62 lines
1.9 KiB
PHP
Raw Normal View History

<?php
declare(strict_types=1);
namespace Rector\Naming\PropertyRenamer;
use PhpParser\Node;
use PhpParser\Node\Expr\PropertyFetch;
use PhpParser\Node\Expr\StaticPropertyFetch;
use PhpParser\Node\Identifier;
use PhpParser\Node\Stmt\ClassLike;
use PhpParser\Node\VarLikeIdentifier;
use Rector\Core\PhpParser\NodeTraverser\CallableNodeTraverser;
use Rector\NodeNameResolver\NodeNameResolver;
final class PropertyFetchRenamer
{
/**
* @var CallableNodeTraverser
*/
private $callableNodeTraverser;
/**
* @var NodeNameResolver
*/
private $nodeNameResolver;
public function __construct(CallableNodeTraverser $callableNodeTraverser, NodeNameResolver $nodeNameResolver)
{
$this->callableNodeTraverser = $callableNodeTraverser;
$this->nodeNameResolver = $nodeNameResolver;
}
public function renamePropertyFetchesInClass(ClassLike $classLike, string $currentName, string $expectedName): void
{
// 1. replace property fetch rename in whole class
$this->callableNodeTraverser->traverseNodesWithCallable(
$classLike,
function (Node $node) use ($currentName, $expectedName): ?Node {
if ($this->nodeNameResolver->isLocalPropertyFetchNamed(
$node,
$currentName
) && $node instanceof PropertyFetch) {
$node->name = new Identifier($expectedName);
return $node;
}
if ($this->nodeNameResolver->isLocalStaticPropertyFetchNamed($node, $currentName)) {
if (! $node instanceof StaticPropertyFetch) {
return null;
}
$node->name = new VarLikeIdentifier($expectedName);
return $node;
}
return null;
}
);
}
}