コードをスキャンして、未使用の Composer 依存関係を表示する Composer ツール。
Andreas Frömer と寄稿者によって作成され、ロゴは Caneco によって作成されました。
このツールをcomposer-pluginとして使用したい場合は、composer-unused-pluginに進んでください。
大規模なリポジトリで作業していると、必要な Composer パッケージを見失うことがあります。パッケージが多すぎて、実際に使用されているかどうかわからない場合があります。
残念ながら、 composer why
コマンドは、パッケージが別のパッケージに依存してインストールされる理由に関する情報しか提供しません。
パッケージの提供されたシンボルがコードで使用されているかどうかを確認するにはどうすればよいでしょうか?
composer unused
!
.phar
アーカイブをダウンロードするか、 PHIVE を使用してローカルにインストールすることをお勧めします。
phive
経由でインストールするか、最新リリースから最新のcomposer-unused.phar
を取得します。
phive install composer-unused curl -OL https://github.com/composer-unused/composer-unused/releases/latest/download/composer-unused.phar
また、 composer-unused
ローカル開発依存関係としてインストールすることもできます。
composer require --dev icanhazstring/composer-unused
インストールの種類に応じて、コマンドが異なる場合があります。
注: パッケージは、 composer-unused
を実行する前に、 composer install
またはcomposer update
によってインストールする必要があります。
phar
アーカイブはプロジェクト内で直接実行できます。
php composer-unused.phar
ローカル依存関係としてcomposer-unused
設定すると、同梱のバイナリを使用して実行できます。
vendor/bin/composer-unused
特定のディレクトリをスキャンしたくない場合や、スキャン中に Composer パッケージを無視したくない場合があります。このような場合、 --excludeDir
または--excludePackage
オプションを指定できます。これらのオプションは、次に示すように複数の値を受け入れます。
php composer-unused.phar --excludeDir=config --excludePackage=symfony/console php composer-unused.phar --excludeDir=bin --excludeDir=config --excludePackage=symfony/assets --excludePackage=symfony/console
パッケージの名前が、
composer.json
とまったく同じであることを確認してください。
プロジェクトのcomposer.json
横にcomposer-unused.php
を配置することでcomposer-unusedを設定できます。この設定は次のようになります:composer-unused.php
依存関係を名前で無視するには、次の行を構成に追加します。
$config->addNamedFilter(NamedFilter::fromString('dependency/name'));
パターンごとに依存関係を無視するには、次の行を構成に追加します。
$config->addPatternFilter(PatternFilter::fromString('/dependency/name/'));
PatternFilter
(例:/symfony/.*/
を使用すると、単一の組織で複数の依存関係を無視できます。
デフォルトでは、 composer-unused
composer.json
自動ロード ディレクティブを使用して、解析するファイルを探す場所を決定します。依存関係によっては、composer.json が正しく設定されていないか、ファイルが別の方法で読み込まれることがあります。これを使用すると、依存関係ごとに追加のファイルを定義できます。
$config->setAdditionalFilesFor('dependency/name', [<list-of-file-paths>]);
CHANGELOG.md
をご覧ください。
CONTRIBUTING.md
をご覧ください。
CODE_OF_CONDUCT.md
をご覧ください。
このパッケージは、MIT ライセンスに基づいてライセンスされています。