PhpStorm 2024.1 ヘルプ

PHP CS Fixer

組み込みのコーディング支援に加えて、PhpStorm は、コード内のコーディング標準の問題を検出する PHP CS Fixer(英語) ツールとの統合によってソースコードをチェックします。

コマンドラインの代わりに PhpStorm から PHP CS Fixer を使用するには、それを PhpStorm に登録し、PhpStorm コードインスペクションとして構成する必要があります。PhpStorm にインストールして有効にすると、開いている PHP ファイルでツールを使用できるようになり、起動するために追加の手順は必要ありません。オンザフライコードチェックはファイルが更新されるたびにアクティブになるため、発見された問題を簡単に取り除くことができます。

PHP CS Fixer によってオンザフライで報告される問題は、PhpStorm の内部コードインスペクションによって報告されるエラーや警告と同じ方法でエディターでハイライトされます。ツールをバッチモードで実行すると、エラーと警告が問題ツールウィンドウに表示されます。各メッセージには、PhpStorm 内部インスペクションと区別するために、PHP CS Fixer プレフィックスが付いています。

事前定義されたルール(英語)を適用したり、独自のカスタムルールセット(英語)を定義したりできます。

前提条件

PHP CS Fixer を PhpStorm に統合する前に、次の前提条件が満たされていることを確認してください。

  • PHP CS Fixer バージョン 2.8.0 以降を使用しています。

  • PHP エンジンの実行可能ファイルを含むディレクトリをシステム path に追加する必要があります。これにより、コード品質ツールスクリプトがシステム全体の PHP エンジンへの呼び出しを実行できるようになります。

  • Docker Compose ベースのリモートインタープリターの場合、追加のコンテナーが生成されないように、必ず docker-compose exec モードを使用してください。

    1. 設定ダイアログ(Ctrl+Alt+S)で、PHP に移動します。

    2. 表示される PHP ページで、CLI インタープリターリストの横にある the Browse button をクリックします。

    3. 開いた CLI インタープリターダイアログで、選択したインタープリターのライフサイクルモードを既存のコンテナーに接続する ('docker-compose exec') に設定します。

      docker-compose exec for PHP interpreter

PHP CS Fixer をインストールして構成する

Composer で PHP CS Fixer をインストールする

PHP CS Fixer を Composer とともにインストールすると、PhpStorm は必要なスクリプトを自動的にダウンロードして IDE に登録し、オプションで対応するコードインスペクションを有効にして構成します。

  1. composer.json 内で、friendsofphp/php-cs-fixer 依存関係レコードを require キーまたは require-dev キーに追加します。パッケージ名とバージョンのコード補完を取得するには、Ctrl+Space を押します。

  2. 以下のいずれか 1 つを実行します:

    • エディターパネルの上部にあるインストールショートカットリンクをクリックします。

    • インストールされていない Composer パッケージインスペクションが有効になっている場合、PhpStorm は、現在インストールされていない宣言済みの依存関係をハイライトします。Alt+Enter を押して、特定の依存関係をインストールするか、すべての依存関係を一度にインストールするかを選択します。

composer.json エディターのガター内のパッケージレコードの横にある the Settings button をクリックすると、対応する設定ページが表示され、そこで PHP CS Fixer を手動で構成できます。

Gutter icon for php-cs-fixer settings in composer.json

PHP CS Fixer 構成をリセット

PHP CS Fixer が最初に構成された後、composer.json をさらに変更しても、インスペクション構成には影響しません。新しい変更を適用するには、PHP CSFixer 構成をリセットします。

  1. 設定ダイアログ (Ctrl+Alt+S) で、PHP | 品質ツール | PHP CS Fixer に移動します。

  2. 構成リストの横にある the Browse button をクリックします。

  3. 開いた PHP CS Fixer ダイアログで、PHP CS Fixer のパスフィールドを空にします。

    Empty PHP CS Fixer path field
  4. composer.json エディターパネルの上部にある更新をクリックして、プロジェクト Composer の依存関係を更新します。詳細については、「依存関係の更新」を参照してください。

PhpStorm は、PHP CS Fixer 構成を新たに実行するため、composer.json の変更を適用します。

PhpStorm で PHP CS Fixer を構成する

Composer を使用して PHP CS Fixer をインストールすると、PhpStorm は vendor/bin フォルダー内の PHP CS Fixer の実行可能ファイルを自動的に検出し、システムパスで構成された PHP インタープリターを設定して実行します。

設定 (Ctrl+Alt+S) で | PHP | 品質ツール | PHP CS Fixer では、デフォルトの PHP インタープリターを変更したり、パスを手動でダウンロードしてインストールした PHP CS Fixer 実行可能ファイル(英語)に設定したり、PhpStorm で実行するときに PHP CS Fixer に渡すオプションを追加したりできます。

