~ubuntu-branches/ubuntu/utopic/php-codesniffer/utopic-proposed

« back to all changes in this revision

Viewing changes to PHP_CodeSniffer-1.5.0RC2/CodeSniffer/Standards/Generic/Sniffs/Formatting/DisallowMultipleStatementsSniff.php

  • Committer: Package Import Robot
  • Author(s): David Prévot
  • Date: 2014-07-21 14:42:41 UTC
  • mto: This revision was merged to the branch mainline in revision 7.
  • Revision ID: package-import@ubuntu.com-20140721144241-t0v9knmgtzftbsw6
Tags: upstream-1.5.3
Import upstream version 1.5.3

Show diffs side-by-side

added added

removed removed

Lines of Context:
1
 
<?php
2
 
/**
3
 
 * Generic_Sniffs_Formatting_DisallowMultipleStatementsSniff.
4
 
 *
5
 
 * PHP version 5
6
 
 *
7
 
 * @category  PHP
8
 
 * @package   PHP_CodeSniffer
9
 
 * @author    Greg Sherwood <gsherwood@squiz.net>
10
 
 * @copyright 2006-2012 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
 
 * Generic_Sniffs_Formatting_DisallowMultipleStatementsSniff.
17
 
 *
18
 
 * Ensures each statement is on a line by itself.
19
 
 *
20
 
 * @category  PHP
21
 
 * @package   PHP_CodeSniffer
22
 
 * @author    Greg Sherwood <gsherwood@squiz.net>
23
 
 * @copyright 2006-2012 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: 1.5.0RC2
26
 
 * @link      http://pear.php.net/package/PHP_CodeSniffer
27
 
 */
28
 
class Generic_Sniffs_Formatting_DisallowMultipleStatementsSniff implements PHP_CodeSniffer_Sniff
29
 
{
30
 
 
31
 
 
32
 
    /**
33
 
     * Returns an array of tokens this test wants to listen for.
34
 
     *
35
 
     * @return array
36
 
     */
37
 
    public function register()
38
 
    {
39
 
        return array(T_SEMICOLON);
40
 
 
41
 
    }//end register()
42
 
 
43
 
 
44
 
    /**
45
 
     * Processes this test, when one of its tokens is encountered.
46
 
     *
47
 
     * @param PHP_CodeSniffer_File $phpcsFile The file being scanned.
48
 
     * @param int                  $stackPtr  The position of the current token in
49
 
     *                                        the stack passed in $tokens.
50
 
     *
51
 
     * @return void
52
 
     */
53
 
    public function process(PHP_CodeSniffer_File $phpcsFile, $stackPtr)
54
 
    {
55
 
        $tokens = $phpcsFile->getTokens();
56
 
 
57
 
        $prev = $phpcsFile->findPrevious(T_SEMICOLON, ($stackPtr - 1));
58
 
        if ($prev === false) {
59
 
            return;
60
 
        }
61
 
 
62
 
        // Ignore multiple statements in a FOR condition.
63
 
        if (isset($tokens[$stackPtr]['nested_parenthesis']) === true) {
64
 
            foreach ($tokens[$stackPtr]['nested_parenthesis'] as $bracket) {
65
 
                if (isset($tokens[$bracket]['parenthesis_owner']) === false) {
66
 
                    // Probably a closure sitting inside a function call.
67
 
                    continue;
68
 
                }
69
 
 
70
 
                $owner = $tokens[$bracket]['parenthesis_owner'];
71
 
                if ($tokens[$owner]['code'] === T_FOR) {
72
 
                    return;
73
 
                }
74
 
            }
75
 
        }
76
 
 
77
 
        if ($tokens[$prev]['line'] === $tokens[$stackPtr]['line']) {
78
 
            $error = 'Each PHP statement must be on a line by itself';
79
 
            $phpcsFile->addError($error, $stackPtr, 'SameLine');
80
 
            return;
81
 
        }
82
 
 
83
 
    }//end process()
84
 
 
85
 
 
86
 
}//end class
87
 
 
88
 
?>