承接 nicksdot/phpstan-prettier-output 相关项目开发

从需求分析到上线部署,全程专人跟进,保证项目质量与交付效率

邮箱:yvsm@zunyunkeji.com | QQ:316430983 | 微信:yvsm316

nicksdot/phpstan-prettier-output

最新稳定版本:0.3.0

Composer 安装命令:

composer require nicksdot/phpstan-prettier-output

包简介

Custom PHPStan formatters for a prettier output.

README 文档

README

Important

This is a proof of concept. Things are rough, hacky and not cleaned up. However, it works.

Installation

$ composer require --dev nicksdot/phpstan-prettier-output

Setup Formatters

services:
+	errorFormatter.customTable:
+		class: NickSdot\PrettierStanOutput\CustomTableFormatter
+	errorFormatter.customJson:
+		class: NickSdot\PrettierStanOutput\CustomJsonFormatter
+	errorFormatter.customCheckstyle:
+		class: NickSdot\PrettierStanOutput\CustomCheckstyleFormatter

IDE Output

If you also want prettier messages in your IDE you must override the default CheckstyleErrorFormatter. To do this, override the service in your phpstan.non.

services:
	errorFormatter.customTable:
		class: NickSdot\PrettierStanOutput\CustomTableFormatter
	errorFormatter.customJson:
		class: NickSdot\PrettierStanOutput\CustomJsonFormatter
	errorFormatter.customCheckstyle:
		class: NickSdot\PrettierStanOutput\CustomCheckstyleFormatter
+	errorFormatter.checkstyle:
+		class: NickSdot\PrettierStanOutput\CustomCheckstyleFormatter

Wishlist

To make this package less hacky, we would need the following.

PHPStorm PHPStan Plugin

  • allow custom formatter in settings
  • allow line breaks in tooltip output.
  • adjust processing and consumption of PhpStanMessageProcessor.java so that inspection tooltips and inspection the inspections message window use different messages. Similar to how it already works in the HTML inspection.

Plugin repo: https://github.com/JetBrains/phpstorm-phpstan-plugin

PHPStan

Currently, we rely on Regex to re-format the reported messages (e.g. adding line-breaks). It would be nice, but it is no deal-breaker if not, if PHPStan would add support for formatted messages.

Possible approaches:

  • keep track of all non sprintf'ed messages in a static property (?) of RuleErrorBuilder::message().
  • make it a first class feature to have a formatted and unformatted variant of messages.
  • add values required to build messages to PHPStan\Command\AnalysisResult.

Considerations

Usage of "Tips"

Ondrej recommended the sole usage of "tips" output. However, this seems not sufficient for the following reasons.

  • More often than not there are no "tips".
  • There can be multiple tips per error.
  • They are often simply external references like in the following example.
12   app/Models/Option.php:12                                                      
PHPDoc type array of property App\Models\Option::$fillable is not the same as PHPDoc type list<string> of overridden property Illuminate\Database\Eloquent\Model::$fillable.                                                                                 

💡 You can fix 3rd party PHPDoc types with stub files:               
💡 https://phpstan.org/user-guide/stub-files    

Given this example, the solution proposed by Ondrej would result in the following which is not much more readable and has the same cognitive load than before.

Using the approach from this repository, the output will result in.

12   app/Models/Option.php:12 
PHPDoc type of property App\Models\Option::$fillable is not the same as PHPDoc type of overridden property Illuminate\Database\Eloquent\Model::$fillable. 

⁉️ array
⁉️ list<string>

💡 You can fix 3rd party PHPDoc types with stub files:               
💡 https://phpstan.org/user-guide/stub-files    

So the current conclusion is, tips are not the way.

Credits

All formatters are based on the PHPStan built-in ErrorFormatters.

Contributing

License

MIT

统计信息

  • 总下载量: 30
  • 月度下载量: 0
  • 日度下载量: 0
  • 收藏数: 0
  • 点击次数: 0
  • 依赖项目数: 0
  • 推荐数: 0

GitHub 信息

  • Stars: 0
  • Watchers: 1
  • Forks: 0
  • 开发语言: PHP

其他信息

  • 授权协议: MIT
  • 更新时间: 2024-08-09