class UselessFunctionDocCommentSniff
Hierarchy
- class \SlevomatCodingStandard\Sniffs\Commenting\UselessFunctionDocCommentSniff implements \PHP_CodeSniffer\Sniffs\Sniff
Expanded class hierarchy of UselessFunctionDocCommentSniff
File
-
vendor/
slevomat/ coding-standard/ SlevomatCodingStandard/ Sniffs/ Commenting/ UselessFunctionDocCommentSniff.php, line 20
Namespace
SlevomatCodingStandard\Sniffs\CommentingView source
class UselessFunctionDocCommentSniff implements Sniff {
public const CODE_USELESS_DOC_COMMENT = 'UselessDocComment';
/** @var list<string> */
public $traversableTypeHints = [];
/** @var array<int, string>|null */
private $normalizedTraversableTypeHints;
/**
* @return array<int, (int|string)>
*/
public function register() : array {
return [
T_FUNCTION,
];
}
/**
* @phpcsSuppress SlevomatCodingStandard.TypeHints.ParameterTypeHint.MissingNativeTypeHint
* @param int $functionPointer
*/
public function process(File $phpcsFile, $functionPointer) : void {
if (!DocCommentHelper::hasDocComment($phpcsFile, $functionPointer)) {
return;
}
if (DocCommentHelper::hasInheritdocAnnotation($phpcsFile, $functionPointer)) {
return;
}
if (DocCommentHelper::hasDocCommentDescription($phpcsFile, $functionPointer)) {
return;
}
$returnTypeHint = FunctionHelper::findReturnTypeHint($phpcsFile, $functionPointer);
$returnAnnotation = FunctionHelper::findReturnAnnotation($phpcsFile, $functionPointer);
if ($returnAnnotation !== null && !AnnotationHelper::isAnnotationUseless($phpcsFile, $functionPointer, $returnTypeHint, $returnAnnotation, $this->getTraversableTypeHints())) {
return;
}
$parameterTypeHints = FunctionHelper::getParametersTypeHints($phpcsFile, $functionPointer);
$parametersAnnotations = FunctionHelper::getValidParametersAnnotations($phpcsFile, $functionPointer);
foreach ($parametersAnnotations as $parameterName => $parameterAnnotation) {
if (!array_key_exists($parameterName, $parameterTypeHints)) {
return;
}
if (!AnnotationHelper::isAnnotationUseless($phpcsFile, $functionPointer, $parameterTypeHints[$parameterName], $parameterAnnotation, $this->getTraversableTypeHints())) {
return;
}
}
foreach (AnnotationHelper::getAnnotations($phpcsFile, $functionPointer) as $annotation) {
if (!in_array($annotation->getName(), [
'@param',
'@return',
], true)) {
return;
}
}
$fix = $phpcsFile->addFixableError(sprintf('%s %s() does not need documentation comment.', FunctionHelper::getTypeLabel($phpcsFile, $functionPointer), FunctionHelper::getFullyQualifiedName($phpcsFile, $functionPointer)), $functionPointer, self::CODE_USELESS_DOC_COMMENT);
if (!$fix) {
return;
}
/** @var int $docCommentOpenPointer */
$docCommentOpenPointer = DocCommentHelper::findDocCommentOpenPointer($phpcsFile, $functionPointer);
$docCommentClosePointer = $phpcsFile->getTokens()[$docCommentOpenPointer]['comment_closer'];
$changeStart = $docCommentOpenPointer;
/** @var int $changeEnd */
$changeEnd = TokenHelper::findNextEffective($phpcsFile, $docCommentClosePointer + 1) - 1;
$phpcsFile->fixer
->beginChangeset();
FixerHelper::removeBetweenIncluding($phpcsFile, $changeStart, $changeEnd);
$phpcsFile->fixer
->endChangeset();
}
/**
* @return array<int, string>
*/
private function getTraversableTypeHints() : array {
if ($this->normalizedTraversableTypeHints === null) {
$this->normalizedTraversableTypeHints = array_map(static function (string $typeHint) : string {
return NamespaceHelper::isFullyQualifiedName($typeHint) ? $typeHint : sprintf('%s%s', NamespaceHelper::NAMESPACE_SEPARATOR, $typeHint);
}, SniffSettingsHelper::normalizeArray($this->traversableTypeHints));
}
return $this->normalizedTraversableTypeHints;
}
}
Members
Title Sort descending | Modifiers | Object type | Summary | Overriden Title |
---|---|---|---|---|
UselessFunctionDocCommentSniff::$normalizedTraversableTypeHints | private | property | @var array<int, string>|null | |
UselessFunctionDocCommentSniff::$traversableTypeHints | public | property | @var list<string> | |
UselessFunctionDocCommentSniff::CODE_USELESS_DOC_COMMENT | public | constant | ||
UselessFunctionDocCommentSniff::getTraversableTypeHints | private | function | * | |
UselessFunctionDocCommentSniff::process | public | function | * @phpcsSuppress SlevomatCodingStandard.TypeHints.ParameterTypeHint.MissingNativeTypeHint * |
Overrides Sniff::process |
UselessFunctionDocCommentSniff::register | public | function | * | Overrides Sniff::register |