Php Symfony5项目的Phan/Phan配置
我是静态分析方面的新手,我正在尝试在我当前的项目中使用phan/phan 我的phan/config.php如下所示Php Symfony5项目的Phan/Phan配置,php,symfony,static-analysis,Php,Symfony,Static Analysis,我是静态分析方面的新手,我正在尝试在我当前的项目中使用phan/phan 我的phan/config.php如下所示 <?php /** * This configuration will be read and overlaid on top of the * default configuration. Command-line arguments will be applied * after this file is read. */ return [ // Su
<?php
/**
* This configuration will be read and overlaid on top of the
* default configuration. Command-line arguments will be applied
* after this file is read.
*/
return [
// Supported values: `'5.6'`, `'7.0'`, `'7.1'`, `'7.2'`, `'7.3'`,
// `'7.4'`, `null`.
// If this is set to `null`,
// then Phan assumes the PHP version which is closest to the minor version
// of the php executable used to execute Phan.
//
// Note that the **only** effect of choosing `'5.6'` is to infer
// that functions removed in php 7.0 exist.
// (See `backward_compatibility_checks` for additional options)
// TODO: Set this.
'target_php_version' => null,
// A list of directories that should be parsed for class and
// method information. After excluding the directories
// defined in exclude_analysis_directory_list, the remaining
// files will be statically analyzed for errors.
//
// Thus, both first-party and third-party code being used by
// your application should be included in this list.
'directory_list' => [
'src',
'vendor/symfony/console',
],
// A regex used to match every file name that you want to
// exclude from parsing. Actual value will exclude every
// "test", "tests", "Test" and "Tests" folders found in
// "vendor/" directory.
'exclude_file_regex' => '@^vendor/.*/(tests?|Tests?)/@',
// A directory list that defines files that will be excluded
// from static analysis, but whose class and method
// information should be included.
//
// Generally, you'll want to include the directories for
// third-party code (such as "vendor/") in this list.
//
// n.b.: If you'd like to parse but not analyze 3rd
// party code, directories containing that code
// should be added to both the `directory_list`
// and `exclude_analysis_directory_list` arrays.
'exclude_analysis_directory_list' => [
'vendor/'
],
];
?>
看起来这是一个已知的问题:
在这个Github问题中,他们建议使用Phan扩展:
或者尝试使用PHPStan或Psalm。我发现了,问题出在以下几行:
'directory_list' => [
'src',
'vendor/symfony/console',
],
这直接取自Phan示例配置,但由于目录列表中仅包含文件夹“vendor/symfony/console”,因此Phan无法了解其他symfony组件
我已将其替换为:
'directory_list' => [
'src',
'vendor',
],
通过包含整个供应商目录,将对其进行解析,并了解src中使用的每个供应商对象
正如Leprechaun提到的,我遇到了另一个问题,即phan无法正确解析注释,因此必须包含以下插件
'plugins' => [
'vendor/drenso/phan-extensions/Plugin/Annotation/SymfonyAnnotationPlugin.php'
],
现在它可以工作了。这并不是我遇到的问题,但是插件很有用,谢谢。