1
0
mirror of https://github.com/danog/psalm.git synced 2025-01-10 15:09:04 +01:00
psalm/src/Psalm/Config/IssueHandler.php

185 lines
4.9 KiB
PHP
Raw Normal View History

2016-12-30 02:07:42 +01:00
<?php
namespace Psalm\Config;
use function array_filter;
use function array_map;
use function dirname;
2019-07-05 22:24:00 +02:00
use function in_array;
use function scandir;
use SimpleXMLElement;
use function strtolower;
use function substr;
2016-12-30 02:07:42 +01:00
class IssueHandler
{
/**
* @var string
*/
private $error_level = \Psalm\Config::REPORT_ERROR;
2016-12-30 02:07:42 +01:00
/**
* @var array<ErrorLevelFileFilter>
*/
private $custom_levels = [];
2016-12-30 02:07:42 +01:00
/**
* @param SimpleXMLElement $e
* @param string $base_dir
2017-05-27 02:16:18 +02:00
*
2016-12-30 02:07:42 +01:00
* @return self
*/
public static function loadFromXMLElement(SimpleXMLElement $e, $base_dir)
2016-12-30 02:07:42 +01:00
{
$handler = new self();
if (isset($e['errorLevel'])) {
$handler->error_level = (string) $e['errorLevel'];
2017-05-27 02:05:57 +02:00
if (!in_array($handler->error_level, \Psalm\Config::$ERROR_LEVELS, true)) {
throw new \Psalm\Exception\ConfigException('Unexpected error level ' . $handler->error_level);
2016-12-30 02:07:42 +01:00
}
}
/** @var \SimpleXMLElement $error_level */
foreach ($e->errorLevel as $error_level) {
$handler->custom_levels[] = ErrorLevelFileFilter::loadFromXMLElement($error_level, $base_dir, true);
2016-12-30 02:07:42 +01:00
}
return $handler;
}
/**
* @param string $error_level
2017-05-27 02:16:18 +02:00
*
2016-12-30 02:07:42 +01:00
* @return void
*/
public function setErrorLevel($error_level)
{
2017-05-27 02:05:57 +02:00
if (!in_array($error_level, \Psalm\Config::$ERROR_LEVELS, true)) {
throw new \Psalm\Exception\ConfigException('Unexpected error level ' . $error_level);
2016-12-30 02:07:42 +01:00
}
$this->error_level = $error_level;
}
/**
* @param string $file_path
2017-05-27 02:16:18 +02:00
*
2016-12-30 02:07:42 +01:00
* @return string
*/
public function getReportingLevelForFile($file_path)
2016-12-30 02:07:42 +01:00
{
foreach ($this->custom_levels as $custom_level) {
if ($custom_level->allows($file_path)) {
2016-12-30 02:07:42 +01:00
return $custom_level->getErrorLevel();
}
}
return $this->error_level;
}
/**
* @param string $fq_classlike_name
*
2019-05-03 23:12:20 +02:00
* @return string|null
*/
public function getReportingLevelForClass($fq_classlike_name)
{
foreach ($this->custom_levels as $custom_level) {
if ($custom_level->allowsClass($fq_classlike_name)) {
return $custom_level->getErrorLevel();
}
}
}
/**
* @param string $method_id
*
2019-05-03 23:12:20 +02:00
* @return string|null
*/
public function getReportingLevelForMethod($method_id)
{
foreach ($this->custom_levels as $custom_level) {
if ($custom_level->allowsMethod(strtolower($method_id))) {
return $custom_level->getErrorLevel();
}
}
}
2019-05-03 23:12:20 +02:00
/**
* @return string|null
*/
public function getReportingLevelForFunction(string $function_id)
{
foreach ($this->custom_levels as $custom_level) {
if ($custom_level->allowsMethod(strtolower($function_id))) {
return $custom_level->getErrorLevel();
}
}
}
2019-05-03 23:12:20 +02:00
/**
* @return string|null
*/
public function getReportingLevelForArgument(string $function_id)
{
foreach ($this->custom_levels as $custom_level) {
if ($custom_level->allowsMethod(strtolower($function_id))) {
return $custom_level->getErrorLevel();
}
}
}
/**
* @param string $property_id
*
2019-05-03 23:12:20 +02:00
* @return string|null
*/
public function getReportingLevelForProperty($property_id)
{
foreach ($this->custom_levels as $custom_level) {
if ($custom_level->allowsProperty($property_id)) {
return $custom_level->getErrorLevel();
}
}
}
2019-05-03 21:29:44 +02:00
/**
* @return string[]
* @psalm-return array<mixed, string>
*/
public static function getAllIssueTypes()
{
return array_filter(
array_map(
/**
* @param string $file_name
*
* @return string
*/
function ($file_name) {
return substr($file_name, 0, -4);
},
scandir(dirname(__DIR__) . '/Issue')
),
/**
* @param string $issue_name
*
* @return bool
*/
function ($issue_name) {
return !empty($issue_name)
&& $issue_name !== 'MethodIssue'
&& $issue_name !== 'PropertyIssue'
&& $issue_name !== 'FunctionIssue'
&& $issue_name !== 'ArgumentIssue'
&& $issue_name !== 'ClassIssue'
&& $issue_name !== 'CodeIssue'
&& $issue_name !== 'PsalmInternalError'
&& $issue_name !== 'ParseError'
&& $issue_name !== 'PluginIssue';
}
);
}
2016-12-30 02:07:42 +01:00
}