PHP CS Fixer settings
  • 構成 : このフィールドでは、デフォルトの PHP インタープリターと、PHP CS Fixer 実行可能ファイルへのパスを変更できます。

    1. インタープリターのみを変更するには、プロジェクトで構成されたローカルおよびリモート PHP インタープリターのリストから必要な項目を選択します。

    2. PHP CS Fixer 実行可能ファイルへのパス、またはインタープリターとパスの両方を変更するには、構成リストの横にある the Browse button をクリックして PHP CS Fixer ダイアログを開き、PHP CS Fixer ダイアログリファレンスページの説明に従ってフィールドを編集します。

  • 無視対象ファイルの表示 : この設定を使用して、PHP CS Fixer 検証インスペクションからファイルを除外します。詳細については、品質ツールリファレンスページを参照してください。

  • オプション : この領域で、PHP CS Fixer を PhpStorm インスペクションとして実行するオプションを追加します。PHP CS Fixer のリファレンスページの説明に従って、フィールドを編集します。

PHP CS Fixer を PhpStorm インスペクションとして有効にする

PHP CS Fixer を PhpStorm インスペクションとしてセットアップするには、Composer を使用した PHP CS Fixer のインストール中に自動的にセットアップする方法と、PhpStorm のインスペクション設定で手動中に自動的にセットアップする方法の 2 つがあります。

PHP CS Fixer インスペクションを Composer で有効にする

composer.jsonスクリプト(英語)セクション内に、デフォルトおよびカスタムの PHPCS フィクサールールセットに関する情報を含めることができます。プロジェクトの依存関係をインストールまたは更新すると、指定されたルールセットが検出され、PHP CS Fixer 検証インスペクションが自動的に有効になります。

composer.jsonscripts セクションにルールセットが指定されていない場合、PhpStorm はさらにプロジェクトルートをチェックして、.php_cs または .php_cs.dist のデフォルト名でルールセットを見つけます。ファイルが存在する場合は、インスペクションのカスタムルールセットとして自動的に選択されます。

  • composer.jsonscripts セクションで、php-cs-fixer PHP CS Fixer 起動コマンドをいずれかのリーフ要素に追加します。

    使用するコーディング標準を示すために --rules 引数を指定します。例: 次のレコードを追加すると PSR1 にコーディング標準が設定されます。

    "scripts": { "php-cs-fixer": "php-cs-fixer --rules=@PSR1" }

    あるいは、--config 引数とルールセットファイルへのパスを指定すると、コーディング標準がカスタムに設定されます。

    "scripts": { "php-cs-fixer": "php-cs-fixer --config=./.php_cs" }

インスペクション設定で PHP CS Fixer の検証を有効にする

  1. 設定ダイアログ (Ctrl+Alt+S) で、エディターインスペクションをクリックします。

  2. 開いているインスペクションページで、PHP | 品質ツールノードを展開し、PHP CS Fixer 検証の横にあるチェックボックスを選択します。

    Select PHP CS Fixer validation checkbox
  3. ページの右側のペインで、PhpStorm が PHP CS Fixer インスペクション出力を処理する方法を構成します。

    1. スコープ : インスペクションアプリケーションを制限するスコープを選択します。

    2. 重大度 : インスペクションの重大度を選択します。選択した値によって、検出された不一致が PhpStorm によってどの程度深刻に扱われ、インスペクションの結果に表示されるかが決まります。

    3. エディター内のハイライト : インスペクションによって検出された問題をエディターでハイライトする方法を選択します。

PHP CS Fixer をバッチモードで実行する

  1. メインメニューで、コード | コードのインスペクションに移動します。

  2. 開いたインスペクションスコープの指定ダイアログで、リストからインスペクションプロファイルを選択するか、構成をクリックしてインスペクションダイアログを開き、新しいプロファイルを構成します。

    構成をクリックして、選択したインスペクションプロファイルの範囲内で適用される修正を確認し、PHP CS Fixer 検証インスペクションが有効になっていることを確認することもできます。

  3. インスペクションの結果を問題ツールウィンドウで表示します。PHP CS Fixer によって報告されたエラーと警告には、PHP CS Fixer: が付いていて、PhpStorm の内部インスペクションと区別されます。

    PHP CS Fixer inspection list

PHP CS Fixer によって検出された問題を修正する

クイックフィックスを使用して問題を修正する

問題を検出すると、PhpStorm は PHP CS Fixer インスペクションの設定に従ってその問題をハイライトします。

  1. 検出された問題にキャレットを置いて the Intention action button をクリックするか、Alt+Enter を押します。

  2. ポップアップメニューから PHP CS Fixer: ファイル全体を修正するを選択してください。これにより、現在のファイルで検出されたすべての問題が修正されます。

バッチモードで問題を検出したり、コードの再フォーマットで自動的に修正したりすることもできます。

コードの再フォーマットに関する問題を修正する

