!C99Shell v. 1.0 pre-release build #13!

Software: Apache. PHP/5.5.15 

uname -a: Windows NT SVR-DMZ 6.1 build 7600 (Windows Server 2008 R2 Enterprise Edition) i586 

SYSTEM 

Safe-mode: OFF (not secure)

E:\nuevo\php\pear\PHP\CodeSniffer\Standards\Squiz\Sniffs\Operators\   drwxrwxrwx
Free 1012.08 MB of 239.26 GB (0.41%)
Detected drives: [ a ] [ c ] [ d ] [ e ] [ f ]
Home    Back    Forward    UPDIR    Refresh    Search    Buffer    Encoder    Tools    Proc.    FTP brute    Sec.    SQL    PHP-code    Update    Feedback    Self remove    Logout    


Viewing file:     IncrementDecrementUsageSniff.php (8.05 KB)      -rw-rw-rw-
Select action/file-type:
(+) | (+) | (+) | Code (+) | Session (+) | (+) | SDB (+) | (+) | (+) | (+) | (+) | (+) |
<?php
/**
 * Squiz_Sniffs_Operators_IncrementDecrementUsageSniff.
 *
 * PHP version 5
 *
 * @category  PHP
 * @package   PHP_CodeSniffer
 * @author    Greg Sherwood <gsherwood@squiz.net>
 * @author    Marc McIntyre <mmcintyre@squiz.net>
 * @copyright 2006-2011 Squiz Pty Ltd (ABN 77 084 670 600)
 * @license   http://matrix.squiz.net/developer/tools/php_cs/licence BSD Licence
 * @link      http://pear.php.net/package/PHP_CodeSniffer
 */

/**
 * Squiz_Sniffs_Operators_IncrementDecrementUsageSniff.
 *
 * Tests that the ++ operators are used when possible and not
 * used when it makes the code confusing.
 *
 * @category  PHP
 * @package   PHP_CodeSniffer
 * @author    Greg Sherwood <gsherwood@squiz.net>
 * @author    Marc McIntyre <mmcintyre@squiz.net>
 * @copyright 2006-2011 Squiz Pty Ltd (ABN 77 084 670 600)
 * @license   http://matrix.squiz.net/developer/tools/php_cs/licence BSD Licence
 * @version   Release: 1.3.3
 * @link      http://pear.php.net/package/PHP_CodeSniffer
 */
class Squiz_Sniffs_Operators_IncrementDecrementUsageSniff implements PHP_CodeSniffer_Sniff
{


    
/**
     * Returns an array of tokens this test wants to listen for.
     *
     * @return array
     */
    
public function register()
    {
        return array(
                
T_EQUAL,
                
T_PLUS_EQUAL,
                
T_MINUS_EQUAL,
                
T_INC,
                
T_DEC,
               );

    }
//end register()


    /**
     * Processes this test, when one of its tokens is encountered.
     *
     * @param PHP_CodeSniffer_File $phpcsFile The file being scanned.
     * @param int                  $stackPtr  The position of the current token
     *                                        in the stack passed in $tokens.
     *
     * @return void
     */
    
public function process(PHP_CodeSniffer_File $phpcsFile$stackPtr)
    {
        
$tokens $phpcsFile->getTokens();

        if (
$tokens[$stackPtr]['code'] === T_INC || $tokens[$stackPtr]['code'] === T_DEC) {
            
$this->processIncDec($phpcsFile$stackPtr);
        } else {
            
$this->processAssignment($phpcsFile$stackPtr);
        }

    }
//end process()


    /**
     * Checks to ensure increment and decrement operators are not confusing.
     *
     * @param PHP_CodeSniffer_File $phpcsFile The file being scanned.
     * @param int                  $stackPtr  The position of the current token
     *                                        in the stack passed in $tokens.
     *
     * @return void
     */
    
protected function processIncDec(PHP_CodeSniffer_File $phpcsFile$stackPtr)
    {
        
$tokens $phpcsFile->getTokens();

        
// Work out where the variable is so we know where to
        // start looking for other operators.
        
if ($tokens[($stackPtr 1)]['code'] === T_VARIABLE) {
            
$start = ($stackPtr 1);
        } else {
            
$start = ($stackPtr 2);
        }

        
$next $phpcsFile->findNext(PHP_CodeSniffer_Tokens::$emptyTokens$startnulltrue);
        if (
$next === false) {
            return;
        }

        if (
in_array($tokens[$next]['code'], PHP_CodeSniffer_Tokens::$arithmeticTokens) === true) {
            
$error 'Increment and decrement operators cannot be used in an arithmetic operation';
            
$phpcsFile->addError($error$stackPtr'NotAllowed');
            return;
        }

        
$prev $phpcsFile->findPrevious(PHP_CodeSniffer_Tokens::$emptyTokens, ($start 3), nulltrue);
        if (
$prev === false) {
            return;
        }

        
// Check if this is in a string concat.
        
if ($tokens[$next]['code'] === T_STRING_CONCAT || $tokens[$prev]['code'] === T_STRING_CONCAT) {
            
$error 'Increment and decrement operators must be bracketed when used in string concatenation';
            
$phpcsFile->addError($error$stackPtr'NoBrackets');
        }

    }
//end processIncDec()


