Chris@0
|
1 <?php
|
Chris@0
|
2 /**
|
Chris@0
|
3 * Drupal_Sniffs_Semantics_FunctionDefinition.
|
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 * Helper class to sniff for function definitions.
|
Chris@0
|
12 *
|
Chris@0
|
13 * @category PHP
|
Chris@0
|
14 * @package PHP_CodeSniffer
|
Chris@0
|
15 * @link http://pear.php.net/package/PHP_CodeSniffer
|
Chris@0
|
16 */
|
Chris@0
|
17 abstract class Drupal_Sniffs_Semantics_FunctionDefinition implements PHP_CodeSniffer_Sniff
|
Chris@0
|
18 {
|
Chris@0
|
19
|
Chris@0
|
20
|
Chris@0
|
21 /**
|
Chris@0
|
22 * Returns an array of tokens this test wants to listen for.
|
Chris@0
|
23 *
|
Chris@0
|
24 * @return array
|
Chris@0
|
25 */
|
Chris@0
|
26 public function register()
|
Chris@0
|
27 {
|
Chris@0
|
28 return array(T_STRING);
|
Chris@0
|
29
|
Chris@0
|
30 }//end register()
|
Chris@0
|
31
|
Chris@0
|
32
|
Chris@0
|
33 /**
|
Chris@0
|
34 * Processes this test, when one of its tokens is encountered.
|
Chris@0
|
35 *
|
Chris@0
|
36 * @param PHP_CodeSniffer_File $phpcsFile The file being scanned.
|
Chris@0
|
37 * @param int $stackPtr The position of the current token
|
Chris@0
|
38 * in the stack passed in $tokens.
|
Chris@0
|
39 *
|
Chris@0
|
40 * @return void
|
Chris@0
|
41 */
|
Chris@0
|
42 public function process(PHP_CodeSniffer_File $phpcsFile, $stackPtr)
|
Chris@0
|
43 {
|
Chris@0
|
44 $tokens = $phpcsFile->getTokens();
|
Chris@0
|
45 // Check if this is a function definition.
|
Chris@0
|
46 $functionPtr = $phpcsFile->findPrevious(
|
Chris@0
|
47 PHP_CodeSniffer_Tokens::$emptyTokens,
|
Chris@0
|
48 ($stackPtr - 1),
|
Chris@0
|
49 null,
|
Chris@0
|
50 true
|
Chris@0
|
51 );
|
Chris@0
|
52 if ($tokens[$functionPtr]['code'] === T_FUNCTION) {
|
Chris@0
|
53 $this->processFunction($phpcsFile, $stackPtr, $functionPtr);
|
Chris@0
|
54 }
|
Chris@0
|
55
|
Chris@0
|
56 }//end process()
|
Chris@0
|
57
|
Chris@0
|
58
|
Chris@0
|
59 /**
|
Chris@0
|
60 * Process this function definition.
|
Chris@0
|
61 *
|
Chris@0
|
62 * @param PHP_CodeSniffer_File $phpcsFile The file being scanned.
|
Chris@0
|
63 * @param int $stackPtr The position of the function name in the stack.
|
Chris@0
|
64 * name in the stack.
|
Chris@0
|
65 * @param int $functionPtr The position of the function keyword in the stack.
|
Chris@0
|
66 * keyword in the stack.
|
Chris@0
|
67 *
|
Chris@0
|
68 * @return void
|
Chris@0
|
69 */
|
Chris@0
|
70 public abstract function processFunction(PHP_CodeSniffer_File $phpcsFile, $stackPtr, $functionPtr);
|
Chris@0
|
71
|
Chris@0
|
72
|
Chris@0
|
73 }//end class
|