1<?php 2/** 3 * Squiz_Sniffs_CSS_EmptyClassDefinitionSniff. 4 * 5 * PHP version 5 6 * 7 * @category PHP 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 13 */ 14 15/** 16 * Squiz_Sniffs_CSS_EmptyClassDefinitionSniff. 17 * 18 * Ensure that class definitions are not empty. 19 * 20 * @category PHP 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: @package_version@ 26 * @link http://pear.php.net/package/PHP_CodeSniffer 27 */ 28class Squiz_Sniffs_CSS_EmptyClassDefinitionSniff implements PHP_CodeSniffer_Sniff 29{ 30 31 /** 32 * A list of tokenizers this sniff supports. 33 * 34 * @var array 35 */ 36 public $supportedTokenizers = array('CSS'); 37 38 39 /** 40 * Returns the token types that this sniff is interested in. 41 * 42 * @return int[] 43 */ 44 public function register() 45 { 46 return array(T_OPEN_CURLY_BRACKET); 47 48 }//end register() 49 50 51 /** 52 * Processes the tokens that this sniff is interested in. 53 * 54 * @param PHP_CodeSniffer_File $phpcsFile The file where the token was found. 55 * @param int $stackPtr The position in the stack where 56 * the token was found. 57 * 58 * @return void 59 */ 60 public function process(PHP_CodeSniffer_File $phpcsFile, $stackPtr) 61 { 62 $tokens = $phpcsFile->getTokens(); 63 $next = $phpcsFile->findNext(PHP_CodeSniffer_Tokens::$emptyTokens, ($stackPtr + 1), null, true); 64 65 if ($next === false || $tokens[$next]['code'] === T_CLOSE_CURLY_BRACKET) { 66 $error = 'Class definition is empty'; 67 $phpcsFile->addError($error, $stackPtr, 'Found'); 68 } 69 70 }//end process() 71 72 73}//end class 74