Chris@0
|
1 <?php
|
Chris@0
|
2 /**
|
Chris@0
|
3 * Drupal_Sniffs_Commenting_PostStatementCommentSniff.
|
Chris@0
|
4 *
|
Chris@0
|
5 * @category PHP
|
Chris@0
|
6 * @package PHP_CodeSniffer
|
Chris@0
|
7 * @link http://pear.php.net/package/PHP_CodeSniffer
|
Chris@0
|
8 */
|
Chris@0
|
9
|
Chris@0
|
10 /**
|
Chris@0
|
11 * Largely copied from Squiz_Sniffs_Commenting_PostStatementCommentSniff but we want
|
Chris@0
|
12 * the fixer to move the comment to the previous line.
|
Chris@0
|
13 *
|
Chris@0
|
14 * @category PHP
|
Chris@0
|
15 * @package PHP_CodeSniffer
|
Chris@0
|
16 * @link http://pear.php.net/package/PHP_CodeSniffer
|
Chris@0
|
17 */
|
Chris@0
|
18 class Drupal_Sniffs_Commenting_PostStatementCommentSniff implements PHP_CodeSniffer_Sniff
|
Chris@0
|
19 {
|
Chris@0
|
20
|
Chris@0
|
21 /**
|
Chris@0
|
22 * A list of tokenizers this sniff supports.
|
Chris@0
|
23 *
|
Chris@0
|
24 * @var array
|
Chris@0
|
25 */
|
Chris@0
|
26 public $supportedTokenizers = array('PHP');
|
Chris@0
|
27
|
Chris@0
|
28
|
Chris@0
|
29 /**
|
Chris@0
|
30 * Returns an array of tokens this test wants to listen for.
|
Chris@0
|
31 *
|
Chris@0
|
32 * @return array
|
Chris@0
|
33 */
|
Chris@0
|
34 public function register()
|
Chris@0
|
35 {
|
Chris@0
|
36 return array(T_COMMENT);
|
Chris@0
|
37
|
Chris@0
|
38 }//end register()
|
Chris@0
|
39
|
Chris@0
|
40
|
Chris@0
|
41 /**
|
Chris@0
|
42 * Processes this sniff, when one of its tokens is encountered.
|
Chris@0
|
43 *
|
Chris@0
|
44 * @param PHP_CodeSniffer_File $phpcsFile The file being scanned.
|
Chris@0
|
45 * @param int $stackPtr The position of the current token in the
|
Chris@0
|
46 * stack passed in $tokens.
|
Chris@0
|
47 *
|
Chris@0
|
48 * @return void
|
Chris@0
|
49 */
|
Chris@0
|
50 public function process(PHP_CodeSniffer_File $phpcsFile, $stackPtr)
|
Chris@0
|
51 {
|
Chris@0
|
52 $tokens = $phpcsFile->getTokens();
|
Chris@0
|
53
|
Chris@0
|
54 if (substr($tokens[$stackPtr]['content'], 0, 2) !== '//') {
|
Chris@0
|
55 return;
|
Chris@0
|
56 }
|
Chris@0
|
57
|
Chris@0
|
58 $commentLine = $tokens[$stackPtr]['line'];
|
Chris@0
|
59 $lastContent = $phpcsFile->findPrevious(T_WHITESPACE, ($stackPtr - 1), null, true);
|
Chris@0
|
60
|
Chris@0
|
61 if ($tokens[$lastContent]['line'] !== $commentLine) {
|
Chris@0
|
62 return;
|
Chris@0
|
63 }
|
Chris@0
|
64
|
Chris@0
|
65 if ($tokens[$lastContent]['code'] === T_CLOSE_CURLY_BRACKET) {
|
Chris@0
|
66 return;
|
Chris@0
|
67 }
|
Chris@0
|
68
|
Chris@0
|
69 // Special case for JS files.
|
Chris@0
|
70 if ($tokens[$lastContent]['code'] === T_COMMA
|
Chris@0
|
71 || $tokens[$lastContent]['code'] === T_SEMICOLON
|
Chris@0
|
72 ) {
|
Chris@0
|
73 $lastContent = $phpcsFile->findPrevious(T_WHITESPACE, ($lastContent - 1), null, true);
|
Chris@0
|
74 if ($tokens[$lastContent]['code'] === T_CLOSE_CURLY_BRACKET) {
|
Chris@0
|
75 return;
|
Chris@0
|
76 }
|
Chris@0
|
77 }
|
Chris@0
|
78
|
Chris@0
|
79 $error = 'Comments may not appear after statements';
|
Chris@0
|
80 $fix = $phpcsFile->addFixableError($error, $stackPtr, 'Found');
|
Chris@0
|
81 if ($fix === true) {
|
Chris@0
|
82 if ($tokens[$lastContent]['code'] === T_OPEN_TAG) {
|
Chris@0
|
83 $phpcsFile->fixer->addNewlineBefore($stackPtr);
|
Chris@0
|
84 return;
|
Chris@0
|
85 }
|
Chris@0
|
86
|
Chris@0
|
87 $lineStart = $stackPtr;
|
Chris@0
|
88 while ($tokens[$lineStart]['line'] === $tokens[$stackPtr]['line']
|
Chris@0
|
89 && $tokens[$lineStart]['code'] !== T_OPEN_TAG
|
Chris@0
|
90 ) {
|
Chris@0
|
91 $lineStart--;
|
Chris@0
|
92 }
|
Chris@0
|
93
|
Chris@0
|
94 $phpcsFile->fixer->beginChangeset();
|
Chris@0
|
95 $phpcsFile->fixer->addContent($lineStart, $tokens[$stackPtr]['content']);
|
Chris@0
|
96 $phpcsFile->fixer->replaceToken($stackPtr, $phpcsFile->eolChar);
|
Chris@0
|
97 $phpcsFile->fixer->endChangeset();
|
Chris@0
|
98 }
|
Chris@0
|
99
|
Chris@0
|
100 }//end process()
|
Chris@0
|
101
|
Chris@0
|
102
|
Chris@0
|
103 }//end class
|