2019-10-13 05:59:52 +00:00
< ? php
2021-05-09 20:15:43 +00:00
declare ( strict_types = 1 );
2022-06-06 17:12:56 +00:00
namespace Rector\Renaming\Rector\StaticCall ;
2018-08-10 19:06:40 +00:00
2022-06-06 17:12:56 +00:00
use PhpParser\Node ;
use PhpParser\Node\Expr\StaticCall ;
use PhpParser\Node\Identifier ;
use PhpParser\Node\Name\FullyQualified ;
2024-01-02 02:40:38 +00:00
use Rector\Contract\Rector\ConfigurableRectorInterface ;
use Rector\Rector\AbstractRector ;
2022-06-06 17:12:56 +00:00
use Rector\Renaming\ValueObject\RenameStaticMethod ;
2022-06-07 09:18:30 +00:00
use Symplify\RuleDocGenerator\ValueObject\CodeSample\ConfiguredCodeSample ;
use Symplify\RuleDocGenerator\ValueObject\RuleDefinition ;
2024-03-01 20:02:28 +00:00
use RectorPrefix202403\Webmozart\Assert\Assert ;
2019-09-03 09:11:45 +00:00
/**
2021-03-12 22:20:25 +00:00
* @ see \Rector\Tests\Renaming\Rector\StaticCall\RenameStaticMethodRector\RenameStaticMethodRectorTest
2019-09-03 09:11:45 +00:00
*/
2022-06-07 08:22:29 +00:00
final class RenameStaticMethodRector extends AbstractRector implements ConfigurableRectorInterface
2018-08-10 19:06:40 +00:00
{
2020-08-23 09:39:09 +00:00
/**
2020-09-12 21:19:08 +00:00
* @ var RenameStaticMethod []
2020-08-23 09:39:09 +00:00
*/
private $staticMethodRenames = [];
2022-06-07 08:22:29 +00:00
public function getRuleDefinition () : RuleDefinition
2018-08-10 19:06:40 +00:00
{
2022-06-07 08:22:29 +00:00
return new RuleDefinition ( 'Turns method names to new ones.' , [ new ConfiguredCodeSample ( 'SomeClass::oldStaticMethod();' , 'AnotherExampleClass::newStaticMethod();' , [ new RenameStaticMethod ( 'SomeClass' , 'oldMethod' , 'AnotherExampleClass' , 'newStaticMethod' )])]);
2018-08-10 19:06:40 +00:00
}
2018-08-14 22:12:41 +00:00
/**
2021-02-27 00:06:15 +00:00
* @ return array < class - string < Node >>
2018-08-14 22:12:41 +00:00
*/
2021-05-09 20:15:43 +00:00
public function getNodeTypes () : array
2018-08-10 19:06:40 +00:00
{
2022-06-07 08:22:29 +00:00
return [ StaticCall :: class ];
2018-08-10 19:06:40 +00:00
}
/**
2021-12-10 10:22:23 +00:00
* @ param StaticCall $node
2018-08-10 19:06:40 +00:00
*/
2022-06-07 08:22:29 +00:00
public function refactor ( Node $node ) : ? Node
2018-08-10 19:06:40 +00:00
{
2020-08-23 09:39:09 +00:00
foreach ( $this -> staticMethodRenames as $staticMethodRename ) {
2023-03-22 14:20:22 +00:00
if ( ! $this -> isName ( $node -> name , $staticMethodRename -> getOldMethod ())) {
2018-10-22 18:12:32 +00:00
continue ;
}
2023-03-22 14:20:22 +00:00
if ( ! $this -> isObjectType ( $node -> class , $staticMethodRename -> getOldObjectType ())) {
2020-08-23 09:39:09 +00:00
continue ;
2018-08-10 19:06:40 +00:00
}
2020-08-23 09:39:09 +00:00
return $this -> rename ( $node , $staticMethodRename );
2018-08-10 19:06:40 +00:00
}
2018-10-22 18:12:32 +00:00
return null ;
2018-08-10 19:06:40 +00:00
}
2021-05-02 10:46:55 +00:00
/**
2021-11-28 17:01:20 +00:00
* @ param mixed [] $configuration
2021-05-02 10:46:55 +00:00
*/
2021-12-10 10:22:23 +00:00
public function configure ( array $configuration ) : void
2020-07-29 13:55:33 +00:00
{
2022-06-07 08:22:29 +00:00
Assert :: allIsAOf ( $configuration , RenameStaticMethod :: class );
2022-02-18 01:46:17 +00:00
$this -> staticMethodRenames = $configuration ;
2020-07-29 13:55:33 +00:00
}
2022-06-07 08:22:29 +00:00
private function rename ( StaticCall $staticCall , RenameStaticMethod $renameStaticMethod ) : StaticCall
2018-08-10 19:06:40 +00:00
{
2022-06-07 08:22:29 +00:00
$staticCall -> name = new Identifier ( $renameStaticMethod -> getNewMethod ());
2020-09-12 21:19:08 +00:00
if ( $renameStaticMethod -> hasClassChanged ()) {
2022-06-07 08:22:29 +00:00
$staticCall -> class = new FullyQualified ( $renameStaticMethod -> getNewClass ());
2018-08-10 19:06:40 +00:00
}
2019-02-22 17:25:31 +00:00
return $staticCall ;
2018-08-10 19:06:40 +00:00
}
}