rector/src/Configuration/RenamedClassesDataCollector.php
Tomas Votruba 91d829557e Updated Rector to commit 00af33a5d4
00af33a5d4 [Rectify] [Php81] Enable Rectify on ArraySpreadInsteadOfArrayMergeRector on php 8.1 (#1383)
2021-12-04 13:02:13 +00:00

55 lines
1.5 KiB
PHP

<?php
declare (strict_types=1);
namespace Rector\Core\Configuration;
use PHPStan\Type\ObjectType;
final class RenamedClassesDataCollector
{
/**
* @var array<string, string>
*/
private $oldToNewClasses = [];
public function addOldToNewClass(string $oldClass, string $newClass) : void
{
$this->oldToNewClasses[$oldClass] = $newClass;
}
public function hasOldClass(string $oldClass) : bool
{
return isset($this->oldToNewClasses[$oldClass]);
}
/**
* @param array<string, string> $oldToNewClasses
*/
public function addOldToNewClasses(array $oldToNewClasses) : void
{
$item0Unpacked = $this->oldToNewClasses;
/** @var array<string, string> $oldToNewClasses */
$oldToNewClasses = \array_merge($item0Unpacked, $oldToNewClasses);
$this->oldToNewClasses = $oldToNewClasses;
}
/**
* @return array<string, string>
*/
public function getOldToNewClasses() : array
{
return $this->oldToNewClasses;
}
public function matchClassName(\PHPStan\Type\ObjectType $objectType) : ?\PHPStan\Type\ObjectType
{
$className = $objectType->getClassName();
$renamedClassName = $this->oldToNewClasses[$className] ?? null;
if ($renamedClassName === null) {
return null;
}
return new \PHPStan\Type\ObjectType($renamedClassName);
}
/**
* @return string[]
*/
public function getOldClasses() : array
{
return \array_keys($this->oldToNewClasses);
}
}