Skip to content

Commit

Permalink
Rector 0.18.0
Browse files Browse the repository at this point in the history
  • Loading branch information
TomasVotruba committed Aug 17, 2023
1 parent b8fef75 commit 758ada2
Show file tree
Hide file tree
Showing 8 changed files with 50 additions and 35 deletions.
44 changes: 35 additions & 9 deletions src/Application/ApplicationFileProcessor.php
Original file line number Diff line number Diff line change
Expand Up @@ -5,6 +5,7 @@

use RectorPrefix202308\Nette\Utils\FileSystem as UtilsFileSystem;
use Rector\Caching\Detector\ChangedFilesDetector;
use Rector\Core\Application\FileProcessor\PhpFileProcessor;
use Rector\Core\Configuration\Option;
use Rector\Core\Configuration\Parameter\SimpleParameterProvider;
use Rector\Core\Contract\Processor\FileProcessorInterface;
Expand Down Expand Up @@ -67,6 +68,11 @@ final class ApplicationFileProcessor
* @var \Rector\Core\Provider\CurrentFileProvider
*/
private $currentFileProvider;
/**
* @readonly
* @var \Rector\Core\Application\FileProcessor\PhpFileProcessor
*/
private $phpFileProcessor;
/**
* @var FileProcessorInterface[]
* @readonly
Expand All @@ -83,7 +89,7 @@ final class ApplicationFileProcessor
/**
* @param FileProcessorInterface[] $fileProcessors
*/
public function __construct(SymfonyStyle $symfonyStyle, FileFactory $fileFactory, ArrayParametersMerger $arrayParametersMerger, ParallelFileProcessor $parallelFileProcessor, ScheduleFactory $scheduleFactory, CpuCoreCountProvider $cpuCoreCountProvider, ChangedFilesDetector $changedFilesDetector, CurrentFileProvider $currentFileProvider, array $fileProcessors)
public function __construct(SymfonyStyle $symfonyStyle, FileFactory $fileFactory, ArrayParametersMerger $arrayParametersMerger, ParallelFileProcessor $parallelFileProcessor, ScheduleFactory $scheduleFactory, CpuCoreCountProvider $cpuCoreCountProvider, ChangedFilesDetector $changedFilesDetector, CurrentFileProvider $currentFileProvider, PhpFileProcessor $phpFileProcessor, array $fileProcessors)
{
$this->symfonyStyle = $symfonyStyle;
$this->fileFactory = $fileFactory;
Expand All @@ -93,12 +99,17 @@ public function __construct(SymfonyStyle $symfonyStyle, FileFactory $fileFactory
$this->cpuCoreCountProvider = $cpuCoreCountProvider;
$this->changedFilesDetector = $changedFilesDetector;
$this->currentFileProvider = $currentFileProvider;
$this->phpFileProcessor = $phpFileProcessor;
$this->fileProcessors = $fileProcessors;
$fileProcessorClasses = [];
foreach ($this->fileProcessors as $fileProcessor) {
\trigger_error(\sprintf('Rector will support only PHP, as that is the only code the AST can handle.%sThe custom "%s" file processor will not be supported, and should be refactored into own tool with file finder/printer.', \PHP_EOL, \get_class($fileProcessor)) . \PHP_EOL . \PHP_EOL, \E_USER_WARNING);
// to notice
\sleep(2);
}
foreach ($fileProcessors as $fileProcessor) {
$fileProcessorClasses[] = \get_class($fileProcessor);
}
Assert::notEmpty($fileProcessorClasses);
Assert::uniqueValues($fileProcessorClasses);
}
/**
Expand Down Expand Up @@ -161,13 +172,11 @@ public function processFiles(array $filePaths, Configuration $configuration, boo
private function processFile(File $file, array $systemErrorsAndFileDiffs, Configuration $configuration) : array
{
$this->currentFileProvider->setFile($file);
foreach ($this->fileProcessors as $fileProcessor) {
if (!$fileProcessor->supports($file, $configuration)) {
continue;
}
$result = $fileProcessor->process($file, $configuration);
$systemErrorsAndFileDiffs = $this->arrayParametersMerger->merge($systemErrorsAndFileDiffs, $result);
}
// BC layer, soon the file processors will be removed
$otherSystemErrorsAndFileDiffs = $this->processWithFileProcessors($file, $configuration, $systemErrorsAndFileDiffs);
$systemErrorsAndFileDiffs = $this->arrayParametersMerger->merge($systemErrorsAndFileDiffs, $otherSystemErrorsAndFileDiffs);
$phpSystemErrorsAndFileDiffs = $this->phpFileProcessor->process($file, $configuration);
$systemErrorsAndFileDiffs = $this->arrayParametersMerger->merge($systemErrorsAndFileDiffs, $phpSystemErrorsAndFileDiffs);
if ($systemErrorsAndFileDiffs[Bridge::SYSTEM_ERRORS] !== []) {
$this->changedFilesDetector->invalidateFile($file->getFilePath());
} elseif (!$configuration->isDryRun() || $systemErrorsAndFileDiffs[Bridge::FILE_DIFFS] === []) {
Expand Down Expand Up @@ -251,4 +260,21 @@ private function resolveCalledRectorBinary() : ?string
}
return $potentialEcsBinaryPath;
}
/**
* @deprecated Custom file processors are deprecated. Use custom tool instead.
*
* @param array{system_errors: SystemError[], file_diffs: FileDiff[], system_errors_count: int} $systemErrorsAndFileDiffs
* @return array{system_errors: SystemError[], file_diffs: FileDiff[], system_errors_count: int}
*/
private function processWithFileProcessors(File $file, Configuration $configuration, array $systemErrorsAndFileDiffs)
{
foreach ($this->fileProcessors as $fileProcessor) {
if (!$fileProcessor->supports($file, $configuration)) {
continue;
}
$result = $fileProcessor->process($file, $configuration);
$systemErrorsAndFileDiffs = $this->arrayParametersMerger->merge($systemErrorsAndFileDiffs, $result);
}
return $systemErrorsAndFileDiffs;
}
}
14 changes: 1 addition & 13 deletions src/Application/FileProcessor/PhpFileProcessor.php
Original file line number Diff line number Diff line change
Expand Up @@ -9,7 +9,6 @@
use Rector\ChangesReporting\ValueObjectFactory\ErrorFactory;
use Rector\ChangesReporting\ValueObjectFactory\FileDiffFactory;
use Rector\Core\Application\FileProcessor;
use Rector\Core\Contract\Processor\FileProcessorInterface;
use Rector\Core\Exception\ShouldNotHappenException;
use Rector\Core\FileSystem\FilePathHelper;
use Rector\Core\PhpParser\Printer\FormatPerservingPrinter;
Expand All @@ -22,7 +21,7 @@
use Rector\Testing\PHPUnit\StaticPHPUnitEnvironment;
use RectorPrefix202308\Symfony\Component\Console\Style\SymfonyStyle;
use Throwable;
final class PhpFileProcessor implements FileProcessorInterface
final class PhpFileProcessor
{
/**
* @readonly
Expand Down Expand Up @@ -128,17 +127,6 @@ public function process(File $file, Configuration $configuration) : array
$systemErrorsAndFileDiffs[Bridge::FILE_DIFFS] = [$fileDiff];
return $systemErrorsAndFileDiffs;
}
public function supports(File $file, Configuration $configuration) : bool
{
return \true;
}
/**
* @return string[]
*/
public function getSupportedFileExtensions() : array
{
return ['php'];
}
/**
* @return SystemError[]
*/
Expand Down
4 changes: 2 additions & 2 deletions src/Application/VersionResolver.php
Original file line number Diff line number Diff line change
Expand Up @@ -19,12 +19,12 @@ final class VersionResolver
* @api
* @var string
*/
public const PACKAGE_VERSION = 'dc580ae1bb540eed78d915db46168b39c1469b42';
public const PACKAGE_VERSION = '0.18.0';
/**
* @api
* @var string
*/
public const RELEASE_DATE = '2023-08-17 13:11:59';
public const RELEASE_DATE = '2023-08-17 14:49:44';
/**
* @var int
*/
Expand Down
2 changes: 2 additions & 0 deletions src/Contract/Processor/FileProcessorInterface.php
Original file line number Diff line number Diff line change
Expand Up @@ -9,6 +9,8 @@
use Rector\Core\ValueObject\Reporting\FileDiff;
/**
* @internal
*
* @deprecated This interface should not be used, as Rector will handle PHP code only. Use custom file processor with own finder instead for any non-PHP changes.
*/
interface FileProcessorInterface
{
Expand Down
1 change: 0 additions & 1 deletion src/DependencyInjection/LazyContainerFactory.php
Original file line number Diff line number Diff line change
Expand Up @@ -292,7 +292,6 @@ public function create() : RectorConfig
}
$rectorConfig->alias(TypeParser::class, BetterTypeParser::class);
$rectorConfig->singleton(PhpFileProcessor::class);
$rectorConfig->tag(PhpFileProcessor::class, FileProcessorInterface::class);
$rectorConfig->singleton(PostFileProcessor::class);
if (\class_exists(InitRecipeCommand::class)) {
$rectorConfig->tag(InitRecipeCommand::class, Command::class);
Expand Down
2 changes: 1 addition & 1 deletion vendor/autoload.php
Original file line number Diff line number Diff line change
Expand Up @@ -22,4 +22,4 @@

require_once __DIR__ . '/composer/autoload_real.php';

return ComposerAutoloaderInit09bf9b7ae79c8d3442a2002158653e4a::getLoader();
return ComposerAutoloaderInitae1b297561b2af333af4101d3842f5ee::getLoader();
10 changes: 5 additions & 5 deletions vendor/composer/autoload_real.php
Original file line number Diff line number Diff line change
Expand Up @@ -2,7 +2,7 @@

// autoload_real.php @generated by Composer

class ComposerAutoloaderInit09bf9b7ae79c8d3442a2002158653e4a
class ComposerAutoloaderInitae1b297561b2af333af4101d3842f5ee
{
private static $loader;

Expand All @@ -22,17 +22,17 @@ public static function getLoader()
return self::$loader;
}

spl_autoload_register(array('ComposerAutoloaderInit09bf9b7ae79c8d3442a2002158653e4a', 'loadClassLoader'), true, true);
spl_autoload_register(array('ComposerAutoloaderInitae1b297561b2af333af4101d3842f5ee', 'loadClassLoader'), true, true);
self::$loader = $loader = new \Composer\Autoload\ClassLoader(\dirname(__DIR__));
spl_autoload_unregister(array('ComposerAutoloaderInit09bf9b7ae79c8d3442a2002158653e4a', 'loadClassLoader'));
spl_autoload_unregister(array('ComposerAutoloaderInitae1b297561b2af333af4101d3842f5ee', 'loadClassLoader'));

require __DIR__ . '/autoload_static.php';
call_user_func(\Composer\Autoload\ComposerStaticInit09bf9b7ae79c8d3442a2002158653e4a::getInitializer($loader));
call_user_func(\Composer\Autoload\ComposerStaticInitae1b297561b2af333af4101d3842f5ee::getInitializer($loader));

$loader->setClassMapAuthoritative(true);
$loader->register(true);

$filesToLoad = \Composer\Autoload\ComposerStaticInit09bf9b7ae79c8d3442a2002158653e4a::$files;
$filesToLoad = \Composer\Autoload\ComposerStaticInitae1b297561b2af333af4101d3842f5ee::$files;
$requireFile = \Closure::bind(static function ($fileIdentifier, $file) {
if (empty($GLOBALS['__composer_autoload_files'][$fileIdentifier])) {
$GLOBALS['__composer_autoload_files'][$fileIdentifier] = true;
Expand Down
8 changes: 4 additions & 4 deletions vendor/composer/autoload_static.php
Original file line number Diff line number Diff line change
Expand Up @@ -4,7 +4,7 @@

namespace Composer\Autoload;

class ComposerStaticInit09bf9b7ae79c8d3442a2002158653e4a
class ComposerStaticInitae1b297561b2af333af4101d3842f5ee
{
public static $files = array (
'ad155f8f1cf0d418fe49e248db8c661b' => __DIR__ . '/..' . '/react/promise/src/functions_include.php',
Expand Down Expand Up @@ -2638,9 +2638,9 @@ class ComposerStaticInit09bf9b7ae79c8d3442a2002158653e4a
public static function getInitializer(ClassLoader $loader)
{
return \Closure::bind(function () use ($loader) {
$loader->prefixLengthsPsr4 = ComposerStaticInit09bf9b7ae79c8d3442a2002158653e4a::$prefixLengthsPsr4;
$loader->prefixDirsPsr4 = ComposerStaticInit09bf9b7ae79c8d3442a2002158653e4a::$prefixDirsPsr4;
$loader->classMap = ComposerStaticInit09bf9b7ae79c8d3442a2002158653e4a::$classMap;
$loader->prefixLengthsPsr4 = ComposerStaticInitae1b297561b2af333af4101d3842f5ee::$prefixLengthsPsr4;
$loader->prefixDirsPsr4 = ComposerStaticInitae1b297561b2af333af4101d3842f5ee::$prefixDirsPsr4;
$loader->classMap = ComposerStaticInitae1b297561b2af333af4101d3842f5ee::$classMap;

}, null, ClassLoader::class);
}
Expand Down

0 comments on commit 758ada2

Please sign in to comment.