2018-12-09 21:47:20 +01:00
|
|
|
<?php
|
2019-06-09 18:37:28 +02:00
|
|
|
namespace Psalm\Report;
|
2018-12-09 21:47:20 +01:00
|
|
|
|
|
|
|
use Psalm\Config;
|
2019-06-09 18:37:28 +02:00
|
|
|
use Psalm\Report;
|
2019-06-26 22:52:29 +02:00
|
|
|
use function sprintf;
|
2018-12-09 21:47:20 +01:00
|
|
|
|
2019-06-09 18:37:28 +02:00
|
|
|
class PylintReport extends Report
|
2018-12-09 21:47:20 +01:00
|
|
|
{
|
|
|
|
public function create(): string
|
|
|
|
{
|
|
|
|
$output = '';
|
|
|
|
foreach ($this->issues_data as $issue_data) {
|
|
|
|
$output .= $this->format($issue_data) . "\n";
|
|
|
|
}
|
|
|
|
|
|
|
|
return $output;
|
|
|
|
}
|
|
|
|
|
2020-02-17 00:24:40 +01:00
|
|
|
private function format(\Psalm\Internal\Analyzer\IssueData $issue_data): string
|
2018-12-09 21:47:20 +01:00
|
|
|
{
|
|
|
|
$message = sprintf(
|
|
|
|
'%s: %s',
|
2020-02-17 00:24:40 +01:00
|
|
|
$issue_data->type,
|
|
|
|
$issue_data->message
|
2018-12-09 21:47:20 +01:00
|
|
|
);
|
|
|
|
|
2020-02-17 00:24:40 +01:00
|
|
|
if ($issue_data->severity === Config::REPORT_ERROR) {
|
2018-12-09 21:47:20 +01:00
|
|
|
$code = 'E0001';
|
|
|
|
} else {
|
|
|
|
$code = 'W0001';
|
|
|
|
}
|
|
|
|
|
|
|
|
// https://docs.pylint.org/en/1.6.0/output.html doesn't mention what to do about 'column',
|
|
|
|
// but it's still useful for users.
|
|
|
|
// E.g. jenkins can't parse %s:%d:%d.
|
2020-02-17 00:24:40 +01:00
|
|
|
$message = sprintf('%s (column %d)', $message, $issue_data->column_from);
|
2018-12-09 21:47:20 +01:00
|
|
|
$issue_string = sprintf(
|
|
|
|
'%s:%d: [%s] %s',
|
2020-02-17 00:24:40 +01:00
|
|
|
$issue_data->file_name,
|
|
|
|
$issue_data->line_from,
|
2018-12-09 21:47:20 +01:00
|
|
|
$code,
|
|
|
|
$message
|
|
|
|
);
|
|
|
|
|
|
|
|
return $issue_string;
|
|
|
|
}
|
|
|
|
}
|