Skip to content

Commit

Permalink
ControlStructures/AssignmentInCondition: prevent fatal error during l…
Browse files Browse the repository at this point in the history
…ive coding

```
Fatal error: Uncaught TypeError: SlevomatCodingStandard\Sniffs\ControlStructures\AssignmentInConditionSniff::processCondition(): Argument #3 ($parenthesisCloser) must be of type int, null given, called in path\to\SlevomatCodingStandard\Sniffs\ControlStructures\AssignmentInConditionSniff.php on line 56 and defined in path\to\SlevomatCodingStandard\Sniffs\ControlStructures\AssignmentInConditionSniff.php:59
Stack trace:
#0 path\to\SlevomatCodingStandard\Sniffs\ControlStructures\AssignmentInConditionSniff.php(56): SlevomatCodingStandard\Sniffs\ControlStructures\AssignmentInConditionSniff->processCondition(Object(PHP_CodeSniffer\Files\LocalFile), 100, NULL, 'if')
#1 D:\000_GitHub\PHPCS\PHP_CodeSniffer\src\Files\File.php(509): SlevomatCodingStandard\Sniffs\ControlStructures\AssignmentInConditionSniff->process(Object(PHP_CodeSniffer\Files\LocalFile), 99)
#2 D:\000_GitHub\PHPCS\PHP_CodeSniffer\src\Files\LocalFile.php(92): PHP_CodeSniffer\Files\File->process()
#3 D:\000_GitHub\PHPCS\PHP_CodeSniffer\src\Runner.php(632): PHP_CodeSniffer\Files\LocalFile->process()
#4 D:\000_GitHub\PHPCS\PHP_CodeSniffer\src\Runner.php(438): PHP_CodeSniffer\Runner->processFile(Object(PHP_CodeSniffer\Files\LocalFile))
#5 D:\000_GitHub\PHPCS\PHP_CodeSniffer\src\Runner.php(116): PHP_CodeSniffer\Runner->run()
#6 D:\000_GitHub\PHPCS\PHP_CodeSniffer\bin\phpcs(18): PHP_CodeSniffer\Runner->runPHPCS()
#7 {main}
  thrown in path\to\SlevomatCodingStandard\Sniffs\ControlStructures\AssignmentInConditionSniff.php on line 59
```
  • Loading branch information
jrfnl committed Sep 28, 2023
1 parent fc778da commit 3034fc5
Show file tree
Hide file tree
Showing 2 changed files with 9 additions and 0 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -53,6 +53,11 @@ public function process(File $phpcsFile, $conditionStartPointer): void
$parenthesisCloser = $token['parenthesis_closer'];
$type = $token['code'] === T_IF ? 'if' : 'elseif';
}

if (isset($parenthesisOpener, $parenthesisCloser) === false) {

Check failure on line 57 in SlevomatCodingStandard/Sniffs/ControlStructures/AssignmentInConditionSniff.php

View workflow job for this annotation

GitHub Actions / Static analysis (highest, 8.2, ubuntu-latest)

Strict comparison using === between true and false will always evaluate to false.

Check failure on line 57 in SlevomatCodingStandard/Sniffs/ControlStructures/AssignmentInConditionSniff.php

View workflow job for this annotation

GitHub Actions / Static analysis (highest, 8.2, ubuntu-latest)

Variable $parenthesisCloser in isset() always exists and is not nullable.

Check failure on line 57 in SlevomatCodingStandard/Sniffs/ControlStructures/AssignmentInConditionSniff.php

View workflow job for this annotation

GitHub Actions / Static analysis (highest, 8.2, ubuntu-latest)

Variable $parenthesisOpener in isset() always exists and is not nullable.
return;
}

$this->processCondition($phpcsFile, $parenthesisOpener, $parenthesisCloser, $type);
}

Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -43,3 +43,7 @@
do {

} while ($foo === 5);

// Live coding/parse error.
// This must be the last test in the file.
if ($a = 1

0 comments on commit 3034fc5

Please sign in to comment.