1<?php 2 3declare(strict_types=1); 4 5use Rector\Caching\ValueObject\Storage\FileCacheStorage; 6use Rector\CodeQuality\Rector\Array_\CallableThisArrayToAnonymousFunctionRector; 7use Rector\CodeQuality\Rector\Concat\JoinStringConcatRector; 8use Rector\CodeQuality\Rector\FunctionLike\SimplifyUselessVariableRector; 9use Rector\CodeQuality\Rector\If_\CombineIfRector; 10use Rector\CodeQuality\Rector\If_\ExplicitBoolCompareRector; 11use Rector\CodeQuality\Rector\If_\SimplifyIfElseToTernaryRector; 12use Rector\CodeQuality\Rector\If_\SimplifyIfReturnBoolRector; 13use Rector\CodeQuality\Rector\Isset_\IssetOnPropertyObjectToPropertyExistsRector; 14use Rector\CodingStyle\Rector\Catch_\CatchExceptionNameMatchingTypeRector; 15use Rector\CodingStyle\Rector\Class_\AddArrayDefaultToArrayPropertyRector; 16use Rector\CodingStyle\Rector\Closure\StaticClosureRector; 17use Rector\CodingStyle\Rector\Encapsed\EncapsedStringsToSprintfRector; 18use Rector\CodingStyle\Rector\Encapsed\WrapEncapsedVariableInCurlyBracesRector; 19use Rector\CodingStyle\Rector\FuncCall\StrictArraySearchRector; 20use Rector\CodingStyle\Rector\PostInc\PostIncDecToPreIncDecRector; 21use Rector\CodingStyle\Rector\Stmt\NewlineAfterStatementRector; 22use Rector\CodingStyle\Rector\String_\SymplifyQuoteEscapeRector; 23use Rector\Config\RectorConfig; 24use Rector\DeadCode\Rector\ClassMethod\RemoveUselessParamTagRector; 25use Rector\DeadCode\Rector\For_\RemoveDeadContinueRector; 26use Rector\DeadCode\Rector\For_\RemoveDeadIfForeachForRector; 27use Rector\DeadCode\Rector\If_\RemoveAlwaysTrueIfConditionRector; 28use Rector\DeadCode\Rector\If_\RemoveUnusedNonEmptyArrayBeforeForeachRector; 29use Rector\DeadCode\Rector\Property\RemoveUselessVarTagRector; 30use Rector\DeadCode\Rector\StaticCall\RemoveParentCallWithoutParentRector; 31use Rector\DeadCode\Rector\Stmt\RemoveUnreachableStatementRector; 32use Rector\Php71\Rector\ClassConst\PublicConstantVisibilityRector; 33use Rector\Php71\Rector\FuncCall\CountOnNullRector; 34use Rector\Php71\Rector\FuncCall\RemoveExtraParametersRector; 35use Rector\Set\ValueObject\LevelSetList; 36use Rector\Set\ValueObject\SetList; 37use Rector\Strict\Rector\Empty_\DisallowedEmptyRuleFixerRector; 38use Rector\TypeDeclaration\Rector\Property\TypedPropertyFromAssignsRector; 39 40return static function (RectorConfig $rectorConfig): void { 41 $rectorConfig->paths([ 42 __DIR__ . '/../inc', 43 __DIR__ . '/../lib', 44 ]); 45 46 $rectorConfig->bootstrapFiles([ 47 __DIR__ . '/../inc/init.php', 48 ]); 49 50 $rectorConfig->importNames(); 51 $rectorConfig->importShortClasses(false); 52 $rectorConfig->cacheClass(FileCacheStorage::class); 53 $rectorConfig->cacheDirectory(__DIR__ . '/.rector-cache'); 54 55 // define sets of rules 56 $rectorConfig->sets([ 57 LevelSetList::UP_TO_PHP_74, 58 SetList::CODE_QUALITY, 59 SetList::DEAD_CODE, 60 SetList::CODING_STYLE, 61 ]); 62 63 $rectorConfig->skip([ 64 // skip paths 65 __DIR__ . '/../inc/lang/*', 66 __DIR__ . '/../lib/plugins/*/_test/*', 67 __DIR__ . '/../lib/tpl/*/_test/*', 68 __DIR__ . '/../lib/plugins/*/lang/*', 69 __DIR__ . '/../lib/tpl/*/lang/*', 70 __DIR__ . '/../lib/plugins/*/vendor/*', 71 __DIR__ . '/../lib/tpl/*/vendor/*', 72 __DIR__ . '/../lib/plugins/*/skel/*', // dev plugin 73 __DIR__ . '/../inc/deprecated.php', 74 __DIR__ . '/../inc/form.php', 75 76 // third party libs, not yet moved to composer 77 __DIR__ . '/../inc/DifferenceEngine.php', 78 __DIR__ . '/../inc/JpegMeta.php', 79 __DIR__ . '/../lib/plugins/authad/adLDAP', 80 81 // skip rules 82 SimplifyIfElseToTernaryRector::class, 83 NewlineAfterStatementRector::class, 84 CombineIfRector::class, 85 ExplicitBoolCompareRector::class, 86 IssetOnPropertyObjectToPropertyExistsRector::class, // maybe? 87 SymplifyQuoteEscapeRector::class, 88 CatchExceptionNameMatchingTypeRector::class, 89 PublicConstantVisibilityRector::class, // open for discussion 90 EncapsedStringsToSprintfRector::class, 91 CallableThisArrayToAnonymousFunctionRector::class, 92 StaticClosureRector::class, 93 SimplifyUselessVariableRector::class, // seems to strip constructor property initializations 94 PostIncDecToPreIncDecRector::class, 95 RemoveUselessParamTagRector::class, 96 DisallowedEmptyRuleFixerRector::class, 97 CountOnNullRector::class, // adds unwanted is_countable checks? 98 RemoveParentCallWithoutParentRector::class, 99 WrapEncapsedVariableInCurlyBracesRector::class, 100 SimplifyIfReturnBoolRector::class, 101 StrictArraySearchRector::class, // we cannot assume strict search is always wanted 102 AddArrayDefaultToArrayPropertyRector::class, // may break code differentiating between null and empty array 103 RemoveUselessVarTagRector::class, 104 TypedPropertyFromAssignsRector::class, // maybe? 105 JoinStringConcatRector::class, // this does not count variables, so it creates overlong lines 106 RemoveExtraParametersRector::class, // this actually broke code 107 RemoveUnusedNonEmptyArrayBeforeForeachRector::class, // seems unreliable when checking on array keys 108 RemoveAlwaysTrueIfConditionRector::class, // fails with if(defined(...)) constructs 109 ]); 110}; 111