.NET Portability Analyzer

Note

.NET Upgrade Assistant によるバイナリ分析が優先され、API ポートは非推奨となりました。 API ポートのバックエンド サービスがシャットダウンされているため、ツールを使うにはオフラインで使う必要があります。 詳細については、.NET API ポートの README を参照してください。

ライブラリでマルチプラットフォームをサポートしたい場合や、 .NET Framework アプリケーションを .NET Core で実行するのに必要な作業量を知りたい場合、 .NET Portability Analyzer というツールがアセンブリを分析し、指定された対象の .NET プラットフォームでアプリケーションまたはライブラリを移植するために不足している .NET API の詳細なレポートを提供します。 Portability Analyzer は、プロジェクトごとに 1 つのアセンブリを分析する Visual Studio 拡張機能 として、および、指定されたファイルまたはディレクトリによりアセンブリを分析する ApiPort コンソール アプリ として提供されています。

.NET Core などの新しいプラットフォームを対象とするようにプロジェクトを変換したら、Roslyn ベースのプラットフォーム互換性アナライザーを使用して、PlatformNotSupportedException の例外とその他の互換性の問題をスローする API を特定することができます。

一般的なターゲット

  • .NET Core: モジュール型の設計で、side-by-side インストールをサポートしており、クロスプラットフォームのシナリオを対象としています。 side-by-side インストールにより、他のアプリに影響を与えることなく新しい .NET Core バージョンを導入することができます。 .NET Core にアプリを移植し、複数のプラットフォームをサポートすることが目的である場合は、これが推奨されるターゲットです。
  • .NET Standard: .NET のすべての実装で使用できる .NET Standard API が含まれています。 .NET でサポートされるすべてのプラットフォームでライブラリを実行させることが目的である場合は、これが推奨されるターゲットです。
  • ASP.NET Core: .NET Core 上に構築された最新の Web フレームワークです。 複数のプラットフォームをサポートするために .NET Core に Web アプリを移植することが目的である場合は、これが推奨されるターゲットです。
  • .NET Core とプラットフォーム拡張機能: Windows 互換機能パックに加えて .NET Core API が含まれます。 .NET Framework で利用可能なテクノロジの多くが提供されます。 Windows で .NET Framework から .NET Core にアプリを移植する場合は、これが推奨されるターゲットです。
  • .NET Standard とプラットフォーム拡張機能: Windows 互換機能パックに加えて .NET Standard API が含まれます。 .NET Framework で利用可能なテクノロジの多くが提供されます。 Windows で .NET Framework から .NET Core にライブラリを移植する場合は、これが推奨されるターゲットです。

.NET Portability Analyzer の使用方法

Visual Studio で .NET Portability Analyzer を使用するには、Visual Studio Marketplace から拡張機能をダウンロードし、インストールする必要があります。 これは、Visual Studio 2017 と Visual Studio 2019 のバージョンで機能します。

重要

.NET Portability Analyzer は、Visual Studio 2022 ではサポートされていません。

Visual Studio で構成するには、[Analyze](分析)>[Portability Analyzer Settings](Portability Analyzer の設定) でターゲット プラットフォームを選択します。ターゲット プラットフォームとは、アセンブリが現在ビルドされているプラットフォーム/バージョンと比較をする、移植における違いを評価する .NET プラットフォーム/バージョンです。

Screenshot of portability analyzer.

ApiPort コンソール アプリケーションを使用して、ApiPort リポジトリからダウンロードすることもできます。 listTargets コマンド オプションを使って使用可能なターゲットの一覧を表示した後、-t または --target コマンド オプションを指定することによってターゲット プラットフォームを選択できます。

ソリューション全体の表示

多数のプロジェクトが含まれるソリューションを分析するためのステップとしては、アセンブリのサブセットのどれが何に依存しているのかを把握するために、依存関係を視覚化するのが有用です。 一般的には、依存関係グラフのリーフ ノードで始まるボトムアップ アプローチで分析結果を適用することが推奨されます。

これを取得するには、次のコマンドを実行します。

ApiPort.exe analyze -r DGML -f [directory or file]

