3
* PSR2_Sniffs_WhiteSpace_ControlStructureSpacingSniff.
8
* @package PHP_CodeSniffer
9
* @author Greg Sherwood <gsherwood@squiz.net>
10
* @copyright 2006-2014 Squiz Pty Ltd (ABN 77 084 670 600)
11
* @license https://github.com/squizlabs/PHP_CodeSniffer/blob/master/licence.txt BSD Licence
12
* @link http://pear.php.net/package/PHP_CodeSniffer
16
* PSR2_Sniffs_WhiteSpace_ControlStructureSpacingSniff.
18
* Checks that control structures have the correct spacing around brackets.
21
* @package PHP_CodeSniffer
22
* @author Greg Sherwood <gsherwood@squiz.net>
23
* @copyright 2006-2014 Squiz Pty Ltd (ABN 77 084 670 600)
24
* @license https://github.com/squizlabs/PHP_CodeSniffer/blob/master/licence.txt BSD Licence
25
* @version Release: 2.3.2
26
* @link http://pear.php.net/package/PHP_CodeSniffer
28
class PSR2_Sniffs_ControlStructures_ControlStructureSpacingSniff implements PHP_CodeSniffer_Sniff
33
* How many spaces should follow the opening bracket.
37
public $requiredSpacesAfterOpen = 0;
40
* How many spaces should precede the closing bracket.
44
public $requiredSpacesBeforeClose = 0;
48
* Returns an array of tokens this test wants to listen for.
52
public function register()
71
* Processes this test, when one of its tokens is encountered.
73
* @param PHP_CodeSniffer_File $phpcsFile The file being scanned.
74
* @param int $stackPtr The position of the current token
75
* in the stack passed in $tokens.
79
public function process(PHP_CodeSniffer_File $phpcsFile, $stackPtr)
81
$this->requiredSpacesAfterOpen = (int) $this->requiredSpacesAfterOpen;
82
$this->requiredSpacesBeforeClose = (int) $this->requiredSpacesBeforeClose;
83
$tokens = $phpcsFile->getTokens();
85
if (isset($tokens[$stackPtr]['parenthesis_opener']) === false
86
|| isset($tokens[$stackPtr]['parenthesis_closer']) === false
91
$parenOpener = $tokens[$stackPtr]['parenthesis_opener'];
92
$parenCloser = $tokens[$stackPtr]['parenthesis_closer'];
94
if ($tokens[($parenOpener + 1)]['code'] === T_WHITESPACE) {
95
if (strpos($tokens[($parenOpener + 1)]['content'], $phpcsFile->eolChar) !== false) {
96
$spaceAfterOpen = 'newline';
98
$spaceAfterOpen = strlen($tokens[($parenOpener + 1)]['content']);
102
$phpcsFile->recordMetric($stackPtr, 'Spaces after control structure open parenthesis', $spaceAfterOpen);
104
if ($spaceAfterOpen !== $this->requiredSpacesAfterOpen) {
105
$error = 'Expected %s spaces after opening bracket; %s found';
107
$this->requiredSpacesAfterOpen,
110
$fix = $phpcsFile->addFixableError($error, ($parenOpener + 1), 'SpacingAfterOpenBrace', $data);
112
$padding = str_repeat(' ', $this->requiredSpacesAfterOpen);
113
if ($spaceAfterOpen === 0) {
114
$phpcsFile->fixer->addContent($parenOpener, $padding);
115
} else if ($spaceAfterOpen === 'newline') {
116
$phpcsFile->fixer->replaceToken(($parenOpener + 1), '');
118
$phpcsFile->fixer->replaceToken(($parenOpener + 1), $padding);
123
if ($tokens[$parenOpener]['line'] === $tokens[$parenCloser]['line']) {
124
$spaceBeforeClose = 0;
125
if ($tokens[($parenCloser - 1)]['code'] === T_WHITESPACE) {
126
$spaceBeforeClose = strlen(ltrim($tokens[($parenCloser - 1)]['content'], $phpcsFile->eolChar));
129
$phpcsFile->recordMetric($stackPtr, 'Spaces before control structure close parenthesis', $spaceBeforeClose);
131
if ($spaceBeforeClose !== $this->requiredSpacesBeforeClose) {
132
$error = 'Expected %s spaces before closing bracket; %s found';
134
$this->requiredSpacesBeforeClose,
137
$fix = $phpcsFile->addFixableError($error, ($parenCloser - 1), 'SpaceBeforeCloseBrace', $data);
139
$padding = str_repeat(' ', $this->requiredSpacesBeforeClose);
140
if ($spaceBeforeClose === 0) {
141
$phpcsFile->fixer->addContentBefore($parenCloser, $padding);
143
$phpcsFile->fixer->replaceToken(($parenCloser - 1), $padding);