annotate vendor/drupal/coder/coder_sniffer/Drupal/Sniffs/Commenting/PostStatementCommentSniff.php @ 2:92f882872392

Trusted hosts, + remove migration modules
author Chris Cannam
date Tue, 05 Dec 2017 09:26:43 +0000
parents 4c8ae668cc8c
children 129ea1e6d783
rev   line source
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