mirror of https://github.com/rectorphp/rector.git
61 lines
2.3 KiB
PHP
61 lines
2.3 KiB
PHP
<?php
|
|
|
|
declare (strict_types=1);
|
|
namespace Rector\Naming\ParamRenamer;
|
|
|
|
use PHPStan\PhpDocParser\Ast\PhpDoc\ParamTagValueNode;
|
|
use Rector\BetterPhpDocParser\PhpDocInfo\PhpDocInfo;
|
|
use Rector\BetterPhpDocParser\PhpDocInfo\PhpDocInfoFactory;
|
|
use Rector\BetterPhpDocParser\ValueObject\PhpDocAttributeKey;
|
|
use Rector\Comments\NodeDocBlock\DocBlockUpdater;
|
|
use Rector\Naming\ValueObject\ParamRename;
|
|
use Rector\Naming\VariableRenamer;
|
|
final class ParamRenamer
|
|
{
|
|
/**
|
|
* @readonly
|
|
* @var \Rector\Naming\VariableRenamer
|
|
*/
|
|
private $variableRenamer;
|
|
/**
|
|
* @readonly
|
|
* @var \Rector\Comments\NodeDocBlock\DocBlockUpdater
|
|
*/
|
|
private $docBlockUpdater;
|
|
/**
|
|
* @readonly
|
|
* @var \Rector\BetterPhpDocParser\PhpDocInfo\PhpDocInfoFactory
|
|
*/
|
|
private $phpDocInfoFactory;
|
|
public function __construct(VariableRenamer $variableRenamer, DocBlockUpdater $docBlockUpdater, PhpDocInfoFactory $phpDocInfoFactory)
|
|
{
|
|
$this->variableRenamer = $variableRenamer;
|
|
$this->docBlockUpdater = $docBlockUpdater;
|
|
$this->phpDocInfoFactory = $phpDocInfoFactory;
|
|
}
|
|
public function rename(ParamRename $paramRename) : void
|
|
{
|
|
// 1. rename param
|
|
$paramRename->getVariable()->name = $paramRename->getExpectedName();
|
|
// 2. rename param in the rest of the method
|
|
$this->variableRenamer->renameVariableInFunctionLike($paramRename->getFunctionLike(), $paramRename->getCurrentName(), $paramRename->getExpectedName(), null);
|
|
// 3. rename @param variable in docblock too
|
|
$this->renameParameterNameInDocBlock($paramRename);
|
|
}
|
|
private function renameParameterNameInDocBlock(ParamRename $paramRename) : void
|
|
{
|
|
$functionLike = $paramRename->getFunctionLike();
|
|
$phpDocInfo = $this->phpDocInfoFactory->createFromNode($functionLike);
|
|
if (!$phpDocInfo instanceof PhpDocInfo) {
|
|
return;
|
|
}
|
|
$paramTagValueNode = $phpDocInfo->getParamTagValueByName($paramRename->getCurrentName());
|
|
if (!$paramTagValueNode instanceof ParamTagValueNode) {
|
|
return;
|
|
}
|
|
$paramTagValueNode->parameterName = '$' . $paramRename->getExpectedName();
|
|
$paramTagValueNode->setAttribute(PhpDocAttributeKey::ORIG_NODE, null);
|
|
$this->docBlockUpdater->updateRefactoredNodeWithPhpDocInfo($functionLike);
|
|
}
|
|
}
|