mirror of
https://github.com/rectorphp/rector.git
synced 2025-01-17 21:38:22 +01:00
Updated Rector to commit 185ee1b473147fd620d3da2c42eb52b1756f2a18
185ee1b473
[DX] Add strict PHPStan rules - step #4 (#1333)
This commit is contained in:
parent
b426e4ba33
commit
11660d59a5
@ -168,7 +168,7 @@ final class PhpDocInfoPrinter
|
||||
$output = '/**' . $output;
|
||||
}
|
||||
// fix missing end
|
||||
if (\Rector\Core\Util\StringUtils::isMatch($output, self::OPENING_DOCBLOCK_REGEX) && $output && !\Rector\Core\Util\StringUtils::isMatch($output, self::CLOSING_DOCBLOCK_REGEX)) {
|
||||
if (\Rector\Core\Util\StringUtils::isMatch($output, self::OPENING_DOCBLOCK_REGEX) && !\Rector\Core\Util\StringUtils::isMatch($output, self::CLOSING_DOCBLOCK_REGEX)) {
|
||||
$output .= ' */';
|
||||
}
|
||||
return $output;
|
||||
@ -212,7 +212,10 @@ final class PhpDocInfoPrinter
|
||||
}
|
||||
private function printEnd(string $output) : string
|
||||
{
|
||||
$lastTokenPosition = $this->getCurrentPhpDocInfo()->getPhpDocNode()->getAttribute(\Rector\BetterPhpDocParser\ValueObject\PhpDocAttributeKey::LAST_PHP_DOC_TOKEN_POSITION) ?: $this->currentTokenPosition;
|
||||
$lastTokenPosition = $this->getCurrentPhpDocInfo()->getPhpDocNode()->getAttribute(\Rector\BetterPhpDocParser\ValueObject\PhpDocAttributeKey::LAST_PHP_DOC_TOKEN_POSITION);
|
||||
if ($lastTokenPosition === null) {
|
||||
$lastTokenPosition = $this->currentTokenPosition;
|
||||
}
|
||||
if ($lastTokenPosition === 0) {
|
||||
$lastTokenPosition = 1;
|
||||
}
|
||||
|
@ -42,7 +42,7 @@ final class FileHashComputer
|
||||
$fileLoaders = [new \RectorPrefix20211128\Symfony\Component\DependencyInjection\Loader\GlobFileLoader($containerBuilder, $fileLocator), new \RectorPrefix20211128\Symfony\Component\DependencyInjection\Loader\PhpFileLoader($containerBuilder, $fileLocator)];
|
||||
$loaderResolver = new \RectorPrefix20211128\Symfony\Component\Config\Loader\LoaderResolver($fileLoaders);
|
||||
$loader = $loaderResolver->resolve($filePath);
|
||||
if (!$loader) {
|
||||
if ($loader === \false) {
|
||||
throw new \Rector\Core\Exception\ShouldNotHappenException();
|
||||
}
|
||||
return $loader;
|
||||
|
@ -78,7 +78,7 @@ final class ConsoleOutputFormatter implements \Rector\ChangesReporting\Contract\
|
||||
}
|
||||
$message = \sprintf('<options=bold>%d) %s</>', ++$i, $relativeFilePath);
|
||||
$this->outputStyle->writeln($message);
|
||||
$this->outputStyle->newLine();
|
||||
$this->outputStyle->newline();
|
||||
$this->outputStyle->writeln($fileDiff->getDiffConsoleFormatted());
|
||||
$rectorsChangelogsLines = $this->createRectorChangelogLines($fileDiff);
|
||||
if ($fileDiff->getRectorChanges() !== []) {
|
||||
|
@ -4,6 +4,7 @@ declare (strict_types=1);
|
||||
namespace Rector\NodeTypeResolver\NodeTypeResolver;
|
||||
|
||||
use PhpParser\Node;
|
||||
use PhpParser\Node\Expr;
|
||||
use PhpParser\Node\Expr\Variable;
|
||||
use PhpParser\Node\Param;
|
||||
use PHPStan\Analyser\Scope;
|
||||
@ -15,6 +16,8 @@ use Rector\NodeTypeResolver\Contract\NodeTypeResolverInterface;
|
||||
use Rector\NodeTypeResolver\Node\AttributeKey;
|
||||
/**
|
||||
* @see \Rector\Tests\NodeTypeResolver\PerNodeTypeResolver\VariableTypeResolver\VariableTypeResolverTest
|
||||
*
|
||||
* @implements NodeTypeResolverInterface<Variable>
|
||||
*/
|
||||
final class VariableTypeResolver implements \Rector\NodeTypeResolver\Contract\NodeTypeResolverInterface
|
||||
{
|
||||
@ -32,7 +35,7 @@ final class VariableTypeResolver implements \Rector\NodeTypeResolver\Contract\No
|
||||
$this->phpDocInfoFactory = $phpDocInfoFactory;
|
||||
}
|
||||
/**
|
||||
* @return array<class-string<Node>>
|
||||
* @return array<class-string<Expr>>
|
||||
*/
|
||||
public function getNodeClasses() : array
|
||||
{
|
||||
|
@ -74,6 +74,9 @@ final class StaticTypeAnalyzer
|
||||
private function isAlwaysTruableArrayType(\PHPStan\Type\ArrayType $arrayType) : bool
|
||||
{
|
||||
$itemType = $arrayType->getItemType();
|
||||
return $itemType instanceof \PHPStan\Type\ConstantScalarType && $itemType->getValue();
|
||||
if (!$itemType instanceof \PHPStan\Type\ConstantScalarType) {
|
||||
return \false;
|
||||
}
|
||||
return (bool) $itemType->getValue();
|
||||
}
|
||||
}
|
||||
|
@ -57,7 +57,7 @@ final class DynamicSourceLocatorProvider implements \Rector\NodeTypeResolver\Con
|
||||
{
|
||||
// do not cache for PHPUnit, as in test every fixture is different
|
||||
$isPHPUnitRun = \Rector\Testing\PHPUnit\StaticPHPUnitEnvironment::isPHPUnitRun();
|
||||
if ($this->aggregateSourceLocator && !$isPHPUnitRun) {
|
||||
if ($this->aggregateSourceLocator instanceof \PHPStan\BetterReflection\SourceLocator\Type\AggregateSourceLocator && !$isPHPUnitRun) {
|
||||
return $this->aggregateSourceLocator;
|
||||
}
|
||||
$sourceLocators = [];
|
||||
|
@ -126,10 +126,7 @@ final class ParallelFileProcessor
|
||||
foreach ($json[\Rector\Parallel\ValueObject\Bridge::FILE_DIFFS] as $jsonError) {
|
||||
$fileDiffs[] = \Rector\Core\ValueObject\Reporting\FileDiff::decode($jsonError);
|
||||
}
|
||||
// @todo why there is a null check?
|
||||
if ($postFileCallback !== null) {
|
||||
$postFileCallback($json[\Rector\Parallel\ValueObject\Bridge::FILES_COUNT]);
|
||||
}
|
||||
$postFileCallback($json[\Rector\Parallel\ValueObject\Bridge::FILES_COUNT]);
|
||||
$systemErrorsCount += $json[\Rector\Parallel\ValueObject\Bridge::SYSTEM_ERRORS_COUNT];
|
||||
if ($systemErrorsCount >= self::SYSTEM_ERROR_COUNT_LIMIT) {
|
||||
$reachedInternalErrorsCountLimit = \true;
|
||||
|
@ -3,15 +3,18 @@
|
||||
declare (strict_types=1);
|
||||
namespace Rector\ReadWrite\Contract;
|
||||
|
||||
use PhpParser\Node;
|
||||
use PhpParser\Node\Expr;
|
||||
/**
|
||||
* @template TExpr as Expr
|
||||
*/
|
||||
interface ReadNodeAnalyzerInterface
|
||||
{
|
||||
/**
|
||||
* @param \PhpParser\Node $node
|
||||
* @param \PhpParser\Node\Expr $expr
|
||||
*/
|
||||
public function supports($node) : bool;
|
||||
public function supports($expr) : bool;
|
||||
/**
|
||||
* @param \PhpParser\Node $node
|
||||
* @param \PhpParser\Node\Expr $expr
|
||||
*/
|
||||
public function isRead($node) : bool;
|
||||
public function isRead($expr) : bool;
|
||||
}
|
||||
|
@ -4,6 +4,7 @@ declare (strict_types=1);
|
||||
namespace Rector\ReadWrite\ReadNodeAnalyzer;
|
||||
|
||||
use PhpParser\Node;
|
||||
use PhpParser\Node\Expr;
|
||||
use PhpParser\Node\Expr\PropertyFetch;
|
||||
use PhpParser\Node\Expr\StaticPropertyFetch;
|
||||
use PhpParser\Node\Stmt\Class_;
|
||||
@ -11,6 +12,9 @@ use Rector\Core\PhpParser\Node\BetterNodeFinder;
|
||||
use Rector\Core\PhpParser\NodeFinder\PropertyFetchFinder;
|
||||
use Rector\NodeNameResolver\NodeNameResolver;
|
||||
use Rector\ReadWrite\Contract\ReadNodeAnalyzerInterface;
|
||||
/**
|
||||
* @implements ReadNodeAnalyzerInterface<PropertyFetch|StaticPropertyFetch>
|
||||
*/
|
||||
final class LocalPropertyFetchReadNodeAnalyzer implements \Rector\ReadWrite\Contract\ReadNodeAnalyzerInterface
|
||||
{
|
||||
/**
|
||||
@ -37,23 +41,23 @@ final class LocalPropertyFetchReadNodeAnalyzer implements \Rector\ReadWrite\Cont
|
||||
$this->betterNodeFinder = $betterNodeFinder;
|
||||
}
|
||||
/**
|
||||
* @param \PhpParser\Node $node
|
||||
* @param \PhpParser\Node\Expr $expr
|
||||
*/
|
||||
public function supports($node) : bool
|
||||
public function supports($expr) : bool
|
||||
{
|
||||
return $node instanceof \PhpParser\Node\Expr\PropertyFetch || $node instanceof \PhpParser\Node\Expr\StaticPropertyFetch;
|
||||
return $expr instanceof \PhpParser\Node\Expr\PropertyFetch || $expr instanceof \PhpParser\Node\Expr\StaticPropertyFetch;
|
||||
}
|
||||
/**
|
||||
* @param \PhpParser\Node $node
|
||||
* @param \PhpParser\Node\Expr $expr
|
||||
*/
|
||||
public function isRead($node) : bool
|
||||
public function isRead($expr) : bool
|
||||
{
|
||||
$class = $this->betterNodeFinder->findParentType($node, \PhpParser\Node\Stmt\Class_::class);
|
||||
$class = $this->betterNodeFinder->findParentType($expr, \PhpParser\Node\Stmt\Class_::class);
|
||||
if (!$class instanceof \PhpParser\Node\Stmt\Class_) {
|
||||
// assume worse to keep node protected
|
||||
return \true;
|
||||
}
|
||||
$propertyName = $this->nodeNameResolver->getName($node->name);
|
||||
$propertyName = $this->nodeNameResolver->getName($expr->name);
|
||||
if ($propertyName === null) {
|
||||
// assume worse to keep node protected
|
||||
return \true;
|
||||
|
@ -3,11 +3,14 @@
|
||||
declare (strict_types=1);
|
||||
namespace Rector\ReadWrite\ReadNodeAnalyzer;
|
||||
|
||||
use PhpParser\Node;
|
||||
use PhpParser\Node\Expr;
|
||||
use PhpParser\Node\Expr\Variable;
|
||||
use Rector\NodeNestingScope\ParentScopeFinder;
|
||||
use Rector\ReadWrite\Contract\ReadNodeAnalyzerInterface;
|
||||
use Rector\ReadWrite\NodeFinder\NodeUsageFinder;
|
||||
/**
|
||||
* @implements ReadNodeAnalyzerInterface<Variable>
|
||||
*/
|
||||
final class VariableReadNodeAnalyzer implements \Rector\ReadWrite\Contract\ReadNodeAnalyzerInterface
|
||||
{
|
||||
/**
|
||||
@ -29,22 +32,22 @@ final class VariableReadNodeAnalyzer implements \Rector\ReadWrite\Contract\ReadN
|
||||
$this->justReadExprAnalyzer = $justReadExprAnalyzer;
|
||||
}
|
||||
/**
|
||||
* @param \PhpParser\Node $node
|
||||
* @param \PhpParser\Node\Expr $expr
|
||||
*/
|
||||
public function supports($node) : bool
|
||||
public function supports($expr) : bool
|
||||
{
|
||||
return $node instanceof \PhpParser\Node\Expr\Variable;
|
||||
return $expr instanceof \PhpParser\Node\Expr\Variable;
|
||||
}
|
||||
/**
|
||||
* @param \PhpParser\Node $node
|
||||
* @param \PhpParser\Node\Expr $expr
|
||||
*/
|
||||
public function isRead($node) : bool
|
||||
public function isRead($expr) : bool
|
||||
{
|
||||
$parentScope = $this->parentScopeFinder->find($node);
|
||||
$parentScope = $this->parentScopeFinder->find($expr);
|
||||
if ($parentScope === null) {
|
||||
return \false;
|
||||
}
|
||||
$variableUsages = $this->nodeUsageFinder->findVariableUsages((array) $parentScope->stmts, $node);
|
||||
$variableUsages = $this->nodeUsageFinder->findVariableUsages((array) $parentScope->stmts, $expr);
|
||||
foreach ($variableUsages as $variableUsage) {
|
||||
if ($this->justReadExprAnalyzer->isReadContext($variableUsage)) {
|
||||
return \true;
|
||||
|
@ -7,10 +7,13 @@ use PhpParser\Node;
|
||||
use PHPStan\Analyser\NameScope;
|
||||
use PHPStan\PhpDocParser\Ast\Type\TypeNode;
|
||||
use PHPStan\Type\Type;
|
||||
/**
|
||||
* @template TTypeNode as TypeNode
|
||||
*/
|
||||
interface PhpDocTypeMapperInterface
|
||||
{
|
||||
/**
|
||||
* @return class-string<TypeNode>
|
||||
* @return class-string<TTypeNode>
|
||||
*/
|
||||
public function getNodeType() : string;
|
||||
/**
|
||||
|
@ -13,7 +13,6 @@ use PHPStan\Reflection\ClassReflection;
|
||||
use PHPStan\Type\Generic\TemplateTypeMap;
|
||||
use PHPStan\Type\Type;
|
||||
use Rector\BetterPhpDocParser\PhpDocInfo\PhpDocInfoFactory;
|
||||
use Rector\Core\Exception\ShouldNotHappenException;
|
||||
use Rector\Core\PhpParser\Node\BetterNodeFinder;
|
||||
use Rector\NodeTypeResolver\Node\AttributeKey;
|
||||
use Rector\StaticTypeMapper\StaticTypeMapper;
|
||||
@ -81,13 +80,9 @@ final class NameScopeFactory
|
||||
foreach ($useNode->uses as $useUse) {
|
||||
/** @var UseUse $useUse */
|
||||
$aliasName = $useUse->getAlias()->name;
|
||||
$useName = $useUse->name->toString();
|
||||
if (!\is_string($useName)) {
|
||||
throw new \Rector\Core\Exception\ShouldNotHappenException();
|
||||
}
|
||||
// uses must be lowercase, as PHPStan lowercases it
|
||||
$lowercasedAliasName = \strtolower($aliasName);
|
||||
$useNamesByAlias[$lowercasedAliasName] = $useName;
|
||||
$useNamesByAlias[$lowercasedAliasName] = $useUse->name->toString();
|
||||
}
|
||||
}
|
||||
return $useNamesByAlias;
|
||||
|
@ -25,6 +25,9 @@ use Rector\StaticTypeMapper\Mapper\ScalarStringToTypeMapper;
|
||||
use Rector\StaticTypeMapper\ValueObject\Type\ParentStaticType;
|
||||
use Rector\StaticTypeMapper\ValueObject\Type\SelfObjectType;
|
||||
use Rector\TypeDeclaration\PHPStan\Type\ObjectTypeSpecifier;
|
||||
/**
|
||||
* @implements PhpDocTypeMapperInterface<IdentifierTypeNode>
|
||||
*/
|
||||
final class IdentifierTypeMapper implements \Rector\StaticTypeMapper\Contract\PhpDocParser\PhpDocTypeMapperInterface
|
||||
{
|
||||
/**
|
||||
@ -55,9 +58,6 @@ final class IdentifierTypeMapper implements \Rector\StaticTypeMapper\Contract\Ph
|
||||
$this->nodeNameResolver = $nodeNameResolver;
|
||||
$this->reflectionProvider = $reflectionProvider;
|
||||
}
|
||||
/**
|
||||
* @return class-string<TypeNode>
|
||||
*/
|
||||
public function getNodeType() : string
|
||||
{
|
||||
return \PHPStan\PhpDocParser\Ast\Type\IdentifierTypeNode::class;
|
||||
|
@ -12,15 +12,15 @@ use PHPStan\Type\Type;
|
||||
use Rector\StaticTypeMapper\Contract\PhpDocParser\PhpDocTypeMapperInterface;
|
||||
use Rector\StaticTypeMapper\PhpDoc\PhpDocTypeMapper;
|
||||
use RectorPrefix20211128\Symfony\Contracts\Service\Attribute\Required;
|
||||
/**
|
||||
* @implements PhpDocTypeMapperInterface<IntersectionTypeNode>
|
||||
*/
|
||||
final class IntersectionTypeMapper implements \Rector\StaticTypeMapper\Contract\PhpDocParser\PhpDocTypeMapperInterface
|
||||
{
|
||||
/**
|
||||
* @var \Rector\StaticTypeMapper\PhpDoc\PhpDocTypeMapper
|
||||
*/
|
||||
private $phpDocTypeMapper;
|
||||
/**
|
||||
* @return class-string<TypeNode>
|
||||
*/
|
||||
public function getNodeType() : string
|
||||
{
|
||||
return \PHPStan\PhpDocParser\Ast\Type\IntersectionTypeNode::class;
|
||||
|
@ -13,6 +13,9 @@ use PHPStan\Type\NullType;
|
||||
use PHPStan\Type\Type;
|
||||
use PHPStan\Type\UnionType;
|
||||
use Rector\StaticTypeMapper\Contract\PhpDocParser\PhpDocTypeMapperInterface;
|
||||
/**
|
||||
* @implements PhpDocTypeMapperInterface<NullableTypeNode>
|
||||
*/
|
||||
final class NullableTypeMapper implements \Rector\StaticTypeMapper\Contract\PhpDocParser\PhpDocTypeMapperInterface
|
||||
{
|
||||
/**
|
||||
@ -28,9 +31,6 @@ final class NullableTypeMapper implements \Rector\StaticTypeMapper\Contract\PhpD
|
||||
$this->identifierTypeMapper = $identifierTypeMapper;
|
||||
$this->typeNodeResolver = $typeNodeResolver;
|
||||
}
|
||||
/**
|
||||
* @return class-string<TypeNode>
|
||||
*/
|
||||
public function getNodeType() : string
|
||||
{
|
||||
return \PHPStan\PhpDocParser\Ast\Type\NullableTypeNode::class;
|
||||
|
@ -12,6 +12,9 @@ use Rector\NodeTypeResolver\PHPStan\Type\TypeFactory;
|
||||
use Rector\StaticTypeMapper\Contract\PhpDocParser\PhpDocTypeMapperInterface;
|
||||
use Rector\StaticTypeMapper\PhpDoc\PhpDocTypeMapper;
|
||||
use RectorPrefix20211128\Symfony\Contracts\Service\Attribute\Required;
|
||||
/**
|
||||
* @implements PhpDocTypeMapperInterface<UnionTypeNode>
|
||||
*/
|
||||
final class UnionTypeMapper implements \Rector\StaticTypeMapper\Contract\PhpDocParser\PhpDocTypeMapperInterface
|
||||
{
|
||||
/**
|
||||
@ -26,9 +29,6 @@ final class UnionTypeMapper implements \Rector\StaticTypeMapper\Contract\PhpDocP
|
||||
{
|
||||
$this->typeFactory = $typeFactory;
|
||||
}
|
||||
/**
|
||||
* @return class-string<TypeNode>
|
||||
*/
|
||||
public function getNodeType() : string
|
||||
{
|
||||
return \PHPStan\PhpDocParser\Ast\Type\UnionTypeNode::class;
|
||||
|
@ -15,9 +15,6 @@ use Rector\StaticTypeMapper\Contract\PhpParser\PhpParserNodeMapperInterface;
|
||||
*/
|
||||
final class ExprNodeMapper implements \Rector\StaticTypeMapper\Contract\PhpParser\PhpParserNodeMapperInterface
|
||||
{
|
||||
/**
|
||||
* @return class-string<Node>
|
||||
*/
|
||||
public function getNodeType() : string
|
||||
{
|
||||
return \PhpParser\Node\Expr::class;
|
||||
|
@ -33,9 +33,6 @@ final class FullyQualifiedNodeMapper implements \Rector\StaticTypeMapper\Contrac
|
||||
$this->currentFileProvider = $currentFileProvider;
|
||||
$this->usedImportsResolver = $usedImportsResolver;
|
||||
}
|
||||
/**
|
||||
* @return class-string<Node>
|
||||
*/
|
||||
public function getNodeType() : string
|
||||
{
|
||||
return \PhpParser\Node\Name\FullyQualified::class;
|
||||
|
@ -21,9 +21,6 @@ final class IdentifierNodeMapper implements \Rector\StaticTypeMapper\Contract\Ph
|
||||
{
|
||||
$this->scalarStringToTypeMapper = $scalarStringToTypeMapper;
|
||||
}
|
||||
/**
|
||||
* @return class-string<Node>
|
||||
*/
|
||||
public function getNodeType() : string
|
||||
{
|
||||
return \PhpParser\Node\Identifier::class;
|
||||
|
@ -55,9 +55,6 @@ final class NameNodeMapper implements \Rector\StaticTypeMapper\Contract\PhpParse
|
||||
$this->betterNodeFinder = $betterNodeFinder;
|
||||
$this->nodeNameResolver = $nodeNameResolver;
|
||||
}
|
||||
/**
|
||||
* @return class-string<Node>
|
||||
*/
|
||||
public function getNodeType() : string
|
||||
{
|
||||
return \PhpParser\Node\Name::class;
|
||||
|
@ -13,9 +13,6 @@ use Rector\StaticTypeMapper\Contract\PhpParser\PhpParserNodeMapperInterface;
|
||||
*/
|
||||
final class StringNodeMapper implements \Rector\StaticTypeMapper\Contract\PhpParser\PhpParserNodeMapperInterface
|
||||
{
|
||||
/**
|
||||
* @return class-string<Node>
|
||||
*/
|
||||
public function getNodeType() : string
|
||||
{
|
||||
return \PhpParser\Node\Scalar\String_::class;
|
||||
|
@ -63,7 +63,7 @@ CODE_SAMPLE
|
||||
*/
|
||||
public function refactor(\PhpParser\Node $node) : ?\PhpParser\Node\Expr\FuncCall
|
||||
{
|
||||
$isJustSwapped = $node->getAttribute(self::JUST_SWAPPED);
|
||||
$isJustSwapped = (bool) $node->getAttribute(self::JUST_SWAPPED, \false);
|
||||
if ($isJustSwapped) {
|
||||
return null;
|
||||
}
|
||||
|
@ -101,7 +101,7 @@ CODE_SAMPLE
|
||||
continue;
|
||||
}
|
||||
$classReflection = $this->reflectionProvider->getClass($propertyFetchVarType->getClassName());
|
||||
if (!$classReflection->hasProperty($propertyFetchName) || $classReflection->isBuiltIn()) {
|
||||
if (!$classReflection->hasProperty($propertyFetchName) || $classReflection->isBuiltin()) {
|
||||
$newNodes[] = $this->replaceToPropertyExistsWithNullCheck($issetVar->var, $propertyFetchName, $issetVar);
|
||||
} else {
|
||||
$newNodes[] = $this->createNotIdenticalToNull($issetVar);
|
||||
|
@ -126,7 +126,7 @@ final class UseImportsAdder
|
||||
private function isCurrentNamespace(string $namespaceName, \PHPStan\Type\ObjectType $objectType) : bool
|
||||
{
|
||||
$afterCurrentNamespace = \RectorPrefix20211128\Nette\Utils\Strings::after($objectType->getClassName(), $namespaceName . '\\');
|
||||
if (!$afterCurrentNamespace) {
|
||||
if ($afterCurrentNamespace === null) {
|
||||
return \false;
|
||||
}
|
||||
return \strpos($afterCurrentNamespace, '\\') === \false;
|
||||
|
@ -201,10 +201,13 @@ final class ShortNameResolver
|
||||
{
|
||||
$shortNamesToFullyQualifiedNames = [];
|
||||
foreach ($shortNames as $shortName) {
|
||||
$stmtsMatchedName = $this->useImportNameMatcher->matchNameWithStmts($shortName, $stmts);
|
||||
if ($reflectionClass instanceof \ReflectionClass) {
|
||||
$fullyQualifiedName = \RectorPrefix20211128\Nette\Utils\Reflection::expandClassName($shortName, $reflectionClass);
|
||||
} elseif (\is_string($stmtsMatchedName)) {
|
||||
$fullyQualifiedName = $stmtsMatchedName;
|
||||
} else {
|
||||
$fullyQualifiedName = $this->useImportNameMatcher->matchNameWithStmts($shortName, $stmts) ?: $shortName;
|
||||
$fullyQualifiedName = $shortName;
|
||||
}
|
||||
$shortNamesToFullyQualifiedNames[$shortName] = $fullyQualifiedName;
|
||||
}
|
||||
|
@ -41,7 +41,11 @@ final class ClassNaming
|
||||
$name = $name->toString();
|
||||
}
|
||||
$name = \trim($name, '\\');
|
||||
return \RectorPrefix20211128\Nette\Utils\Strings::after($name, '\\', -1) ?: $name;
|
||||
$shortName = \RectorPrefix20211128\Nette\Utils\Strings::after($name, '\\', -1);
|
||||
if (\is_string($shortName)) {
|
||||
return $shortName;
|
||||
}
|
||||
return $name;
|
||||
}
|
||||
public function getNamespace(string $fullyQualifiedName) : ?string
|
||||
{
|
||||
|
@ -105,8 +105,8 @@ final class NameImporter
|
||||
}
|
||||
// Importing root namespace classes (like \DateTime) is optional
|
||||
if (!$this->parameterProvider->provideBoolParameter(\Rector\Core\Configuration\Option::IMPORT_SHORT_CLASSES)) {
|
||||
$name = $this->nodeNameResolver->getName($name);
|
||||
if ($name !== null && \substr_count($name, '\\') === 0) {
|
||||
$stringName = $this->nodeNameResolver->getName($name);
|
||||
if ($stringName !== null && \substr_count($stringName, '\\') === 0) {
|
||||
return \true;
|
||||
}
|
||||
}
|
||||
@ -153,7 +153,7 @@ final class NameImporter
|
||||
{
|
||||
$parentNode = $name->getAttribute(\Rector\NodeTypeResolver\Node\AttributeKey::PARENT_NODE);
|
||||
$fullName = $name->toString();
|
||||
$autoImportNames = $this->parameterProvider->provideParameter(\Rector\Core\Configuration\Option::AUTO_IMPORT_NAMES);
|
||||
$autoImportNames = $this->parameterProvider->provideBoolParameter(\Rector\Core\Configuration\Option::AUTO_IMPORT_NAMES);
|
||||
if ($autoImportNames && !$parentNode instanceof \PhpParser\Node && \strpos($fullName, '\\') === \false && $this->reflectionProvider->hasFunction(new \PhpParser\Node\Name($fullName), null)) {
|
||||
return \true;
|
||||
}
|
||||
|
@ -77,7 +77,7 @@ CODE_SAMPLE
|
||||
foreach ($node->parts as $part) {
|
||||
if ($part instanceof \PhpParser\Node\Scalar\EncapsedStringPart) {
|
||||
$this->collectEncapsedStringPart($part);
|
||||
} elseif ($part instanceof \PhpParser\Node\Expr) {
|
||||
} else {
|
||||
$this->collectExpr($part);
|
||||
}
|
||||
}
|
||||
|
@ -32,7 +32,7 @@ final class BuiltInMethodAnalyzer
|
||||
return \false;
|
||||
}
|
||||
foreach ($classReflection->getInterfaces() as $interfaceReflection) {
|
||||
if (!$interfaceReflection->isBuiltIn()) {
|
||||
if (!$interfaceReflection->isBuiltin()) {
|
||||
continue;
|
||||
}
|
||||
if (!$interfaceReflection->hasMethod($methodName)) {
|
||||
|
@ -44,7 +44,7 @@ final class InflectorSingularResolver
|
||||
public function resolve(string $currentName) : string
|
||||
{
|
||||
$matchBy = \RectorPrefix20211128\Nette\Utils\Strings::match($currentName, self::BY_MIDDLE_REGEX);
|
||||
if ($matchBy) {
|
||||
if ($matchBy !== null) {
|
||||
return \RectorPrefix20211128\Nette\Utils\Strings::substring($currentName, 0, -\strlen($matchBy['by']));
|
||||
}
|
||||
$resolvedValue = $this->resolveSingularizeMap($currentName);
|
||||
|
@ -56,7 +56,7 @@ CODE_SAMPLE
|
||||
if ($this->shouldSkip()) {
|
||||
return null;
|
||||
}
|
||||
return $this->isArrayAndDualCheckToAble->processBooleanOr($node, 'Countable', 'is_countable') ?: $node;
|
||||
return $this->isArrayAndDualCheckToAble->processBooleanOr($node, 'Countable', 'is_countable');
|
||||
}
|
||||
public function provideMinPhpVersion() : int
|
||||
{
|
||||
|
@ -159,7 +159,7 @@ CODE_SAMPLE
|
||||
if (!\is_string($variableName)) {
|
||||
return;
|
||||
}
|
||||
if (!$methodName) {
|
||||
if (!\is_string($methodName)) {
|
||||
return;
|
||||
}
|
||||
$this->callsByVariable[$variableName][] = $methodName;
|
||||
|
@ -4,6 +4,7 @@ declare (strict_types=1);
|
||||
namespace Rector\Privatization\NodeAnalyzer;
|
||||
|
||||
use PhpParser\Node;
|
||||
use PhpParser\Node\Expr;
|
||||
use PhpParser\Node\Expr\Assign;
|
||||
use PhpParser\Node\Expr\PropertyFetch;
|
||||
use PhpParser\Node\Stmt;
|
||||
@ -52,7 +53,7 @@ final class PropertyFetchByMethodAnalyzer
|
||||
{
|
||||
$propertyUsageByMethods = [];
|
||||
foreach ($propertyNames as $propertyName) {
|
||||
if ($this->isPropertyHasDefaultValue($class, $propertyName)) {
|
||||
if ($this->isPropertyWithDefaultValue($class, $propertyName)) {
|
||||
continue;
|
||||
}
|
||||
foreach ($class->getMethods() as $classMethod) {
|
||||
@ -79,10 +80,13 @@ final class PropertyFetchByMethodAnalyzer
|
||||
}
|
||||
return $this->isPropertyChangingInMultipleMethodCalls($classMethod, $propertyName);
|
||||
}
|
||||
private function isPropertyHasDefaultValue(\PhpParser\Node\Stmt\Class_ $class, string $propertyName) : bool
|
||||
private function isPropertyWithDefaultValue(\PhpParser\Node\Stmt\Class_ $class, string $propertyName) : bool
|
||||
{
|
||||
$property = $class->getProperty($propertyName);
|
||||
return $property instanceof \PhpParser\Node\Stmt\Property && $property->props[0]->default;
|
||||
if (!$property instanceof \PhpParser\Node\Stmt\Property) {
|
||||
return \false;
|
||||
}
|
||||
return $property->props[0]->default instanceof \PhpParser\Node\Expr;
|
||||
}
|
||||
private function isInConstructWithPropertyChanging(\PhpParser\Node\Stmt\ClassMethod $classMethod, string $propertyName) : bool
|
||||
{
|
||||
@ -124,7 +128,7 @@ final class PropertyFetchByMethodAnalyzer
|
||||
private function verifyPropertyReadInIf(?bool $isPropertyReadInIf, \PhpParser\Node $node, string $propertyName) : ?bool
|
||||
{
|
||||
if ($node instanceof \PhpParser\Node\Stmt\If_) {
|
||||
$isPropertyReadInIf = $this->refactorIf($node, $propertyName);
|
||||
return $this->refactorIf($node, $propertyName);
|
||||
}
|
||||
return $isPropertyReadInIf;
|
||||
}
|
||||
|
@ -313,7 +313,7 @@ final class ClassRenamer
|
||||
$scope = $classLike->getAttribute(\Rector\NodeTypeResolver\Node\AttributeKey::SCOPE);
|
||||
$classLike->implements = \array_unique($classLike->implements);
|
||||
foreach ($classLike->implements as $key => $implementName) {
|
||||
$virtualNode = $implementName->getAttribute(\Rector\NodeTypeResolver\Node\AttributeKey::VIRTUAL_NODE);
|
||||
$virtualNode = (bool) $implementName->getAttribute(\Rector\NodeTypeResolver\Node\AttributeKey::VIRTUAL_NODE, \false);
|
||||
if (!$virtualNode) {
|
||||
continue;
|
||||
}
|
||||
|
@ -16,11 +16,11 @@ final class VersionResolver
|
||||
/**
|
||||
* @var string
|
||||
*/
|
||||
public const PACKAGE_VERSION = '6340d263f40c31eae44c1c5c057eff253c002921';
|
||||
public const PACKAGE_VERSION = '185ee1b473147fd620d3da2c42eb52b1756f2a18';
|
||||
/**
|
||||
* @var string
|
||||
*/
|
||||
public const RELEASE_DATE = '2021-11-28 18:19:45';
|
||||
public const RELEASE_DATE = '2021-11-28 18:48:56';
|
||||
public static function resolvePackageVersion() : string
|
||||
{
|
||||
$process = new \RectorPrefix20211128\Symfony\Component\Process\Process(['git', 'log', '--pretty="%H"', '-n1', 'HEAD'], __DIR__);
|
||||
|
2
vendor/autoload.php
vendored
2
vendor/autoload.php
vendored
@ -4,4 +4,4 @@
|
||||
|
||||
require_once __DIR__ . '/composer/autoload_real.php';
|
||||
|
||||
return ComposerAutoloaderInitb0edd70802cd8b0614e2d4b03138e349::getLoader();
|
||||
return ComposerAutoloaderInit318ac5f3e8b1ab124e631699d7247d22::getLoader();
|
||||
|
14
vendor/composer/autoload_real.php
vendored
14
vendor/composer/autoload_real.php
vendored
@ -2,7 +2,7 @@
|
||||
|
||||
// autoload_real.php @generated by Composer
|
||||
|
||||
class ComposerAutoloaderInitb0edd70802cd8b0614e2d4b03138e349
|
||||
class ComposerAutoloaderInit318ac5f3e8b1ab124e631699d7247d22
|
||||
{
|
||||
private static $loader;
|
||||
|
||||
@ -22,15 +22,15 @@ class ComposerAutoloaderInitb0edd70802cd8b0614e2d4b03138e349
|
||||
return self::$loader;
|
||||
}
|
||||
|
||||
spl_autoload_register(array('ComposerAutoloaderInitb0edd70802cd8b0614e2d4b03138e349', 'loadClassLoader'), true, true);
|
||||
spl_autoload_register(array('ComposerAutoloaderInit318ac5f3e8b1ab124e631699d7247d22', 'loadClassLoader'), true, true);
|
||||
self::$loader = $loader = new \Composer\Autoload\ClassLoader(\dirname(\dirname(__FILE__)));
|
||||
spl_autoload_unregister(array('ComposerAutoloaderInitb0edd70802cd8b0614e2d4b03138e349', 'loadClassLoader'));
|
||||
spl_autoload_unregister(array('ComposerAutoloaderInit318ac5f3e8b1ab124e631699d7247d22', 'loadClassLoader'));
|
||||
|
||||
$useStaticLoader = PHP_VERSION_ID >= 50600 && !defined('HHVM_VERSION') && (!function_exists('zend_loader_file_encoded') || !zend_loader_file_encoded());
|
||||
if ($useStaticLoader) {
|
||||
require __DIR__ . '/autoload_static.php';
|
||||
|
||||
call_user_func(\Composer\Autoload\ComposerStaticInitb0edd70802cd8b0614e2d4b03138e349::getInitializer($loader));
|
||||
call_user_func(\Composer\Autoload\ComposerStaticInit318ac5f3e8b1ab124e631699d7247d22::getInitializer($loader));
|
||||
} else {
|
||||
$classMap = require __DIR__ . '/autoload_classmap.php';
|
||||
if ($classMap) {
|
||||
@ -42,19 +42,19 @@ class ComposerAutoloaderInitb0edd70802cd8b0614e2d4b03138e349
|
||||
$loader->register(true);
|
||||
|
||||
if ($useStaticLoader) {
|
||||
$includeFiles = Composer\Autoload\ComposerStaticInitb0edd70802cd8b0614e2d4b03138e349::$files;
|
||||
$includeFiles = Composer\Autoload\ComposerStaticInit318ac5f3e8b1ab124e631699d7247d22::$files;
|
||||
} else {
|
||||
$includeFiles = require __DIR__ . '/autoload_files.php';
|
||||
}
|
||||
foreach ($includeFiles as $fileIdentifier => $file) {
|
||||
composerRequireb0edd70802cd8b0614e2d4b03138e349($fileIdentifier, $file);
|
||||
composerRequire318ac5f3e8b1ab124e631699d7247d22($fileIdentifier, $file);
|
||||
}
|
||||
|
||||
return $loader;
|
||||
}
|
||||
}
|
||||
|
||||
function composerRequireb0edd70802cd8b0614e2d4b03138e349($fileIdentifier, $file)
|
||||
function composerRequire318ac5f3e8b1ab124e631699d7247d22($fileIdentifier, $file)
|
||||
{
|
||||
if (empty($GLOBALS['__composer_autoload_files'][$fileIdentifier])) {
|
||||
require $file;
|
||||
|
8
vendor/composer/autoload_static.php
vendored
8
vendor/composer/autoload_static.php
vendored
@ -4,7 +4,7 @@
|
||||
|
||||
namespace Composer\Autoload;
|
||||
|
||||
class ComposerStaticInitb0edd70802cd8b0614e2d4b03138e349
|
||||
class ComposerStaticInit318ac5f3e8b1ab124e631699d7247d22
|
||||
{
|
||||
public static $files = array (
|
||||
'a4a119a56e50fbb293281d9a48007e0e' => __DIR__ . '/..' . '/symfony/polyfill-php80/bootstrap.php',
|
||||
@ -3770,9 +3770,9 @@ class ComposerStaticInitb0edd70802cd8b0614e2d4b03138e349
|
||||
public static function getInitializer(ClassLoader $loader)
|
||||
{
|
||||
return \Closure::bind(function () use ($loader) {
|
||||
$loader->prefixLengthsPsr4 = ComposerStaticInitb0edd70802cd8b0614e2d4b03138e349::$prefixLengthsPsr4;
|
||||
$loader->prefixDirsPsr4 = ComposerStaticInitb0edd70802cd8b0614e2d4b03138e349::$prefixDirsPsr4;
|
||||
$loader->classMap = ComposerStaticInitb0edd70802cd8b0614e2d4b03138e349::$classMap;
|
||||
$loader->prefixLengthsPsr4 = ComposerStaticInit318ac5f3e8b1ab124e631699d7247d22::$prefixLengthsPsr4;
|
||||
$loader->prefixDirsPsr4 = ComposerStaticInit318ac5f3e8b1ab124e631699d7247d22::$prefixDirsPsr4;
|
||||
$loader->classMap = ComposerStaticInit318ac5f3e8b1ab124e631699d7247d22::$classMap;
|
||||
|
||||
}, null, ClassLoader::class);
|
||||
}
|
||||
|
10
vendor/scoper-autoload.php
vendored
10
vendor/scoper-autoload.php
vendored
@ -12,8 +12,8 @@ if (!class_exists('GenerateChangelogCommand', false) && !interface_exists('Gener
|
||||
if (!class_exists('AutoloadIncluder', false) && !interface_exists('AutoloadIncluder', false) && !trait_exists('AutoloadIncluder', false)) {
|
||||
spl_autoload_call('RectorPrefix20211128\AutoloadIncluder');
|
||||
}
|
||||
if (!class_exists('ComposerAutoloaderInitb0edd70802cd8b0614e2d4b03138e349', false) && !interface_exists('ComposerAutoloaderInitb0edd70802cd8b0614e2d4b03138e349', false) && !trait_exists('ComposerAutoloaderInitb0edd70802cd8b0614e2d4b03138e349', false)) {
|
||||
spl_autoload_call('RectorPrefix20211128\ComposerAutoloaderInitb0edd70802cd8b0614e2d4b03138e349');
|
||||
if (!class_exists('ComposerAutoloaderInit318ac5f3e8b1ab124e631699d7247d22', false) && !interface_exists('ComposerAutoloaderInit318ac5f3e8b1ab124e631699d7247d22', false) && !trait_exists('ComposerAutoloaderInit318ac5f3e8b1ab124e631699d7247d22', false)) {
|
||||
spl_autoload_call('RectorPrefix20211128\ComposerAutoloaderInit318ac5f3e8b1ab124e631699d7247d22');
|
||||
}
|
||||
if (!class_exists('Helmich\TypoScriptParser\Parser\AST\Statement', false) && !interface_exists('Helmich\TypoScriptParser\Parser\AST\Statement', false) && !trait_exists('Helmich\TypoScriptParser\Parser\AST\Statement', false)) {
|
||||
spl_autoload_call('RectorPrefix20211128\Helmich\TypoScriptParser\Parser\AST\Statement');
|
||||
@ -81,9 +81,9 @@ if (!function_exists('print_node')) {
|
||||
return \RectorPrefix20211128\print_node(...func_get_args());
|
||||
}
|
||||
}
|
||||
if (!function_exists('composerRequireb0edd70802cd8b0614e2d4b03138e349')) {
|
||||
function composerRequireb0edd70802cd8b0614e2d4b03138e349() {
|
||||
return \RectorPrefix20211128\composerRequireb0edd70802cd8b0614e2d4b03138e349(...func_get_args());
|
||||
if (!function_exists('composerRequire318ac5f3e8b1ab124e631699d7247d22')) {
|
||||
function composerRequire318ac5f3e8b1ab124e631699d7247d22() {
|
||||
return \RectorPrefix20211128\composerRequire318ac5f3e8b1ab124e631699d7247d22(...func_get_args());
|
||||
}
|
||||
}
|
||||
if (!function_exists('scanPath')) {
|
||||
|
Loading…
x
Reference in New Issue
Block a user