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

Breadcrumb

  1. Drupal Core 11.1.x

RequireOneLinePropertyDocCommentSniff.php

Namespace

SlevomatCodingStandard\Sniffs\Commenting

File

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

View source
<?php

declare (strict_types=1);
namespace SlevomatCodingStandard\Sniffs\Commenting;

use PHP_CodeSniffer\Files\File;
use SlevomatCodingStandard\Helpers\DocCommentHelper;
use SlevomatCodingStandard\Helpers\PropertyHelper;
use SlevomatCodingStandard\Helpers\TokenHelper;
use function sprintf;
use const T_VARIABLE;
class RequireOneLinePropertyDocCommentSniff extends AbstractRequireOneLineDocComment {
    public const CODE_MULTI_LINE_PROPERTY_COMMENT = 'MultiLinePropertyComment';
    
    /**
     * @phpcsSuppress SlevomatCodingStandard.TypeHints.ParameterTypeHint.MissingNativeTypeHint
     * @param int $docCommentStartPointer
     */
    public function process(File $phpcsFile, $docCommentStartPointer) : void {
        $propertyPointer = TokenHelper::findNext($phpcsFile, T_VARIABLE, $docCommentStartPointer + 1);
        if ($propertyPointer === null) {
            return;
        }
        // Not a property
        if (!PropertyHelper::isProperty($phpcsFile, $propertyPointer)) {
            return;
        }
        // Check that doc comment belongs to the found property
        $propertyDocCommentStartPointer = DocCommentHelper::findDocCommentOpenPointer($phpcsFile, $propertyPointer);
        if ($propertyDocCommentStartPointer !== $docCommentStartPointer) {
            return;
        }
        // Only validate properties without description
        if (DocCommentHelper::hasDocCommentDescription($phpcsFile, $propertyPointer)) {
            return;
        }
        parent::process($phpcsFile, $docCommentStartPointer);
    }
    protected function addError(File $phpcsFile, int $docCommentStartPointer) : bool {
        $error = 'Found multi-line comment for property %s with single line content, use one-line comment instead.';
        
        /** @var int $propertyPointer */
        $propertyPointer = $phpcsFile->findNext(T_VARIABLE, $docCommentStartPointer);
        return $phpcsFile->addFixableError(sprintf($error, PropertyHelper::getFullyQualifiedName($phpcsFile, $propertyPointer)), $docCommentStartPointer, self::CODE_MULTI_LINE_PROPERTY_COMMENT);
    }

}

Classes

Title Deprecated Summary
RequireOneLinePropertyDocCommentSniff
RSS feed
Powered by Drupal