mirror of https://github.com/rectorphp/rector.git
41 lines
1.3 KiB
PHP
41 lines
1.3 KiB
PHP
<?php
|
|
|
|
declare (strict_types=1);
|
|
namespace Rector\Naming\NamingConvention;
|
|
|
|
use PhpParser\Node\Expr\FuncCall;
|
|
use PhpParser\Node\Expr\MethodCall;
|
|
use PhpParser\Node\Expr\StaticCall;
|
|
use Rector\NodeNameResolver\NodeNameResolver;
|
|
use Rector\Util\StringUtils;
|
|
final class NamingConventionAnalyzer
|
|
{
|
|
/**
|
|
* @readonly
|
|
* @var \Rector\NodeNameResolver\NodeNameResolver
|
|
*/
|
|
private $nodeNameResolver;
|
|
public function __construct(NodeNameResolver $nodeNameResolver)
|
|
{
|
|
$this->nodeNameResolver = $nodeNameResolver;
|
|
}
|
|
/**
|
|
* Matches cases:
|
|
*
|
|
* $someNameSuffix = $this->getSomeName();
|
|
* $prefixSomeName = $this->getSomeName();
|
|
* $someName = $this->getSomeName();
|
|
* @param \PhpParser\Node\Expr\FuncCall|\PhpParser\Node\Expr\StaticCall|\PhpParser\Node\Expr\MethodCall $expr
|
|
*/
|
|
public function isCallMatchingVariableName($expr, string $currentName, string $expectedName) : bool
|
|
{
|
|
// skip "$call = $method->call();" based conventions
|
|
$callName = $this->nodeNameResolver->getName($expr->name);
|
|
if ($currentName === $callName) {
|
|
return \true;
|
|
}
|
|
// starts with or ends with
|
|
return StringUtils::isMatch($currentName, '#^(' . $expectedName . '|' . $expectedName . '$)#i');
|
|
}
|
|
}
|