cakedc / cakephp-phpstan
CakePHP 插件扩展用于 PHPStan。
Requires
- php: >=8.1.0
- cakephp/cakephp: ^5.0
- phpstan/phpstan: ^1.10
Requires (Dev)
- cakephp/cakephp-codesniffer: ^5.0
- phpstan/phpstan-phpunit: ^1.0
- phpunit/phpunit: ^10.1
- symplify/phpstan-rules: ^12.4
This package is auto-updated.
Last update: 2024-08-28 19:27:11 UTC
README
提供服务和规则,以优化 CakePHP 应用程序的 PHPStan 分析,包括解析类型(表、辅助函数、行为等)的多个规则。
安装
要使用此扩展,通过 Composer 引入
composer require --dev cakedc/cakephp-phpstan
如果您还安装了 phpstan/extension-installer,那么您就准备好了!
手动安装
如果您不想使用 phpstan/extension-installer,请将 extension.neon 包含在项目 PHPStan 配置中
includes:
    - vendor/cakedc/cakephp-phpstan/extension.neon
通用类加载/检索扩展
包含的功能
- 为 Cake\ORM\Locator\LocatorInterface::get()提供正确的返回类型
- 为 Cake\Controller\Controller::loadComponent()提供正确的返回类型
- 为 Cake\Controller\Controller::fetchTable()提供正确的返回类型
- 为 Cake\Controller\Component::fetchTable()提供正确的返回类型
- 为 Cake\Command\Command::fetchTable()提供正确的返回类型
- 为 Cake\Mailer\Mailer::fetchTable()提供正确的返回类型
- 为 Cake\View\Cell::fetchTable()提供正确的返回类型
- 为 Cake\Console\ConsoleIo::helper()提供正确的返回类型
表格类返回类型扩展
TableEntityDynamicReturnTypeExtension
- 基于您的表格类名称,为 Cake\ORM\Table::get提供正确的返回类型
- 基于您的表格类名称,为 Cake\ORM\Table::newEntity提供正确的返回类型
- 基于您的表格类名称,为 Cake\ORM\Table::newEntities提供正确的返回类型
- 基于您的表格类名称,为 Cake\ORM\Table::newEmptyEntity提供正确的返回类型
- 基于您的表格类名称,为 Cake\ORM\Table::findOrCreate提供正确的返回类型
示例
//Now PHPStan know that \App\Models\Table\NotesTable::get returns \App\Model\Entity\Note $note = $this->Notes->get(1); $note->note = 'My new note';//No error //Now PHPStan know that \App\Models\Table\NotesTable::newEntity returns \App\Model\Entity\Note $note = $this->Notes->newEntity($data); $note->note = 'My new note new entity';//No error //Now PHPStan know that \App\Models\Table\NotesTable::newEmptyEntity returns \App\Model\Entity\Note $note = $this->Notes->newEmptyEntity($data); $note->note = 'My new note new empty entity';//No error //Now PHPStan know that \App\Models\Table\NotesTable::findOrCreate returns \App\Model\Entity\Note $note = $this->Notes->findOrCreate($data); $note->note = 'My entity found or created';//No error //Now PHPStan know that \App\Models\Table\NotesTable::newEntities returns \App\Model\Entity\Note[] $notes = $this->Notes->newEntities($data); foreach ($notes as $note) { $note->note = 'My new note';//No error }
TableFirstArgIsTheReturnTypeExtension
- 基于传递的第一个参数,为 Cake\ORM\Table::patchEntity提供正确的返回类型
- 基于传递的第一个参数,为 Cake\ORM\Table::patchEntities提供正确的返回类型
- 基于传递的第一个参数,为 Cake\ORM\Table::save提供正确的返回类型
- 基于传递的第一个参数,为 Cake\ORM\Table::saveOrFail提供正确的返回类型
- 基于传递的第一个参数,为 Cake\ORM\Table::saveMany提供正确的返回类型
- 基于传递的第一个参数,为 Cake\ORM\Table::saveManyOrFail提供正确的返回类型
- 基于传递的第一个参数,为 Cake\ORM\Table::deleteMany提供正确的返回类型
- 基于传递的第一个参数,为 Cake\ORM\Table::deleteManyOrFail提供正确的返回类型
示例
//Now PHPStan know that \App\Models\Table\NotesTable::get returns \App\Model\Entity\Note $note = $this->Notes->get(1); $notes = $this->Notes->newEntities($data); //Since PHPStan knows the type of $note, these methods call use the same type as return type: $note = $this->Notes->patchEntity($note, $data); $text = $note->note;//No error. $note = $this->Notes->save($note); $text = $note->note;//No error. $note = $this->Notes->saveOrFail($note); $text = $note->note;//No error. //Since PHPStan knows the type of $notes, these methods call use the same type as return type: $notes = $this->Notes->patchEntities($notes); $notes = $this->Notes->saveMany($notes); $notes = $this->Notes->saveManyOrFail($notes); $notes = $this->Notes->deleteMany($notes); $notes = $this->Notes->deleteManyOrFail($notes);
规则
此库提供的所有规则都包含在 rules.neon 中,默认启用
AddAssociationExistsTableClassRule
此规则检查在调用 Table::belongsTo、Table::hasMany、Table::belongsToMany、Table::hasOne 和 AssociationCollection::load 时目标关联是否有有效的表格类。
AddAssociationMatchOptionsTypesRule
此规则检查关联选项是否为有效选项类型,基于每个类期望的内容。这涵盖了调用 Table::belongsTo、Table::hasMany、Table::belongsToMany、Table::hasOne 和 AssociationCollection::load。
AddBehaviorExistsClassRule
此规则检查在调用Table::addBehavior和BehaviorRegistry::load时,目标行为是否有有效的表类。
OrmSelectQueryFindMatchOptionsTypesRule
此规则检查传递给Table::find和SelectQuery的选项(参数)是否为有效的查找选项类型。
TableGetMatchOptionsTypesRule
此规则检查传递给Table::get的选项(参数)是否为有效的查找选项类型。
如何禁用规则
每个规则在cakeDC 'namespace'中都有一个参数来启用或禁用,它与规则的名称相同,首字母小写。例如,要禁用AddAssociationExistsTableClassRule规则,你应该有
parameters:
	cakeDC:
	 	addAssociationExistsTableClassRule: false
PHPDoc 扩展
TableAssociationTypeNodeResolverExtension
修复交集关联的phpDoc以正确指定泛型对象类型,例如
将\Cake\ORM\Association\BelongsTo&\App\Model\Table\UsersTable更改为\Cake\ORM\Association\BelongsTo<\App\Model\Table\UsersTable>
技巧
为了使您的开发更轻松,请确保在您的表类中使用@mixin和@method注解。`@mixin`注解将帮助phpstan知道您正在使用行为中的方法,而`@method`注解将允许它知道像Table::get()、Table::newEntity()这样的方法的正确返回类型。
您可以使用插件IdeHelper轻松更新注解。
支持
对于错误和功能请求,请使用此存储库的问题部分。
还提供商业支持,联系我们获取更多信息。
贡献
如果您想为此插件贡献新功能、增强或错误修复,请阅读我们的贡献指南以获取详细说明。