PhpStorm 2024.1 ヘルプ

PHPStan

PhpStorm は、PHPStan(英語) ツールとの統合を通じてコード品質チェックを提供します。このツールは、一連の検証ルールに対してコードの整合性を検証します。

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

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

PHPStan 統合は、オープンソースの PHPStan プラグイン(英語)を介して実装されます。このプラグインは PhpStorm にバンドルされており、デフォルトで有効になっています。

前提条件

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

  • 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

PHPStan をインストールして構成する

Composer を使用して PHPStan をインストールする

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

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

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

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

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

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

Gutter icon for phpstan settings in composer.json

PHPStan 構成をリセットする

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

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

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

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

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

PhpStorm は PHPStan 構成を新たに実行し、composer.json の変更を適用します。

PhpStorm で PHPStan を構成する

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

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

PHPStan settings

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

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

PHPStan インスペクションを Composer で有効にする

composer.jsonスクリプト(英語)セクション内に PHPStan 構成ファイルに関する情報を含めることができます。プロジェクトの依存関係をインストールまたは更新すると、指定された構成ファイルが検出され、PHPStan 検証インスペクションが自動的に有効になります。

composer.jsonscripts セクションで構成ファイルが指定されていない場合、PhpStorm はさらにプロジェクトルートをチェックして、phpstan.neon または phpstan.neon.dist のデフォルト名を持つルールセットを見つけます。

  • composer.jsonscripts セクションで、phpstan PHPStan 起動コマンドをリーフ要素の 1 つに追加します。

    -c 引数と構成ファイルへのパスを指定します。

    "scripts": { "phpstan": "vendor/bin/phpstan -c phpstan.neon" }

インスペクション設定で PHPStan 検証を有効にする

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

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

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

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

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

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

PHPStan をバッチモードで実行する

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

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

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

  3. 問題ツールウィンドウでインスペクションの結果を表示します。PHPStan によって報告されるエラーと警告には、PhpStorm 内部インスペクションと区別するために phpstan:: というプレフィックスが付けられます。

    PHPStan inspection list

PHPStan 検証インスペクションからファイルを除外する

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

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

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

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

    • リストからファイルを削除して PHPStan に再度処理させるには、ファイルを選択して 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 インタープリターダイアログで、左側のペインのをクリックして、ポップアップメニュー...