PATH:
opt
/
cpanel
/
ea-wappspector
/
vendor
/
slevomat
/
coding-standard
/
SlevomatCodingStandard
/
Sniffs
/
Functions
<?php declare(strict_types = 1); namespace SlevomatCodingStandard\Sniffs\Functions; use PHP_CodeSniffer\Files\File; use PHP_CodeSniffer\Sniffs\Sniff; use SlevomatCodingStandard\Helpers\FixerHelper; use SlevomatCodingStandard\Helpers\TokenHelper; use SlevomatCodingStandard\Helpers\VariableHelper; use const T_CLOSURE; use const T_DOUBLE_QUOTED_STRING; use const T_FN; use const T_OPEN_PARENTHESIS; use const T_PARENT; use const T_STATIC; use const T_STRING; use const T_VARIABLE; class StaticClosureSniff implements Sniff { public const CODE_CLOSURE_NOT_STATIC = 'ClosureNotStatic'; /** * @return array<int, (int|string)> */ public function register(): array { return [ T_CLOSURE, T_FN, ]; } /** * @phpcsSuppress SlevomatCodingStandard.TypeHints.ParameterTypeHint.MissingNativeTypeHint * @param int $closurePointer */ public function process(File $phpcsFile, $closurePointer): void { $tokens = $phpcsFile->getTokens(); $previousPointer = TokenHelper::findPreviousEffective($phpcsFile, $closurePointer - 1); if ($tokens[$previousPointer]['code'] === T_STATIC) { return; } if ($tokens[$previousPointer]['code'] === T_OPEN_PARENTHESIS) { $pointerBeforeParenthesis = TokenHelper::findPreviousEffective($phpcsFile, $previousPointer - 1); if ( $tokens[$pointerBeforeParenthesis]['code'] === T_STRING && $tokens[$pointerBeforeParenthesis]['content'] === 'bind' ) { return; } } $closureScopeOpenerPointer = $tokens[$closurePointer]['scope_opener']; $closureScopeCloserPointer = $tokens[$closurePointer]['scope_closer']; $thisPointer = TokenHelper::findNextContent( $phpcsFile, T_VARIABLE, '$this', $closureScopeOpenerPointer + 1, $closureScopeCloserPointer + 1, ); if ($thisPointer !== null) { return; } $stringPointers = TokenHelper::findNextAll( $phpcsFile, T_DOUBLE_QUOTED_STRING, $closureScopeOpenerPointer + 1, $closureScopeCloserPointer, ); foreach ($stringPointers as $stringPointer) { if (VariableHelper::isUsedInScopeInString($phpcsFile, '$this', $stringPointer)) { return; } } $parentPointer = TokenHelper::findNext($phpcsFile, T_PARENT, $closureScopeOpenerPointer + 1, $closureScopeCloserPointer); if ($parentPointer !== null) { return; } $fix = $phpcsFile->addFixableError( 'Closure not using "$this" should be declared static.', $closurePointer, self::CODE_CLOSURE_NOT_STATIC, ); if (!$fix) { return; } $phpcsFile->fixer->beginChangeset(); FixerHelper::addBefore($phpcsFile, $closurePointer, 'static '); $phpcsFile->fixer->endChangeset(); } }
[-] ArrowFunctionDeclarationSniff.php
[edit]
[-] StrictCallSniff.php
[edit]
[-] UselessParameterDefaultValueSniff.php
[edit]
[-] RequireTrailingCommaInCallSniff.php
[edit]
[-] DisallowTrailingCommaInCallSniff.php
[edit]
[-] RequireMultiLineCallSniff.php
[edit]
[+]
..
[-] UnusedInheritedVariablePassedToClosureSniff.php
[edit]
[-] NamedArgumentSpacingSniff.php
[edit]
[-] RequireTrailingCommaInClosureUseSniff.php
[edit]
[-] DisallowTrailingCommaInDeclarationSniff.php
[edit]
[-] RequireArrowFunctionSniff.php
[edit]
[-] DisallowArrowFunctionSniff.php
[edit]
[-] DisallowTrailingCommaInClosureUseSniff.php
[edit]
[-] DisallowNamedArgumentsSniff.php
[edit]
[-] RequireTrailingCommaInDeclarationSniff.php
[edit]
[-] FunctionLengthSniff.php
[edit]
[-] RequireSingleLineCallSniff.php
[edit]
[-] UnusedParameterSniff.php
[edit]
[-] StaticClosureSniff.php
[edit]
[-] DisallowEmptyFunctionSniff.php
[edit]
[-] AbstractLineCall.php
[edit]