From 9103d799683aef845b123cc4f38d0042eaabdfcc Mon Sep 17 00:00:00 2001 From: jrfnl Date: Tue, 4 Jul 2017 03:59:34 +0200 Subject: [PATCH] Add metrics to the `PSR2.ControlStructures.SwitchDeclaration` sniff I've explicitly not added metrics for: * lowercase keyword as those are already recorded by the `Generic.PHP.LowerCaseKeyword` sniff * `break`/`return` not on a line by itself as that is already recorded by the `Generic.Formatting.DisallowMultipleStatements` sniff --- .../SwitchDeclarationSniff.php | 26 ++++++++++++++++++- 1 file changed, 25 insertions(+), 1 deletion(-) diff --git a/src/Standards/PSR2/Sniffs/ControlStructures/SwitchDeclarationSniff.php b/src/Standards/PSR2/Sniffs/ControlStructures/SwitchDeclarationSniff.php index a63ba88198..b42e881833 100644 --- a/src/Standards/PSR2/Sniffs/ControlStructures/SwitchDeclarationSniff.php +++ b/src/Standards/PSR2/Sniffs/ControlStructures/SwitchDeclarationSniff.php @@ -85,6 +85,12 @@ public function process(File $phpcsFile, $stackPtr) && ($tokens[($nextCase + 1)]['code'] !== T_WHITESPACE || $tokens[($nextCase + 1)]['content'] !== ' ') ) { + if ($tokens[($nextCase + 1)]['code'] === T_WHITESPACE) { + $phpcsFile->recordMetric($nextCase, 'Spaces following the "case" keyword', $tokens[($nextCase + 1)]['length']); + } else { + $phpcsFile->recordMetric($nextCase, 'Spaces following the "case" keyword', 'none'); + } + $error = 'CASE keyword must be followed by a single space'; $fix = $phpcsFile->addFixableError($error, $nextCase, 'SpacingAfterCase'); if ($fix === true) { @@ -94,17 +100,24 @@ public function process(File $phpcsFile, $stackPtr) $phpcsFile->fixer->replaceToken(($nextCase + 1), ' '); } } + } else if ($type === 'case') { + $phpcsFile->recordMetric($nextCase, 'Spaces following the "case" keyword', 1); } $opener = $tokens[$nextCase]['scope_opener']; $nextCloser = $tokens[$nextCase]['scope_closer']; if ($tokens[$opener]['code'] === T_COLON) { + $phpcsFile->recordMetric($opener, 'Default/case statement followed by colon', 'yes'); + if ($tokens[($opener - 1)]['code'] === T_WHITESPACE) { + $phpcsFile->recordMetric($opener, 'Spaces before colon after case/default keyword', $tokens[($opener - 1)]['length']); $error = 'There must be no space before the colon in a '.strtoupper($type).' statement'; $fix = $phpcsFile->addFixableError($error, $nextCase, 'SpaceBeforeColon'.strtoupper($type)); if ($fix === true) { $phpcsFile->fixer->replaceToken(($opener - 1), ''); } + } else { + $phpcsFile->recordMetric($opener, 'Spaces before colon after case/default keyword', 0); } for ($next = ($opener + 1); $next < $nextCloser; $next++) { @@ -116,6 +129,8 @@ public function process(File $phpcsFile, $stackPtr) } } + $phpcsFile->recordMetric($opener, 'Blank lines at start of case/default body', ($tokens[$next]['line'] - ($tokens[$opener]['line'] + 1))); + if ($tokens[$next]['line'] !== ($tokens[$opener]['line'] + 1)) { $error = 'The '.strtoupper($type).' body must start on the line following the statement'; $fix = $phpcsFile->addFixableError($error, $nextCase, 'BodyOnNextLine'.strtoupper($type)); @@ -158,6 +173,7 @@ public function process(File $phpcsFile, $stackPtr) } else { $diff = ($tokens[$nextCase]['column'] + $this->indent - $tokens[$nextCloser]['column']); if ($diff !== 0) { + $phpcsFile->recordMetric($nextCloser, 'Terminating statement aligned with body of case', 'no'); $error = 'Terminating statement must be indented to the same level as the CASE body'; $fix = $phpcsFile->addFixableError($error, $nextCloser, 'BreakIndent'); if ($fix === true) { @@ -167,10 +183,13 @@ public function process(File $phpcsFile, $stackPtr) $phpcsFile->fixer->substrToken(($nextCloser - 1), 0, $diff); } } + } else { + $phpcsFile->recordMetric($nextCloser, 'Terminating statement aligned with body of case', 'yes'); } }//end if }//end if } else { + $phpcsFile->recordMetric($opener, 'Default/case statement followed by colon', 'no'); $error = strtoupper($type).' statements must be defined using a colon'; $phpcsFile->addError($error, $nextCase, 'WrongOpener'.$type); }//end if @@ -193,11 +212,16 @@ public function process(File $phpcsFile, $stackPtr) if (isset(Tokens::$commentTokens[$tokens[$prevCode]['code']]) === false && $this->findNestedTerminator($phpcsFile, ($opener + 1), $nextCode) === false ) { + $phpcsFile->recordMetric($nextCode, 'Case falls through to next', 'yes, without comment'); $error = 'There must be a comment when fall-through is intentional in a non-empty case body'; $phpcsFile->addError($error, $nextCase, 'TerminatingComment'); + } else { + $phpcsFile->recordMetric($nextCode, 'Case falls through to next', 'yes, with comment'); } + } else { + $phpcsFile->recordMetric($nextCode, 'Case falls through to next', 'no'); } - } + }//end if }//end while }//end process()