承接 stevebauman/unfinalize 相关项目开发

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

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

stevebauman/unfinalize

最新稳定版本:v2.2.0

Composer 安装命令:

composer create-project stevebauman/unfinalize

包简介

Permanently remove final keywords from vendor packages.

README 文档

README

Unleash the freedom lost with open source PHP packages marking classes and methods as final.

Unfinalize uses PHP CS Fixer to permanently remove final keywords from composer vendor packages:

- final class Foo + class Foo { - final public function bar() + public function bar() { // ... } }
  • Updates to PHP files are done safely, quickly, and performant.
  • Changes are stored permanently. There is no performance impact using Unfinalize.
  • No additional dependencies to your application. Unfinalize and its dependencies are compiled into a single phar file.

Installation

composer require stevebauman/unfinalize

Usage

You may unfinalize files using two different methods: file paths, or package paths.

File Paths

Using files paths allow you to unfinalize specific files or directories by specifying them in the command:

php vendor/bin/unfinalize run vendor/package/src/File.php

You may unfinalize multiple files or directories by separating them by a space:

php vendor/bin/unfinalize run vendor/package/src/Foo/ vendor/package/src/Bar/File.php

To make sure this is always done on your project's dependencies, add the command to your composer.json file in the scripts property:

{ "scripts": { "post-update-cmd": [ "@php vendor/bin/unfinalize run vendor/package/src/Foo/ vendor/package/src/Bar/File.php" ] } }

Then run composer update.

Package Paths

Using package paths allow you to unfinalize entire packages by specifying them in your composer.json file.

Add the vendor packages you want to remove the final keywords from inside an unfinalize property:

{ "unfinalize": [ "vendor/package" ] }

Add the unfinalize command to your composer.json so it runs on composer update:

{ "scripts": { "post-update-cmd": [ "@php vendor/bin/unfinalize run" ] } }

Then, run composer update.

Options

--annotate={annotation}

If you would like final classes and methods to be marked with an annotation (@{annotation}) doc block after unfinalizing, you may add the --annotate option to the unfinalize command:

If an annotation already exists in a doc block then it will be left untouched.

{ "scripts": { "post-update-cmd": [ "@php vendor/bin/unfinalize run --annotate=internal" ] } }

Which will produce:

Before:

final class Foo { final public function bar() { // ... } }

After:

/**  * @internal  */ class Foo { /**  * @internal  */ public function bar() { // ... } }

--properties={protected/public}

If you would like to change the visibility of private properties to protected or public, you may add the --properties option to the unfinalize command with the new visibility to assign:

{ "scripts": { "post-update-cmd": [ "@php vendor/bin/unfinalize run --properties=protected" ] } }

Which will produce:

Before:

class Foo { private $bar; }

After:

class Foo { protected $bar; }

--methods={protected/public}

If you would like to change the visibility of private methods to protected or public, you may add the --methods option to the unfinalize command with the new visibility to assign:

{ "scripts": { "post-update-cmd": [ "@php vendor/bin/unfinalize run --methods=public" ] } }

Which will produce:

Before:

class Foo { private function bar() { } }

After:

class Foo { public function bar() { } }

--dry

Execute a dry run to see what files will be modified by Unfinalize:

vendor/bin/unfinalize run --dry

统计信息

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

GitHub 信息

  • Stars: 144
  • Watchers: 3
  • Forks: 5
  • 开发语言: PHP

其他信息

  • 授权协议: MIT
  • 更新时间: 2026-01-04