Chris@0
|
1 <?php
|
Chris@0
|
2 /**
|
Chris@0
|
3 * Source report for PHP_CodeSniffer.
|
Chris@0
|
4 *
|
Chris@0
|
5 * PHP version 5
|
Chris@0
|
6 *
|
Chris@0
|
7 * @category PHP
|
Chris@0
|
8 * @package PHP_CodeSniffer
|
Chris@0
|
9 * @author Gabriele Santini <gsantini@sqli.com>
|
Chris@0
|
10 * @author Greg Sherwood <gsherwood@squiz.net>
|
Chris@0
|
11 * @copyright 2009-2014 SQLI <www.sqli.com>
|
Chris@0
|
12 * @copyright 2006-2014 Squiz Pty Ltd (ABN 77 084 670 600)
|
Chris@0
|
13 * @license https://github.com/squizlabs/PHP_CodeSniffer/blob/master/licence.txt BSD Licence
|
Chris@0
|
14 * @link http://pear.php.net/package/PHP_CodeSniffer
|
Chris@0
|
15 */
|
Chris@0
|
16
|
Chris@0
|
17 /**
|
Chris@0
|
18 * Source report for PHP_CodeSniffer.
|
Chris@0
|
19 *
|
Chris@0
|
20 * PHP version 5
|
Chris@0
|
21 *
|
Chris@0
|
22 * @category PHP
|
Chris@0
|
23 * @package PHP_CodeSniffer
|
Chris@0
|
24 * @author Gabriele Santini <gsantini@sqli.com>
|
Chris@0
|
25 * @author Greg Sherwood <gsherwood@squiz.net>
|
Chris@0
|
26 * @copyright 2009-2014 SQLI <www.sqli.com>
|
Chris@0
|
27 * @copyright 2006-2014 Squiz Pty Ltd (ABN 77 084 670 600)
|
Chris@0
|
28 * @license https://github.com/squizlabs/PHP_CodeSniffer/blob/master/licence.txt BSD Licence
|
Chris@0
|
29 * @version Release: @package_version@
|
Chris@0
|
30 * @link http://pear.php.net/package/PHP_CodeSniffer
|
Chris@0
|
31 */
|
Chris@0
|
32 class PHP_CodeSniffer_Reports_Source implements PHP_CodeSniffer_Report
|
Chris@0
|
33 {
|
Chris@0
|
34
|
Chris@0
|
35 /**
|
Chris@0
|
36 * A cache of source stats collected during the run.
|
Chris@0
|
37 *
|
Chris@0
|
38 * @var array
|
Chris@0
|
39 */
|
Chris@0
|
40 private $_sourceCache = array();
|
Chris@0
|
41
|
Chris@0
|
42
|
Chris@0
|
43 /**
|
Chris@0
|
44 * Generate a partial report for a single processed file.
|
Chris@0
|
45 *
|
Chris@0
|
46 * Function should return TRUE if it printed or stored data about the file
|
Chris@0
|
47 * and FALSE if it ignored the file. Returning TRUE indicates that the file and
|
Chris@0
|
48 * its data should be counted in the grand totals.
|
Chris@0
|
49 *
|
Chris@0
|
50 * @param array $report Prepared report data.
|
Chris@0
|
51 * @param PHP_CodeSniffer_File $phpcsFile The file being reported on.
|
Chris@0
|
52 * @param boolean $showSources Show sources?
|
Chris@0
|
53 * @param int $width Maximum allowed line width.
|
Chris@0
|
54 *
|
Chris@0
|
55 * @return boolean
|
Chris@0
|
56 */
|
Chris@0
|
57 public function generateFileReport(
|
Chris@0
|
58 $report,
|
Chris@0
|
59 PHP_CodeSniffer_File $phpcsFile,
|
Chris@0
|
60 $showSources=false,
|
Chris@0
|
61 $width=80
|
Chris@0
|
62 ) {
|
Chris@0
|
63 if ($report['errors'] === 0 && $report['warnings'] === 0) {
|
Chris@0
|
64 // Nothing to print.
|
Chris@0
|
65 return false;
|
Chris@0
|
66 }
|
Chris@0
|
67
|
Chris@0
|
68 foreach ($report['messages'] as $line => $lineErrors) {
|
Chris@0
|
69 foreach ($lineErrors as $column => $colErrors) {
|
Chris@0
|
70 foreach ($colErrors as $error) {
|
Chris@0
|
71 $source = $error['source'];
|
Chris@0
|
72 if (isset($this->_sourceCache[$source]) === false) {
|
Chris@0
|
73 if ($showSources === true) {
|
Chris@0
|
74 $parts = null;
|
Chris@0
|
75 $sniff = $source;
|
Chris@0
|
76 } else {
|
Chris@0
|
77 $parts = explode('.', $source);
|
Chris@0
|
78 if ($parts[0] === 'Internal') {
|
Chris@0
|
79 $parts[2] = $parts[1];
|
Chris@0
|
80 $parts[1] = '';
|
Chris@0
|
81 }
|
Chris@0
|
82
|
Chris@0
|
83 $parts[1] = $this->makeFriendlyName($parts[1]);
|
Chris@0
|
84
|
Chris@0
|
85 $sniff = $this->makeFriendlyName($parts[2]);
|
Chris@0
|
86 if (isset($parts[3]) === true) {
|
Chris@0
|
87 $name = $this->makeFriendlyName($parts[3]);
|
Chris@0
|
88 $name[0] = strtolower($name[0]);
|
Chris@0
|
89 $sniff .= ' '.$name;
|
Chris@0
|
90 unset($parts[3]);
|
Chris@0
|
91 }
|
Chris@0
|
92
|
Chris@0
|
93 $parts[2] = $sniff;
|
Chris@0
|
94 }//end if
|
Chris@0
|
95
|
Chris@0
|
96 $this->_sourceCache[$source] = array(
|
Chris@0
|
97 'count' => 1,
|
Chris@0
|
98 'fixable' => $error['fixable'],
|
Chris@0
|
99 'parts' => $parts,
|
Chris@0
|
100 'strlen' => strlen($sniff),
|
Chris@0
|
101 );
|
Chris@0
|
102 } else {
|
Chris@0
|
103 $this->_sourceCache[$source]['count']++;
|
Chris@0
|
104 }//end if
|
Chris@0
|
105 }//end foreach
|
Chris@0
|
106 }//end foreach
|
Chris@0
|
107 }//end foreach
|
Chris@0
|
108
|
Chris@0
|
109 return true;
|
Chris@0
|
110
|
Chris@0
|
111 }//end generateFileReport()
|
Chris@0
|
112
|
Chris@0
|
113
|
Chris@0
|
114 /**
|
Chris@0
|
115 * Prints the source of all errors and warnings.
|
Chris@0
|
116 *
|
Chris@0
|
117 * @param string $cachedData Any partial report data that was returned from
|
Chris@0
|
118 * generateFileReport during the run.
|
Chris@0
|
119 * @param int $totalFiles Total number of files processed during the run.
|
Chris@0
|
120 * @param int $totalErrors Total number of errors found during the run.
|
Chris@0
|
121 * @param int $totalWarnings Total number of warnings found during the run.
|
Chris@0
|
122 * @param int $totalFixable Total number of problems that can be fixed.
|
Chris@0
|
123 * @param boolean $showSources Show sources?
|
Chris@0
|
124 * @param int $width Maximum allowed line width.
|
Chris@0
|
125 * @param boolean $toScreen Is the report being printed to screen?
|
Chris@0
|
126 *
|
Chris@0
|
127 * @return void
|
Chris@0
|
128 */
|
Chris@0
|
129 public function generate(
|
Chris@0
|
130 $cachedData,
|
Chris@0
|
131 $totalFiles,
|
Chris@0
|
132 $totalErrors,
|
Chris@0
|
133 $totalWarnings,
|
Chris@0
|
134 $totalFixable,
|
Chris@0
|
135 $showSources=false,
|
Chris@0
|
136 $width=80,
|
Chris@0
|
137 $toScreen=true
|
Chris@0
|
138 ) {
|
Chris@0
|
139 if (empty($this->_sourceCache) === true) {
|
Chris@0
|
140 // Nothing to show.
|
Chris@0
|
141 return;
|
Chris@0
|
142 }
|
Chris@0
|
143
|
Chris@0
|
144 // Make sure the report width isn't too big.
|
Chris@0
|
145 $maxLength = 0;
|
Chris@0
|
146 foreach ($this->_sourceCache as $source => $data) {
|
Chris@0
|
147 $maxLength = max($maxLength, $data['strlen']);
|
Chris@0
|
148 }
|
Chris@0
|
149
|
Chris@0
|
150 if ($showSources === true) {
|
Chris@0
|
151 $width = min($width, ($maxLength + 11));
|
Chris@0
|
152 } else {
|
Chris@0
|
153 $width = min($width, ($maxLength + 41));
|
Chris@0
|
154 }
|
Chris@0
|
155
|
Chris@0
|
156 $width = max($width, 70);
|
Chris@0
|
157
|
Chris@0
|
158 asort($this->_sourceCache);
|
Chris@0
|
159 $this->_sourceCache = array_reverse($this->_sourceCache);
|
Chris@0
|
160
|
Chris@0
|
161 echo PHP_EOL."\033[1mPHP CODE SNIFFER VIOLATION SOURCE SUMMARY\033[0m".PHP_EOL;
|
Chris@0
|
162 echo str_repeat('-', $width).PHP_EOL."\033[1m";
|
Chris@0
|
163 if ($showSources === true) {
|
Chris@0
|
164 if ($totalFixable > 0) {
|
Chris@0
|
165 echo ' SOURCE'.str_repeat(' ', ($width - 15)).'COUNT'.PHP_EOL;
|
Chris@0
|
166 } else {
|
Chris@0
|
167 echo 'SOURCE'.str_repeat(' ', ($width - 11)).'COUNT'.PHP_EOL;
|
Chris@0
|
168 }
|
Chris@0
|
169 } else {
|
Chris@0
|
170 if ($totalFixable > 0) {
|
Chris@0
|
171 echo ' STANDARD CATEGORY SNIFF'.str_repeat(' ', ($width - 44)).'COUNT'.PHP_EOL;
|
Chris@0
|
172 } else {
|
Chris@0
|
173 echo 'STANDARD CATEGORY SNIFF'.str_repeat(' ', ($width - 40)).'COUNT'.PHP_EOL;
|
Chris@0
|
174 }
|
Chris@0
|
175 }
|
Chris@0
|
176
|
Chris@0
|
177 echo "\033[0m".str_repeat('-', $width).PHP_EOL;
|
Chris@0
|
178
|
Chris@0
|
179 $fixableSources = 0;
|
Chris@0
|
180
|
Chris@0
|
181 if ($showSources === true) {
|
Chris@0
|
182 $maxSniffWidth = ($width - 7);
|
Chris@0
|
183 } else {
|
Chris@0
|
184 $maxSniffWidth = ($width - 37);
|
Chris@0
|
185 }
|
Chris@0
|
186
|
Chris@0
|
187 if ($totalFixable > 0) {
|
Chris@0
|
188 $maxSniffWidth -= 4;
|
Chris@0
|
189 }
|
Chris@0
|
190
|
Chris@0
|
191 foreach ($this->_sourceCache as $source => $sourceData) {
|
Chris@0
|
192 if ($totalFixable > 0) {
|
Chris@0
|
193 echo '[';
|
Chris@0
|
194 if ($sourceData['fixable'] === true) {
|
Chris@0
|
195 echo 'x';
|
Chris@0
|
196 $fixableSources++;
|
Chris@0
|
197 } else {
|
Chris@0
|
198 echo ' ';
|
Chris@0
|
199 }
|
Chris@0
|
200
|
Chris@0
|
201 echo '] ';
|
Chris@0
|
202 }
|
Chris@0
|
203
|
Chris@0
|
204 if ($showSources === true) {
|
Chris@0
|
205 if ($sourceData['strlen'] > $maxSniffWidth) {
|
Chris@0
|
206 $source = substr($source, 0, $maxSniffWidth);
|
Chris@0
|
207 }
|
Chris@0
|
208
|
Chris@0
|
209 echo $source;
|
Chris@0
|
210 if ($totalFixable > 0) {
|
Chris@0
|
211 echo str_repeat(' ', ($width - 9 - strlen($source)));
|
Chris@0
|
212 } else {
|
Chris@0
|
213 echo str_repeat(' ', ($width - 5 - strlen($source)));
|
Chris@0
|
214 }
|
Chris@0
|
215 } else {
|
Chris@0
|
216 $parts = $sourceData['parts'];
|
Chris@0
|
217
|
Chris@0
|
218 if (strlen($parts[0]) > 8) {
|
Chris@0
|
219 $parts[0] = substr($parts[0], 0, ((strlen($parts[0]) - 8) * -1));
|
Chris@0
|
220 }
|
Chris@0
|
221
|
Chris@0
|
222 echo $parts[0].str_repeat(' ', (10 - strlen($parts[0])));
|
Chris@0
|
223
|
Chris@0
|
224 $category = $parts[1];
|
Chris@0
|
225 if (strlen($category) > 18) {
|
Chris@0
|
226 $category = substr($category, 0, ((strlen($category) - 18) * -1));
|
Chris@0
|
227 }
|
Chris@0
|
228
|
Chris@0
|
229 echo $category.str_repeat(' ', (20 - strlen($category)));
|
Chris@0
|
230
|
Chris@0
|
231 $sniff = $parts[2];
|
Chris@0
|
232 if (strlen($sniff) > $maxSniffWidth) {
|
Chris@0
|
233 $sniff = substr($sniff, 0, $maxSniffWidth);
|
Chris@0
|
234 }
|
Chris@0
|
235
|
Chris@0
|
236 if ($totalFixable > 0) {
|
Chris@0
|
237 echo $sniff.str_repeat(' ', ($width - 39 - strlen($sniff)));
|
Chris@0
|
238 } else {
|
Chris@0
|
239 echo $sniff.str_repeat(' ', ($width - 35 - strlen($sniff)));
|
Chris@0
|
240 }
|
Chris@0
|
241 }//end if
|
Chris@0
|
242
|
Chris@0
|
243 echo $sourceData['count'].PHP_EOL;
|
Chris@0
|
244 }//end foreach
|
Chris@0
|
245
|
Chris@0
|
246 echo str_repeat('-', $width).PHP_EOL;
|
Chris@0
|
247 echo "\033[1m".'A TOTAL OF '.($totalErrors + $totalWarnings).' SNIFF VIOLATION';
|
Chris@0
|
248 if (($totalErrors + $totalWarnings) > 1) {
|
Chris@0
|
249 echo 'S';
|
Chris@0
|
250 }
|
Chris@0
|
251
|
Chris@0
|
252 echo ' WERE FOUND IN '.count($this->_sourceCache).' SOURCE';
|
Chris@0
|
253 if (count($this->_sourceCache) !== 1) {
|
Chris@0
|
254 echo 'S';
|
Chris@0
|
255 }
|
Chris@0
|
256
|
Chris@0
|
257 echo "\033[0m";
|
Chris@0
|
258
|
Chris@0
|
259 if ($totalFixable > 0) {
|
Chris@0
|
260 echo PHP_EOL.str_repeat('-', $width).PHP_EOL;
|
Chris@0
|
261 echo "\033[1mPHPCBF CAN FIX THE $fixableSources MARKED SOURCES AUTOMATICALLY ($totalFixable VIOLATIONS IN TOTAL)\033[0m";
|
Chris@0
|
262 }
|
Chris@0
|
263
|
Chris@0
|
264 echo PHP_EOL.str_repeat('-', $width).PHP_EOL.PHP_EOL;
|
Chris@0
|
265
|
Chris@0
|
266 if ($toScreen === true && PHP_CODESNIFFER_INTERACTIVE === false) {
|
Chris@0
|
267 PHP_CodeSniffer_Reporting::printRunTime();
|
Chris@0
|
268 }
|
Chris@0
|
269
|
Chris@0
|
270 }//end generate()
|
Chris@0
|
271
|
Chris@0
|
272
|
Chris@0
|
273 /**
|
Chris@0
|
274 * Converts a camel caps name into a readable string.
|
Chris@0
|
275 *
|
Chris@0
|
276 * @param string $name The camel caps name to convert.
|
Chris@0
|
277 *
|
Chris@0
|
278 * @return string
|
Chris@0
|
279 */
|
Chris@0
|
280 public function makeFriendlyName($name)
|
Chris@0
|
281 {
|
Chris@0
|
282 if (trim($name) === '') {
|
Chris@0
|
283 return '';
|
Chris@0
|
284 }
|
Chris@0
|
285
|
Chris@0
|
286 $friendlyName = '';
|
Chris@0
|
287 $length = strlen($name);
|
Chris@0
|
288
|
Chris@0
|
289 $lastWasUpper = false;
|
Chris@0
|
290 $lastWasNumeric = false;
|
Chris@0
|
291 for ($i = 0; $i < $length; $i++) {
|
Chris@0
|
292 if (is_numeric($name[$i]) === true) {
|
Chris@0
|
293 if ($lastWasNumeric === false) {
|
Chris@0
|
294 $friendlyName .= ' ';
|
Chris@0
|
295 }
|
Chris@0
|
296
|
Chris@0
|
297 $lastWasUpper = false;
|
Chris@0
|
298 $lastWasNumeric = true;
|
Chris@0
|
299 } else {
|
Chris@0
|
300 $lastWasNumeric = false;
|
Chris@0
|
301
|
Chris@0
|
302 $char = strtolower($name[$i]);
|
Chris@0
|
303 if ($char === $name[$i]) {
|
Chris@0
|
304 // Lowercase.
|
Chris@0
|
305 $lastWasUpper = false;
|
Chris@0
|
306 } else {
|
Chris@0
|
307 // Uppercase.
|
Chris@0
|
308 if ($lastWasUpper === false) {
|
Chris@0
|
309 $friendlyName .= ' ';
|
Chris@0
|
310 if ($i < ($length - 1)) {
|
Chris@0
|
311 $next = $name[($i + 1)];
|
Chris@0
|
312 if (strtolower($next) === $next) {
|
Chris@0
|
313 // Next char is lowercase so it is a word boundary.
|
Chris@0
|
314 $name[$i] = strtolower($name[$i]);
|
Chris@0
|
315 }
|
Chris@0
|
316 }
|
Chris@0
|
317 }
|
Chris@0
|
318
|
Chris@0
|
319 $lastWasUpper = true;
|
Chris@0
|
320 }
|
Chris@0
|
321 }//end if
|
Chris@0
|
322
|
Chris@0
|
323 $friendlyName .= $name[$i];
|
Chris@0
|
324 }//end for
|
Chris@0
|
325
|
Chris@0
|
326 $friendlyName = trim($friendlyName);
|
Chris@0
|
327 $friendlyName[0] = strtoupper($friendlyName[0]);
|
Chris@0
|
328
|
Chris@0
|
329 return $friendlyName;
|
Chris@0
|
330
|
Chris@0
|
331 }//end makeFriendlyName()
|
Chris@0
|
332
|
Chris@0
|
333
|
Chris@0
|
334 }//end class
|