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

Breadcrumb

  1. Drupal Core 11.1.x

RequireNumericLiteralSeparatorSniff.php

Namespace

SlevomatCodingStandard\Sniffs\Numbers

File

vendor/slevomat/coding-standard/SlevomatCodingStandard/Sniffs/Numbers/RequireNumericLiteralSeparatorSniff.php

View source
<?php

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

use PHP_CodeSniffer\Files\File;
use PHP_CodeSniffer\Sniffs\Sniff;
use SlevomatCodingStandard\Helpers\SniffSettingsHelper;
use function preg_match;
use function strpos;
use const T_DNUMBER;
use const T_LNUMBER;
class RequireNumericLiteralSeparatorSniff implements Sniff {
    public const CODE_REQUIRED_NUMERIC_LITERAL_SEPARATOR = 'RequiredNumericLiteralSeparator';
    
    /** @var bool|null */
    public $enable = null;
    
    /** @var int */
    public $minDigitsBeforeDecimalPoint = 4;
    
    /** @var int */
    public $minDigitsAfterDecimalPoint = 4;
    
    /** @var bool */
    public $ignoreOctalNumbers = true;
    
    /**
     * @return array<int, (int|string)>
     */
    public function register() : array {
        return [
            T_LNUMBER,
            T_DNUMBER,
        ];
    }
    
    /**
     * @phpcsSuppress SlevomatCodingStandard.TypeHints.ParameterTypeHint.MissingNativeTypeHint
     * @param int $numberPointer
     */
    public function process(File $phpcsFile, $numberPointer) : void {
        $this->enable = SniffSettingsHelper::isEnabledByPhpVersion($this->enable, 70400);
        $this->minDigitsBeforeDecimalPoint = SniffSettingsHelper::normalizeInteger($this->minDigitsBeforeDecimalPoint);
        $this->minDigitsAfterDecimalPoint = SniffSettingsHelper::normalizeInteger($this->minDigitsAfterDecimalPoint);
        if (!$this->enable) {
            return;
        }
        $tokens = $phpcsFile->getTokens();
        $number = $tokens[$numberPointer]['content'];
        if (strpos($tokens[$numberPointer]['content'], '_') !== false) {
            return;
        }
        if ($this->ignoreOctalNumbers && preg_match('~^0[0-7]+$~', $number) === 1) {
            return;
        }
        $regexp = '~(?:^\\d{' . $this->minDigitsBeforeDecimalPoint . '}|\\.\\d{' . $this->minDigitsAfterDecimalPoint . '})~';
        if (preg_match($regexp, $number) === 0) {
            return;
        }
        $phpcsFile->addError('Use of numeric literal separator is required.', $numberPointer, self::CODE_REQUIRED_NUMERIC_LITERAL_SEPARATOR);
    }

}

Classes

Title Deprecated Summary
RequireNumericLiteralSeparatorSniff
RSS feed
Powered by Drupal