この結果を Visual Studio で開くと次のようになります。

Screenshot of DGML analysis.

移植性を分析する

Visual Studio でプロジェクト全体を分析するには、ソリューション エクスプローラーでプロジェクトを右クリックし、 [Analyze Assembly Portability](アセンブリの移植性を分析する) を選択します。 または、 [分析] メニューで [Analyze Assembly Portability] (アセンブリの移植性を分析) を選択します。 そこから、プロジェクトの実行可能ファイルまたは DLL を選択します。

Screenshot of Portability Analyzer from Solution Explorer.

ApiPort コンソール アプリを使うこともできます。

現在のディレクトリを分析するには、次のコマンドを入力します。

ApiPort.exe analyze -f .

特定の .dll ファイルの一覧を分析するには、次のコマンドを入力します。

ApiPort.exe analyze -f first.dll -f second.dll -f third.dll

特定のバージョンをターゲットにするには、-t パラメーターを使用します。

ApiPort.exe analyze -t ".NET, Version=5.0" -f .

詳細なヘルプを表示するには ApiPort.exe -? を実行します。

自分が所有していて移植したいすべての関連する exe と dll ファイルを含め、アプリが依存しているけれども自分で所有しているのではなく移植できないファイルを除外することをお勧めします。 これにより、最も関連のある移植性レポートが得られます。

移植性の結果を表示して解釈する

レポートには、ターゲット プラットフォームによってサポートされていない API のみが表示されます。 Visual Studio で分析を実行すると、.NET 移植性レポート ファイルのリンクがポップアップ表示されます。 ApiPort コンソール アプリを使った場合は、.NET 移植性レポートは指定した形式のファイルとして保存されます。 既定では、現在のディレクトリの Excel ファイル ( .xlsx) です。

移植性の概要

Screenshot of the Portability Summary.

レポートの [Portability Summary](移植性の概要) セクションでは、実行に含まれる各アセンブリの移植性の割合が示されます。 前の例では、svcutil アプリで使われている .NET Framework API の 71.24% が、.NET Core とプラットフォーム拡張機能で使用できます。 複数のアセンブリに対して .NET Portability Analyzer ツールを実行した場合、移植性の概要レポートでは各アセンブリが 1 行に表示されます。

詳細

Screenshot of the Portability Details.

レポートの [説明] セクションには、選択したターゲット プラットフォームのいずれからも欠落している API が一覧表示されます。

  • [Target type](ターゲットの型): 型にターゲット プラットフォームに存在しない API があります
  • [Target member](ターゲットのメンバー): メンバーがターゲット プラットフォームにありません
  • [Assembly name](アセンブリ名): ない API が存在する .NET Framework アセンブリです。
  • 選択されているターゲット プラットフォームごとに 1 つの列 (".NET Core" など): [Not supported](サポートされていません) という値は、その API がこのターゲット プラットフォームでサポートされていないことを意味します。
  • [Recommended Changes](推奨される変更): それに変更することが推奨される API またはテクノロジです。 現時点では、このフィールドは空であるか、多くの API に対応しなくなっています。 API の数は多く、最新の状態に保つために尽力しているところです。 お客様に役に立つ情報を提供する代わりの解決策を検討中です。

足りないアセンブリ

Screenshot of missing assemblies.

レポートには [Missing Assemblies](足りないアセンブリ) セクションが含まれる場合があります。 このセクションには、分析されたアセンブリによって参照されている、分析されていないアセンブリの一覧が示されます。 自分が所有しているアセンブリの場合は、API Portability Analyzer の実行にそれを含めて、そのアセンブリに関する API レベルの詳細な移植性レポートを取得できます。 それがサードパーティ製のライブラリである場合は、ご自分のターゲット プラットフォームをサポートする新しいバージョンがあるかどうかを確認し、その新しいバージョンに移行することを検討してください。 この一覧には最終的に、アプリが依存し、ターゲット プラットフォームをサポートするバージョンのすべてのサード パーティ アセンブリが含まれるようにします。

.NET Portability Analyzer の詳細については、GitHub のドキュメントを参照してください。