~ubuntu-branches/ubuntu/vivid/php-codesniffer/vivid

« back to all changes in this revision

Viewing changes to PHP_CodeSniffer-1.5.4/CodeSniffer/Standards/Generic/Sniffs/PHP/DisallowShortOpenTagSniff.php

  • Committer: Package Import Robot
  • Author(s): David Prévot, Greg Sherwood, Alexey, Emily, David Prévot
  • Date: 2014-09-26 13:44:35 UTC
  • mfrom: (1.1.6)
  • Revision ID: package-import@ubuntu.com-20140926134435-wvjq16miqq4d60y0
Tags: 1.5.5-1
[ Greg Sherwood ]
* Improved closure support in Generic ScopeIndentSniff
* Improved indented PHP tag support in Generic ScopeIndentSniff
* Standards can now be located within hidden directories
 (further fix for bug #20323)
* Fixed bug #20373 : Inline comment sniff tab handling way
* Fixed bug #20378 : Report appended to existing file if no errors
  found in run
* Fixed bug #20381 : Invalid "Comment closer must be on a new line"
* PHP tokenizer no longer converts class/function names to special
  tokens types
* Fixed bug #20386 : Squiz.Commenting.ClassComment.SpacingBefore
  thrown if first block comment
* Squiz and PEAR FunctionCommentSnif now support _()
* PEAR ValidFunctionNameSniff no longer throws an error for _()
* Fixed bug #248 : FunctionCommentSniff expects ampersand on param name
* Fixed bug #248 in Squiz sniff as well
* Fixed bug #265 : False positives with type hints in ForbiddenFunctionsSniff
* Prepare for 1.5.5 release

[ Alexey ]
* Allowed single undersored methods and functions

[ Emily ]
* Added var_dump to discouraged functions sniff

[ David Prévot ]
* Revert "Add XS-Testsuite still needed for ci.d.n"
* Add self to uploaders
* Bump standards version to 3.9.6

Show diffs side-by-side

added added

removed removed

Lines of Context:
1
 
<?php
2
 
/**
3
 
 * Generic_Sniffs_PHP_DisallowShortOpenTagSniff.
4
 
 *
5
 
 * PHP version 5
6
 
 *
7
 
 * @category  PHP
8
 
 * @package   PHP_CodeSniffer
9
 
 * @author    Greg Sherwood <gsherwood@squiz.net>
10
 
 * @author    Marc McIntyre <mmcintyre@squiz.net>
11
 
 * @copyright 2006-2014 Squiz Pty Ltd (ABN 77 084 670 600)
12
 
 * @license   https://github.com/squizlabs/PHP_CodeSniffer/blob/master/licence.txt BSD Licence
13
 
 * @link      http://pear.php.net/package/PHP_CodeSniffer
14
 
 */
15
 
 
16
 
/**
17
 
 * Generic_Sniffs_PHP_DisallowShortOpenTagSniff.
18
 
 *
19
 
 * Makes sure that shorthand PHP open tags are not used.
20
 
 *
21
 
 * @category  PHP
22
 
 * @package   PHP_CodeSniffer
23
 
 * @author    Greg Sherwood <gsherwood@squiz.net>
24
 
 * @author    Marc McIntyre <mmcintyre@squiz.net>
25
 
 * @copyright 2006-2014 Squiz Pty Ltd (ABN 77 084 670 600)
26
 
 * @license   https://github.com/squizlabs/PHP_CodeSniffer/blob/master/licence.txt BSD Licence
27
 
 * @version   Release: 1.5.4
28
 
 * @link      http://pear.php.net/package/PHP_CodeSniffer
29
 
 */
30
 
class Generic_Sniffs_PHP_DisallowShortOpenTagSniff implements PHP_CodeSniffer_Sniff
31
 
{
32
 
 
33
 
 
34
 
    /**
35
 
     * Returns an array of tokens this test wants to listen for.
36
 
     *
37
 
     * @return array
38
 
     */
39
 
    public function register()
40
 
    {
41
 
        return array(
42
 
                T_OPEN_TAG,
43
 
                T_OPEN_TAG_WITH_ECHO,
44
 
               );
45
 
 
46
 
    }//end register()
47
 
 
48
 
 
49
 
    /**
50
 
     * Processes this test, when one of its tokens is encountered.
51
 
     *
52
 
     * @param PHP_CodeSniffer_File $phpcsFile The file being scanned.
53
 
     * @param int                  $stackPtr  The position of the current token
54
 
     *                                        in the stack passed in $tokens.
55
 
     *
56
 
     * @return void
57
 
     */
58
 
    public function process(PHP_CodeSniffer_File $phpcsFile, $stackPtr)
59
 
    {
60
 
        $tokens  = $phpcsFile->getTokens();
61
 
        $openTag = $tokens[$stackPtr];
62
 
 
63
 
        if ($openTag['content'] === '<?') {
64
 
            $error = 'Short PHP opening tag used; expected "<?php" but found "%s"';
65
 
            $data  = array($openTag['content']);
66
 
            $phpcsFile->addError($error, $stackPtr, 'Found', $data);
67
 
        }
68
 
 
69
 
        if ($openTag['code'] === T_OPEN_TAG_WITH_ECHO) {
70
 
            $nextVar = $tokens[$phpcsFile->findNext(PHP_CodeSniffer_Tokens::$emptyTokens, ($stackPtr + 1), null, true)];
71
 
            $error   = 'Short PHP opening tag used with echo; expected "<?php echo %s ..." but found "%s %s ..."';
72
 
            $data = array(
73
 
                     $nextVar['content'],
74
 
                     $openTag['content'],
75
 
                     $nextVar['content'],
76
 
                    );
77
 
            $phpcsFile->addError($error, $stackPtr, 'EchoFound', $data);
78
 
        }
79
 
 
80
 
    }//end process()
81
 
 
82
 
 
83
 
}//end class
84
 
 
85
 
?>