rector/rules/Privatization/NodeFactory/ClassConstantFetchValueFactory.php
Tomas Votruba 67d83c7b32 Updated Rector to commit 4e377b26af1762f9fb8c968341df5d742ec0160f
4e377b26af Add option of case-insensitive ReplaceStringWithClassConstantRector (#1004)
2021-10-15 16:34:45 +00:00

54 lines
1.9 KiB
PHP

<?php
declare (strict_types=1);
namespace Rector\Privatization\NodeFactory;
use PhpParser\Node\Expr;
use PhpParser\Node\Expr\ClassConstFetch;
use Rector\Core\PhpParser\Node\NodeFactory;
use Rector\Core\PhpParser\Node\Value\ValueResolver;
use Rector\Privatization\Reflection\ClassConstantsResolver;
final class ClassConstantFetchValueFactory
{
/**
* @var \Rector\Core\PhpParser\Node\Value\ValueResolver
*/
private $valueResolver;
/**
* @var \Rector\Core\PhpParser\Node\NodeFactory
*/
private $nodeFactory;
/**
* @var \Rector\Privatization\Reflection\ClassConstantsResolver
*/
private $classConstantsResolver;
public function __construct(\Rector\Core\PhpParser\Node\Value\ValueResolver $valueResolver, \Rector\Core\PhpParser\Node\NodeFactory $nodeFactory, \Rector\Privatization\Reflection\ClassConstantsResolver $classConstantsResolver)
{
$this->valueResolver = $valueResolver;
$this->nodeFactory = $nodeFactory;
$this->classConstantsResolver = $classConstantsResolver;
}
/**
* @param class-string $classWithConstants
*/
public function create(\PhpParser\Node\Expr $expr, string $classWithConstants, bool $caseInsensitive) : ?\PhpParser\Node\Expr\ClassConstFetch
{
$value = $this->valueResolver->getValue($expr);
if ($value === null) {
return null;
}
$constantNamesToValues = $this->classConstantsResolver->getClassConstantNamesToValues($classWithConstants);
foreach ($constantNamesToValues as $constantName => $constantValue) {
if ($caseInsensitive) {
$constantValue = \strtolower($constantValue);
$value = \strtolower($value);
}
if ($constantValue !== $value) {
continue;
}
return $this->nodeFactory->createClassConstFetch($classWithConstants, $constantName);
}
return null;
}
}