mirror of
https://github.com/rectorphp/rector.git
synced 2024-06-13 14:42:23 +00:00
074b1781b3
Remove RemoveUnusedVariableAssignRector, as could be breaking code in order of excution and hard to do reliable (#3793)
108 lines
4.2 KiB
PHP
108 lines
4.2 KiB
PHP
<?php
|
|
|
|
declare (strict_types=1);
|
|
namespace Rector\Symfony\Rector\MethodCall;
|
|
|
|
use PhpParser\Node;
|
|
use PhpParser\Node\Expr\MethodCall;
|
|
use PhpParser\Node\Expr\StaticCall;
|
|
use PHPStan\Reflection\ReflectionProvider;
|
|
use PHPStan\Type\ObjectType;
|
|
use Rector\Core\Rector\AbstractRector;
|
|
use Rector\Symfony\NodeAnalyzer\LiteralCallLikeConstFetchReplacer;
|
|
use Rector\Symfony\ValueObject\ConstantMap\SymfonyRequestConstantMap;
|
|
use Symplify\RuleDocGenerator\ValueObject\CodeSample\CodeSample;
|
|
use Symplify\RuleDocGenerator\ValueObject\RuleDefinition;
|
|
/**
|
|
* @see \Rector\Symfony\Tests\Rector\MethodCall\LiteralGetToRequestClassConstantRector\LiteralGetToRequestClassConstantRectorTest
|
|
*/
|
|
final class LiteralGetToRequestClassConstantRector extends AbstractRector
|
|
{
|
|
/**
|
|
* @readonly
|
|
* @var \Rector\Symfony\NodeAnalyzer\LiteralCallLikeConstFetchReplacer
|
|
*/
|
|
private $literalCallLikeConstFetchReplacer;
|
|
/**
|
|
* @readonly
|
|
* @var \PHPStan\Reflection\ReflectionProvider
|
|
*/
|
|
private $reflectionProvider;
|
|
public function __construct(LiteralCallLikeConstFetchReplacer $literalCallLikeConstFetchReplacer, ReflectionProvider $reflectionProvider)
|
|
{
|
|
$this->literalCallLikeConstFetchReplacer = $literalCallLikeConstFetchReplacer;
|
|
$this->reflectionProvider = $reflectionProvider;
|
|
}
|
|
public function getRuleDefinition() : RuleDefinition
|
|
{
|
|
return new RuleDefinition('Replace "GET" string by Symfony Request object class constants', [new CodeSample(<<<'CODE_SAMPLE'
|
|
use Symfony\Component\Form\FormBuilderInterface;
|
|
|
|
final class SomeClass
|
|
{
|
|
public function detail(FormBuilderInterface $formBuilder)
|
|
{
|
|
$formBuilder->setMethod('GET');
|
|
}
|
|
}
|
|
CODE_SAMPLE
|
|
, <<<'CODE_SAMPLE'
|
|
use Symfony\Component\Form\FormBuilderInterface;
|
|
|
|
final class SomeClass
|
|
{
|
|
public function detail(FormBuilderInterface $formBuilder)
|
|
{
|
|
$formBuilder->setMethod(\Symfony\Component\HttpFoundation\Request::GET);
|
|
}
|
|
}
|
|
CODE_SAMPLE
|
|
)]);
|
|
}
|
|
/**
|
|
* @return array<class-string<Node>>
|
|
*/
|
|
public function getNodeTypes() : array
|
|
{
|
|
return [MethodCall::class, StaticCall::class];
|
|
}
|
|
/**
|
|
* @param MethodCall|StaticCall $node
|
|
*/
|
|
public function refactor(Node $node) : ?Node
|
|
{
|
|
if ($node instanceof StaticCall) {
|
|
return $this->refactorStaticCall($node);
|
|
}
|
|
// for client, the transitional dependency to browser-kit might be missing and cause fatal error on PHPStan reflection
|
|
// in most cases that should be skipped, @changelog https://github.com/rectorphp/rector/issues/7135
|
|
if ($this->reflectionProvider->hasClass('Symfony\\Component\\BrowserKit\\AbstractBrowser') && $this->isObjectType($node->var, new ObjectType('Symfony\\Component\\HttpKernel\\Client'))) {
|
|
return $this->refactorClientMethodCall($node);
|
|
}
|
|
if (!$this->isName($node->name, 'setMethod')) {
|
|
return null;
|
|
}
|
|
if (!$this->isObjectType($node->var, new ObjectType('Symfony\\Component\\Form\\FormBuilderInterface'))) {
|
|
return null;
|
|
}
|
|
return $this->literalCallLikeConstFetchReplacer->replaceArgOnPosition($node, 0, 'Symfony\\Component\\HttpFoundation\\Request', SymfonyRequestConstantMap::METHOD_TO_CONST);
|
|
}
|
|
private function refactorStaticCall(StaticCall $staticCall) : ?\PhpParser\Node\Expr\StaticCall
|
|
{
|
|
if (!$this->isName($staticCall->name, 'create')) {
|
|
return null;
|
|
}
|
|
if (!$this->isObjectType($staticCall->class, new ObjectType('Symfony\\Component\\HttpFoundation\\Request'))) {
|
|
return null;
|
|
}
|
|
return $this->literalCallLikeConstFetchReplacer->replaceArgOnPosition($staticCall, 1, 'Symfony\\Component\\HttpFoundation\\Request', SymfonyRequestConstantMap::METHOD_TO_CONST);
|
|
}
|
|
private function refactorClientMethodCall(MethodCall $methodCall) : ?\PhpParser\Node\Expr\MethodCall
|
|
{
|
|
if (!$this->isName($methodCall->name, 'request')) {
|
|
return null;
|
|
}
|
|
return $this->literalCallLikeConstFetchReplacer->replaceArgOnPosition($methodCall, 0, 'Symfony\\Component\\HttpFoundation\\Request', SymfonyRequestConstantMap::METHOD_TO_CONST);
|
|
}
|
|
}
|