    /**
     * Checks to ensure increment and decrement operators are used.
     *
     * @param PHP_CodeSniffer_File $phpcsFile The file being scanned.
     * @param int                  $stackPtr  The position of the current token
     *                                        in the stack passed in $tokens.
     *
     * @return void
     */
    
protected function processAssignment(PHP_CodeSniffer_File $phpcsFile$stackPtr)
    {
        
$tokens $phpcsFile->getTokens();

        
$assignedVar $phpcsFile->findPrevious(T_WHITESPACE, ($stackPtr 1), nulltrue);
        
// Not an assignment, return.
        
if ($tokens[$assignedVar]['code'] !== T_VARIABLE) {
            return;
        }

        
$statementEnd $phpcsFile->findNext(array(T_SEMICOLONT_CLOSE_PARENTHESIST_CLOSE_SQUARE_BRACKETT_CLOSE_CURLY_BRACKET), $stackPtr);

        
// If there is anything other than variables, numbers, spaces or operators we need to return.
        
$noiseTokens $phpcsFile->findNext(array(T_LNUMBERT_VARIABLET_WHITESPACET_PLUST_MINUST_OPEN_PARENTHESIS), ($stackPtr 1), $statementEndtrue);

        if (
$noiseTokens !== false) {
            return;
        }

        
// If we are already using += or -=, we need to ignore
        // the statement if a variable is being used.
        
if ($tokens[$stackPtr]['code'] !== T_EQUAL) {
            
$nextVar $phpcsFile->findNext(T_VARIABLE, ($stackPtr 1), $statementEnd);
            if (
$nextVar !== false) {
                return;
            }
        }

        if (
$tokens[$stackPtr]['code'] === T_EQUAL) {
            
$nextVar          = ($stackPtr 1);
            
$previousVariable = ($stackPtr 1);
            
$variableCount    0;
            while ((
$nextVar $phpcsFile->findNext(T_VARIABLE, ($nextVar 1), $statementEnd)) !== false) {
                
$previousVariable $nextVar;
                
$variableCount++;
            }

            if (
$variableCount !== 1) {
                return;
            }

            
$nextVar $previousVariable;
            if (
$tokens[$nextVar]['content'] !== $tokens[$assignedVar]['content']) {
                return;
            }
        }

        
// We have only one variable, and it's the same as what is being assigned,
        // so we need to check what is being added or subtracted.
        
$nextNumber     = ($stackPtr 1);
        
$previousNumber = ($stackPtr 1);
        
$numberCount    0;
        while ((
$nextNumber $phpcsFile->findNext(array(T_LNUMBER), ($nextNumber 1), $statementEndfalse)) !== false) {
            
$previousNumber $nextNumber;
            
$numberCount++;
        }

        if (
$numberCount !== 1) {
            return;
        }

        
$nextNumber $previousNumber;
        if (
$tokens[$nextNumber]['content'] === '1') {
            if (
$tokens[$stackPtr]['code'] === T_EQUAL) {
                
$opToken $phpcsFile->findNext(array(T_PLUST_MINUS), ($nextVar 1), $statementEnd);
                if (
$opToken === false) {
                    
// Operator was before the variable, like:
                    // $var = 1 + $var;
                    // So we ignore it.
                    
return;
                }

                
$operator $tokens[$opToken]['content'];
            } else {
                
$operator substr($tokens[$stackPtr]['content'], 01);
            }

            
// If we are adding or subtracting negative value, the operator
            // needs to be reversed.
            
if ($tokens[$stackPtr]['code'] !== T_EQUAL) {
                
$negative $phpcsFile->findPrevious(T_MINUS, ($nextNumber 1), $stackPtr);
                if (
$negative !== false) {
                    
$operator = ($operator === '+') ? '-' '+';
                }
            }

            
$expected $tokens[$assignedVar]['content'].$operator.$operator;
            
$found    $phpcsFile->getTokensAsString($assignedVar, ($statementEnd $assignedVar 1));

            if (
$operator === '+') {
                
$error 'Increment';
            } else {
                
$error 'Decrement';
            }

            
$error .= " operators should be used where possible; found \"$found\" but expected \"$expected\"";
            
$phpcsFile->addError($error$stackPtr);
        }
//end if

    
}//end processAssignment()


}//end class

?>

:: Command execute ::

Enter:
 
Select:
 

:: Search ::
  - regexp 

:: Upload ::
 
[ ok ]

:: Make Dir ::
 
[ ok ]
:: Make File ::
 
[ ok ]

:: Go Dir ::
 
:: Go File ::
 

--[ c99shell v. 1.0 pre-release build #13 powered by Captain Crunch Security Team | http://ccteam.ru | Generation time: 0.0312 ]--