Seditio Source
Root |
./othercms/croogo-4.0.7/vendor/squizlabs/php_codesniffer/src/Reports/Cbf.php
<?php
/**
 * CBF report for PHP_CodeSniffer.
 *
 * This report implements the various auto-fixing features of the
 * PHPCBF script and is not intended (or allowed) to be selected as a
 * report from the command line.
 *
 * @author    Greg Sherwood <gsherwood@squiz.net>
 * @copyright 2006-2015 Squiz Pty Ltd (ABN 77 084 670 600)
 * @license   https://github.com/squizlabs/PHP_CodeSniffer/blob/master/licence.txt BSD Licence
 */

namespace PHP_CodeSniffer\Reports;

use
PHP_CodeSniffer\Exceptions\DeepExitException;
use
PHP_CodeSniffer\Files\File;
use
PHP_CodeSniffer\Util;

class
Cbf implements Report
{


   
/**
     * Generate a partial report for a single processed file.
     *
     * Function should return TRUE if it printed or stored data about the file
     * and FALSE if it ignored the file. Returning TRUE indicates that the file and
     * its data should be counted in the grand totals.
     *
     * @param array                 $report      Prepared report data.
     * @param \PHP_CodeSniffer\File $phpcsFile   The file being reported on.
     * @param bool                  $showSources Show sources?
     * @param int                   $width       Maximum allowed line width.
     *
     * @return bool
     * @throws \PHP_CodeSniffer\Exceptions\DeepExitException
     */
   
public function generateFileReport($report, File $phpcsFile, $showSources=false, $width=80)
    {
       
$errors = $phpcsFile->getFixableCount();
        if (
$errors !== 0) {
            if (
PHP_CODESNIFFER_VERBOSITY > 0) {
               
ob_end_clean();
               
$startTime = microtime(true);
                echo
"\t=> Fixing file: $errors/$errors violations remaining";
            }

           
$fixed = $phpcsFile->fixer->fixFile();
        }

        if (
$phpcsFile->config->stdin === true) {
           
// Replacing STDIN, so output current file to STDOUT
            // even if nothing was fixed. Exit here because we
            // can't process any more than 1 file in this setup.
           
$fixedContent = $phpcsFile->fixer->getContents();
            throw new
DeepExitException($fixedContent, 1);
        }

        if (
$errors === 0) {
            return
false;
        }

        if (
PHP_CODESNIFFER_VERBOSITY > 0) {
            if (
$fixed === false) {
                echo
'ERROR';
            } else {
                echo
'DONE';
            }

           
$timeTaken = ((microtime(true) - $startTime) * 1000);
            if (
$timeTaken < 1000) {
               
$timeTaken = round($timeTaken);
                echo
" in {$timeTaken}ms".PHP_EOL;
            } else {
               
$timeTaken = round(($timeTaken / 1000), 2);
                echo
" in $timeTaken secs".PHP_EOL;
            }
        }

        if (
$fixed === true) {
           
// The filename in the report may be truncated due to a basepath setting
            // but we are using it for writing here and not display,
            // so find the correct path if basepath is in use.
           
$newFilename = $report['filename'].$phpcsFile->config->suffix;
            if (
$phpcsFile->config->basepath !== null) {
               
$newFilename = $phpcsFile->config->basepath.DIRECTORY_SEPARATOR.$newFilename;
            }

           
$newContent = $phpcsFile->fixer->getContents();
           
file_put_contents($newFilename, $newContent);

            if (
PHP_CODESNIFFER_VERBOSITY > 0) {
                if (
$newFilename === $report['filename']) {
                    echo
"\t=> File was overwritten".PHP_EOL;
                } else {
                    echo
"\t=> Fixed file written to ".basename($newFilename).PHP_EOL;
                }
            }
        }

        if (
PHP_CODESNIFFER_VERBOSITY > 0) {
           
ob_start();
        }

       
$errorCount   = $phpcsFile->getErrorCount();
       
$warningCount = $phpcsFile->getWarningCount();
       
$fixableCount = $phpcsFile->getFixableCount();
       
$fixedCount   = ($errors - $fixableCount);
        echo
$report['filename'].">>$errorCount>>$warningCount>>$fixableCount>>$fixedCount".PHP_EOL;

        return
$fixed;

    }
//end generateFileReport()


    /**
     * Prints a summary of fixed files.
     *
     * @param string $cachedData    Any partial report data that was returned from
     *                              generateFileReport during the run.
     * @param int    $totalFiles    Total number of files processed during the run.
     * @param int    $totalErrors   Total number of errors found during the run.
     * @param int    $totalWarnings Total number of warnings found during the run.
     * @param int    $totalFixable  Total number of problems that can be fixed.
     * @param bool   $showSources   Show sources?
     * @param int    $width         Maximum allowed line width.
     * @param bool   $interactive   Are we running in interactive mode?
     * @param bool   $toScreen      Is the report being printed to screen?
     *
     * @return void
     */
   
public function generate(
       
$cachedData,
       
$totalFiles,
       
$totalErrors,
       
$totalWarnings,
       
$totalFixable,
       
$showSources=false,
       
$width=80,
       
$interactive=false,
       
$toScreen=true
   
) {
       
$lines = explode(PHP_EOL, $cachedData);
       
array_pop($lines);

        if (empty(
$lines) === true) {
            echo
PHP_EOL.'No fixable errors were found'.PHP_EOL;
            return;
        }

       
$reportFiles = [];
       
$maxLength   = 0;
       
$totalFixed  = 0;
       
$failures    = 0;

        foreach (
$lines as $line) {
           
$parts   = explode('>>', $line);
           
$fileLen = strlen($parts[0]);
           
$reportFiles[$parts[0]] = [
               
'errors'   => $parts[1],
               
'warnings' => $parts[2],
               
'fixable'  => $parts[3],
               
'fixed'    => $parts[4],
               
'strlen'   => $fileLen,
            ];

           
$maxLength = max($maxLength, $fileLen);

           
$totalFixed += $parts[4];

            if (
$parts[3] > 0) {
               
$failures++;
            }
        }

       
$width = min($width, ($maxLength + 21));
       
$width = max($width, 70);

        echo
PHP_EOL."\033[1m".'PHPCBF RESULT SUMMARY'."\033[0m".PHP_EOL;
        echo
str_repeat('-', $width).PHP_EOL;
        echo
"\033[1m".'FILE'.str_repeat(' ', ($width - 20)).'FIXED  REMAINING'."\033[0m".PHP_EOL;
        echo
str_repeat('-', $width).PHP_EOL;

        foreach (
$reportFiles as $file => $data) {
           
$padding = ($width - 18 - $data['strlen']);
            if (
$padding < 0) {
               
$file    = '...'.substr($file, (($padding * -1) + 3));
               
$padding = 0;
            }

            echo
$file.str_repeat(' ', $padding).'  ';

            if (
$data['fixable'] > 0) {
                echo
"\033[31mFAILED TO FIX\033[0m".PHP_EOL;
                continue;
            }

           
$remaining = ($data['errors'] + $data['warnings']);

            if (
$data['fixed'] !== 0) {
                echo
$data['fixed'];
                echo
str_repeat(' ', (7 - strlen((string) $data['fixed'])));
            } else {
                echo
'0      ';
            }

            if (
$remaining !== 0) {
                echo
$remaining;
            } else {
                echo
'0';
            }

            echo
PHP_EOL;
        }
//end foreach

       
echo str_repeat('-', $width).PHP_EOL;
        echo
"\033[1mA TOTAL OF $totalFixed ERROR";
        if (
$totalFixed !== 1) {
            echo
'S';
        }

       
$numFiles = count($reportFiles);
        echo
' WERE FIXED IN '.$numFiles.' FILE';
        if (
$numFiles !== 1) {
            echo
'S';
        }

        echo
"\033[0m";

        if (
$failures > 0) {
            echo
PHP_EOL.str_repeat('-', $width).PHP_EOL;
            echo
"\033[1mPHPCBF FAILED TO FIX $failures FILE";
            if (
$failures !== 1) {
                echo
'S';
            }

            echo
"\033[0m";
        }

        echo
PHP_EOL.str_repeat('-', $width).PHP_EOL.PHP_EOL;

        if (
$toScreen === true && $interactive === false) {
           
Util\Timing::printRunTime();
        }

    }
//end generate()


}//end class