phpDocTagRemover = $phpDocTagRemover; } public function getRuleDefinition() : RuleDefinition { return new RuleDefinition('Remove annotation by names', [new ConfiguredCodeSample(<<<'CODE_SAMPLE' /** * @method getName() */ final class SomeClass { } CODE_SAMPLE , <<<'CODE_SAMPLE' final class SomeClass { } CODE_SAMPLE , ['method'])]); } /** * @return array> */ public function getNodeTypes() : array { return [ClassLike::class, FunctionLike::class, Property::class, ClassConst::class]; } /** * @param ClassLike|FunctionLike|Property|ClassConst $node */ public function refactor(Node $node) : ?Node { if ($this->annotationsToRemove === []) { return null; } $phpDocInfo = $this->phpDocInfoFactory->createFromNodeOrEmpty($node); foreach ($this->annotationsToRemove as $annotationToRemove) { $this->phpDocTagRemover->removeByName($phpDocInfo, $annotationToRemove); if (!\is_a($annotationToRemove, PhpDocTagValueNode::class, \true)) { continue; } $phpDocInfo->removeByType($annotationToRemove); } if ($phpDocInfo->hasChanged()) { return $node; } return null; } /** * @param mixed[] $configuration */ public function configure(array $configuration) : void { Assert::allString($configuration); $this->annotationsToRemove = $configuration; } }