PHP CS Fixer によって検出された問題は、コードの再フォーマットアクションを実行することで修正できます。

  1. 品質ツールの設定PHP CS Fixer を外部フォーマッタとして設定します。

    これを行うには、設定ダイアログ (Ctrl+Alt+S) で PHP | 品質ツールに移動し、外部フォーマッターセクションで PHP CS Fixer を選択します。

    Select external formatter
  2. 必要なファイルまたはプロジェクトスコープにコードの整形を適用します。

    • エディターで開かれたコードフラグメントまたはファイルの場合、メインメニューからコード | コードの整形を選択するか、Ctrl+Alt+L を押します。

    • プロジェクトツールウィンドウで選択したファイル、ディレクトリ、ファイルのグループについて、コンテキストメニューからコードの整形を選択するか、Ctrl+Alt+L を押します。

チームでカスタムコーディングスタイルを共有する

  1. コーディング標準のルートディレクトリをプロジェクトルートの下に置きます。

  2. PHP CS Fixer を PhpStorm インスペクションとして設定します

  3. コーディング標準を指定します。

  4. インスペクションページの上部でプロジェクトプロファイルが選択されていることを確認します。このようなプロファイルは、特定のプロジェクトの .idea ディレクトリ (たとえば、$PROJECT_DIR$/.idea/inspectionProfiles) に保存されます。詳細については、「プロファイルを構成する」を参照してください。

  5. 設定ダイアログのバージョン管理ページで、.idea ディレクトリがバージョン管理下にあることを確認します。

PHP CS Fixer インスペクションからファイルを除外する

PHP CS Fixer の応答を待つときに、PHP CS Fixer ダイアログのツールプロセスのタイムアウトフィールドで指定された制限を超えると、PhpStorm はファイルを無視リストに追加することを提案します。

  1. 設定ダイアログ (Ctrl+Alt+S) で、PHP | 品質ツール | PHP CS Fixer に移動します。

  2. 無視対象ファイルの表示リンクをクリックします。

    • ファイルを追加するには、the Add button をクリックし、表示されるダイアログで目的のファイルを探します。

    • リストからファイルを削除して PHP CS Fixer に再度処理させるには、ファイルを選択して the Remove button をクリックします。

    • 一覧からすべてのファイルを削除するには、the Close button をクリックします。

関連ページ:

コードインスペクション

PhpStorm には、プロジェクト内の異常なコードを検出して修正する一連のコードインスペクションがあります。IDE は、さまざまな問題を見つけてハイライトし、デッドコードを見つけ、考えられるバグやスペルの問題を見つけ、全体的なコード構造を改善することができます。インスペクションは、すべてのプロジェクトファイルまたは特定のスコープでのみ(たとえば、本番コードまたは変更されたファイルでのみ)コードをスキャンできます。すべてのインスペクションには、問題がコードに影響を与える可能性がある程度の重大度レ...

インスペクションを実行する

PhpStorm は、エディターで開かれたファイル内のコードを分析し、入力時に問題のあるコードをハイライトします。さらに、選択したファイル範囲に対して必要なインスペクションまたは一連のインスペクションを手動で実行できます。この場合、ファイル内で検出されたすべての問題に関する包括的なレポートが得られます。現在のファイルの即時分析:IDE は継続的にコードをチェックし、問題を検索します。エディターの右上隅にあるウィジェットには、現在のファイルで検出された各重大度の問題の数が表示されます。ウィジェッ...

問題ツールウィンドウ

問題ツールウィンドウには、PhpStorm がプロジェクト内で検出した問題がいくつかのタブを使用して表示されます。ウィンドウ内で問題を選択してを押すか、問題をダブルクリックしてエディター内の対応する行に移動します。ツールウィンドウのタブを切り替えるには、とを押します。設計時コードインスペクションが有効になっている場合、このタブには、現在のファイルで見つかったすべてのコードの問題が一覧表示されます。エディターでファイルを切り替えると、リストが更新されます。ツールバー:表示オプション重大度で

リモート PHP インタープリターの構成

リモート PHP インタープリターという用語は、リモートホストまたは仮想環境にインストールされた PHP エンジンを指します。リモート PHP インタープリターという用語は、コンピューターにインストールされているローカル PHP インタープリターの対義語として使用されます (ローカル PHP インタープリターの構成を参照)。SSH、Docker、Docker Compose、Vagrant、WSL を介してリモート PHP インタープリターにアクセスできます。SSH を使用すると、PHP インター...

Composer 依存関係マネージャー

PhpStorm は Composer 依存関係マネージャーと統合されています。これにより、Packagist またはカスタムリポジトリからのパッケージをプロジェクトの依存関係として宣言し、IDE から管理できます。PhpStorm は以下を提供します。一般的な Composer コマンド (init、install、update、および多数の追加 Composer コマンド) を実行するための専用ユーザーインターフェース。コマンド出力は Composer ログコンソールに表示されます。PhpStorm...

ローカル PHP インタープリターを構成する

ローカル PHP インタープリターは、リモートホスト、Docker コンテナー、または Vagrant 仮想環境にインストールされるリモート PHP インタープリターとは対照的に、コンピューターにインストールされる PHP エンジンです。ローカル PHP インタープリターを構成するを押して設定を開き、を選択します。表示される PHP ページで、CLI インタープリターリストの横にあるをクリックします。表示される CLI インタープリターダイアログで、左側のペインのをクリックして、ポップアップメニュー...