Preview: UselessInheritDocCommentSniff.php
Size: 3.13 KB
/opt/cpanel/ea-wappspector/vendor/slevomat/coding-standard/SlevomatCodingStandard/Sniffs/Commenting/UselessInheritDocCommentSniff.php
<?php declare(strict_types = 1);
namespace SlevomatCodingStandard\Sniffs\Commenting;
use PHP_CodeSniffer\Files\File;
use PHP_CodeSniffer\Sniffs\Sniff;
use SlevomatCodingStandard\Helpers\FixerHelper;
use SlevomatCodingStandard\Helpers\FunctionHelper;
use SlevomatCodingStandard\Helpers\TokenHelper;
use SlevomatCodingStandard\Helpers\TypeHintHelper;
use function in_array;
use function preg_match;
use const T_ATTRIBUTE;
use const T_DOC_COMMENT_OPEN_TAG;
use const T_DOC_COMMENT_STAR;
use const T_DOC_COMMENT_WHITESPACE;
class UselessInheritDocCommentSniff implements Sniff
{
public const CODE_USELESS_INHERIT_DOC_COMMENT = 'UselessInheritDocComment';
/**
* @return array<int, (int|string)>
*/
public function register(): array
{
return [
T_DOC_COMMENT_OPEN_TAG,
];
}
/**
* @phpcsSuppress SlevomatCodingStandard.TypeHints.ParameterTypeHint.MissingNativeTypeHint
* @param int $docCommentOpenPointer
*/
public function process(File $phpcsFile, $docCommentOpenPointer): void
{
$tokens = $phpcsFile->getTokens();
$docCommentContent = '';
for ($i = $docCommentOpenPointer + 1; $i < $tokens[$docCommentOpenPointer]['comment_closer']; $i++) {
if (in_array($tokens[$i]['code'], [T_DOC_COMMENT_WHITESPACE, T_DOC_COMMENT_STAR], true)) {
continue;
}
$docCommentContent .= $tokens[$i]['content'];
}
if (preg_match('~^(?:\{@inheritDoc\}|@inheritDoc)$~i', $docCommentContent) === 0) {
return;
}
$searchPointer = $tokens[$docCommentOpenPointer]['comment_closer'] + 1;
do {
$docCommentOwnerPointer = TokenHelper::findNext(
$phpcsFile,
[...TokenHelper::FUNCTION_TOKEN_CODES, ...TokenHelper::TYPE_HINT_TOKEN_CODES, T_ATTRIBUTE],
$searchPointer,
);
if ($docCommentOwnerPointer === null) {
return;
}
if ($tokens[$docCommentOwnerPointer]['code'] === T_ATTRIBUTE) {
$searchPointer = $tokens[$docCommentOwnerPointer]['attribute_closer'] + 1;
continue;
}
break;
} while (true);
if (in_array($tokens[$docCommentOwnerPointer]['code'], TokenHelper::FUNCTION_TOKEN_CODES, true)) {
$returnTypeHint = FunctionHelper::findReturnTypeHint($phpcsFile, $docCommentOwnerPointer);
if ($returnTypeHint === null) {
return;
}
if (TypeHintHelper::isSimpleIterableTypeHint($returnTypeHint->getTypeHintWithoutNullabilitySymbol())) {
return;
}
$parametersTypeHints = FunctionHelper::getParametersTypeHints($phpcsFile, $docCommentOwnerPointer);
foreach ($parametersTypeHints as $parameterTypeHint) {
if ($parameterTypeHint === null) {
return;
}
if (TypeHintHelper::isSimpleIterableTypeHint($parameterTypeHint->getTypeHint())) {
return;
}
}
}
$fix = $phpcsFile->addFixableError(
'Useless documentation comment with @inheritDoc.',
$docCommentOpenPointer,
self::CODE_USELESS_INHERIT_DOC_COMMENT,
);
if (!$fix) {
return;
}
/** @var int $fixerStart */
$fixerStart = TokenHelper::findLastTokenOnPreviousLine($phpcsFile, $docCommentOpenPointer);
$phpcsFile->fixer->beginChangeset();
FixerHelper::removeBetweenIncluding($phpcsFile, $fixerStart, $tokens[$docCommentOpenPointer]['comment_closer']);
$phpcsFile->fixer->endChangeset();
}
}
Directory Contents
Dirs: 0 × Files: 14