?????????? ????????? - ??????????????? - /home/agenciai/public_html/cd38d8/Visibility.tar
???????
ValueObject/ChangeMethodVisibility.php 0000644 00000001533 15126466667 0014103 0 ustar 00 <?php declare (strict_types=1); namespace Rector\Visibility\ValueObject; use Rector\Validation\RectorAssert; final class ChangeMethodVisibility { /** * @readonly * @var string */ private $class; /** * @readonly * @var string */ private $method; /** * @readonly * @var int */ private $visibility; public function __construct(string $class, string $method, int $visibility) { $this->class = $class; $this->method = $method; $this->visibility = $visibility; RectorAssert::className($class); } public function getClass() : string { return $this->class; } public function getMethod() : string { return $this->method; } public function getVisibility() : int { return $this->visibility; } } ValueObject/ChangeConstantVisibility.php 0000644 00000001637 15126466667 0014461 0 ustar 00 <?php declare (strict_types=1); namespace Rector\Visibility\ValueObject; use PHPStan\Type\ObjectType; use Rector\Validation\RectorAssert; final class ChangeConstantVisibility { /** * @readonly * @var string */ private $class; /** * @readonly * @var string */ private $constant; /** * @readonly * @var int */ private $visibility; public function __construct(string $class, string $constant, int $visibility) { $this->class = $class; $this->constant = $constant; $this->visibility = $visibility; RectorAssert::className($class); } public function getObjectType() : ObjectType { return new ObjectType($this->class); } public function getConstant() : string { return $this->constant; } public function getVisibility() : int { return $this->visibility; } } Rector/ClassConst/ChangeConstantVisibilityRector.php 0000644 00000006076 15126466667 0016751 0 ustar 00 <?php declare (strict_types=1); namespace Rector\Visibility\Rector\ClassConst; use PhpParser\Node; use PhpParser\Node\Stmt\Class_; use PhpParser\Node\Stmt\Interface_; use Rector\Contract\Rector\ConfigurableRectorInterface; use Rector\Privatization\NodeManipulator\VisibilityManipulator; use Rector\Rector\AbstractRector; use Rector\ValueObject\Visibility; use Rector\Visibility\ValueObject\ChangeConstantVisibility; use Symplify\RuleDocGenerator\ValueObject\CodeSample\ConfiguredCodeSample; use Symplify\RuleDocGenerator\ValueObject\RuleDefinition; use RectorPrefix202411\Webmozart\Assert\Assert; /** * @see \Rector\Tests\Visibility\Rector\ClassConst\ChangeConstantVisibilityRector\ChangeConstantVisibilityRectorTest */ final class ChangeConstantVisibilityRector extends AbstractRector implements ConfigurableRectorInterface { /** * @readonly * @var \Rector\Privatization\NodeManipulator\VisibilityManipulator */ private $visibilityManipulator; /** * @var ChangeConstantVisibility[] */ private $classConstantVisibilityChanges = []; public function __construct(VisibilityManipulator $visibilityManipulator) { $this->visibilityManipulator = $visibilityManipulator; } public function getRuleDefinition() : RuleDefinition { return new RuleDefinition('Change visibility of constant from parent class.', [new ConfiguredCodeSample(<<<'CODE_SAMPLE' class FrameworkClass { protected const SOME_CONSTANT = 1; } class MyClass extends FrameworkClass { public const SOME_CONSTANT = 1; } CODE_SAMPLE , <<<'CODE_SAMPLE' class FrameworkClass { protected const SOME_CONSTANT = 1; } class MyClass extends FrameworkClass { protected const SOME_CONSTANT = 1; } CODE_SAMPLE , [new ChangeConstantVisibility('ParentObject', 'SOME_CONSTANT', Visibility::PROTECTED)])]); } /** * @return array<class-string<Node>> */ public function getNodeTypes() : array { return [Class_::class, Interface_::class]; } /** * @param Class_|Interface_ $node */ public function refactor(Node $node) : ?Node { $hasChanged = \false; foreach ($this->classConstantVisibilityChanges as $classConstantVisibilityChange) { if (!$this->isObjectType($node, $classConstantVisibilityChange->getObjectType())) { continue; } foreach ($node->getConstants() as $classConst) { if (!$this->isName($classConst, $classConstantVisibilityChange->getConstant())) { continue; } $this->visibilityManipulator->changeNodeVisibility($classConst, $classConstantVisibilityChange->getVisibility()); $hasChanged = \true; } } if ($hasChanged) { return $node; } return null; } /** * @param mixed[] $configuration */ public function configure(array $configuration) : void { Assert::allIsAOf($configuration, ChangeConstantVisibility::class); $this->classConstantVisibilityChanges = $configuration; } } Rector/ClassMethod/ExplicitPublicClassMethodRector.php 0000644 00000002745 15126466667 0017202 0 ustar 00 <?php declare (strict_types=1); namespace Rector\Visibility\Rector\ClassMethod; use PhpParser\Node; use PhpParser\Node\Stmt\ClassMethod; use Rector\Privatization\NodeManipulator\VisibilityManipulator; use Rector\Rector\AbstractRector; use Symplify\RuleDocGenerator\ValueObject\CodeSample\CodeSample; use Symplify\RuleDocGenerator\ValueObject\RuleDefinition; /** * @see \Rector\Tests\Visibility\Rector\ClassMethod\ExplicitPublicClassMethodRector\ExplicitPublicClassMethodRectorTest */ final class ExplicitPublicClassMethodRector extends AbstractRector { /** * @readonly * @var \Rector\Privatization\NodeManipulator\VisibilityManipulator */ private $visibilityManipulator; public function __construct(VisibilityManipulator $visibilityManipulator) { $this->visibilityManipulator = $visibilityManipulator; } public function getRuleDefinition() : RuleDefinition { return new RuleDefinition('Add explicit public method visibility.', [new CodeSample(<<<'CODE_SAMPLE' class SomeClass { function foo() { } } CODE_SAMPLE , <<<'CODE_SAMPLE' class SomeClass { public function foo() { } } CODE_SAMPLE )]); } /** * @return array<class-string<Node>> */ public function getNodeTypes() : array { return [ClassMethod::class]; } /** * @param ClassMethod $node */ public function refactor(Node $node) : ?Node { return $this->visibilityManipulator->publicize($node); } } Rector/ClassMethod/ChangeMethodVisibilityRector.php 0000644 00000006567 15126466667 0016537 0 ustar 00 <?php declare (strict_types=1); namespace Rector\Visibility\Rector\ClassMethod; use PhpParser\Node; use PhpParser\Node\Stmt\ClassMethod; use PHPStan\Analyser\Scope; use Rector\Contract\Rector\ConfigurableRectorInterface; use Rector\NodeCollector\ScopeResolver\ParentClassScopeResolver; use Rector\Privatization\NodeManipulator\VisibilityManipulator; use Rector\Rector\AbstractScopeAwareRector; use Rector\ValueObject\Visibility; use Rector\Visibility\ValueObject\ChangeMethodVisibility; use Symplify\RuleDocGenerator\ValueObject\CodeSample\ConfiguredCodeSample; use Symplify\RuleDocGenerator\ValueObject\RuleDefinition; use RectorPrefix202411\Webmozart\Assert\Assert; /** * @see \Rector\Tests\Visibility\Rector\ClassMethod\ChangeMethodVisibilityRector\ChangeMethodVisibilityRectorTest */ final class ChangeMethodVisibilityRector extends AbstractScopeAwareRector implements ConfigurableRectorInterface { /** * @readonly * @var \Rector\NodeCollector\ScopeResolver\ParentClassScopeResolver */ private $parentClassScopeResolver; /** * @readonly * @var \Rector\Privatization\NodeManipulator\VisibilityManipulator */ private $visibilityManipulator; /** * @var ChangeMethodVisibility[] */ private $methodVisibilities = []; public function __construct(ParentClassScopeResolver $parentClassScopeResolver, VisibilityManipulator $visibilityManipulator) { $this->parentClassScopeResolver = $parentClassScopeResolver; $this->visibilityManipulator = $visibilityManipulator; } public function getRuleDefinition() : RuleDefinition { return new RuleDefinition('Change visibility of method from parent class.', [new ConfiguredCodeSample(<<<'CODE_SAMPLE' class FrameworkClass { protected function someMethod() { } } class MyClass extends FrameworkClass { public function someMethod() { } } CODE_SAMPLE , <<<'CODE_SAMPLE' class FrameworkClass { protected function someMethod() { } } class MyClass extends FrameworkClass { protected function someMethod() { } } CODE_SAMPLE , [new ChangeMethodVisibility('FrameworkClass', 'someMethod', Visibility::PROTECTED)])]); } /** * @return array<class-string<Node>> */ public function getNodeTypes() : array { return [ClassMethod::class]; } /** * @param ClassMethod $node */ public function refactorWithScope(Node $node, Scope $scope) : ?Node { if ($this->methodVisibilities === []) { return null; } $parentClassName = $this->parentClassScopeResolver->resolveParentClassName($scope); if ($parentClassName === null) { return null; } foreach ($this->methodVisibilities as $methodVisibility) { if ($methodVisibility->getClass() !== $parentClassName) { continue; } if (!$this->isName($node, $methodVisibility->getMethod())) { continue; } $this->visibilityManipulator->changeNodeVisibility($node, $methodVisibility->getVisibility()); return $node; } return null; } /** * @param mixed[] $configuration */ public function configure(array $configuration) : void { Assert::allIsAOf($configuration, ChangeMethodVisibility::class); $this->methodVisibilities = $configuration; } }
| ver. 1.6 |
Github
|
.
| PHP 8.2.30 | ??????????? ?????????: 0 |
proxy
|
phpinfo
|
???????????