Skip to main content
Drupal API
User account menu
  • Log in

Breadcrumb

  1. Drupal Core 11.1.x

UselessInheritDocCommentSniff.php

Namespace

SlevomatCodingStandard\Sniffs\Commenting

File

vendor/slevomat/coding-standard/SlevomatCodingStandard/Sniffs/Commenting/UselessInheritDocCommentSniff.php

View source
<?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 array_merge;
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, array_merge(TokenHelper::$functionTokenCodes, TokenHelper::getTypeHintTokenCodes(), [
                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::$functionTokenCodes, 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();
    }

}

Classes

Title Deprecated Summary
UselessInheritDocCommentSniff
RSS feed
Powered by Drupal