リレーショナルコンバーターを生成する
ReSharper は、選択したフィールドとプロパティを使用して Comparer<T>
から派生したネストされた比較クラスを作成できます。文字列比較アルゴリズムの選択と null チェックの生成に加えて、比較クラスをコンシューマーに公開する静的プロパティを生成することもできます。
以下の例では、このコマンドを使用して、Person
クラスのオブジェクトを比較するときに、int _birthYear
および string _name
フィールドを考慮に入れたリレーショナル比較関数を生成します。
生成前 | 生成後 |
---|---|
class Person
{
private int _birthYear;
private string _name;
}
|
class Person
{
private int _birthYear;
private string _name;
private sealed class BirthYearNameRelationalComparer : Comparer<Person>
{
public override int Compare(Person x, Person y)
{
if (ReferenceEquals(x, y)) return 0;
if (ReferenceEquals(null, y)) return 1;
if (ReferenceEquals(null, x)) return -1;
var birthYearComparison = x._birthYear.CompareTo(y._birthYear);
if (birthYearComparison != 0) return birthYearComparison;
return string.Compare(x._name, y._name, StringComparison.Ordinal);
}
}
public static Comparer<Person> BirthYearNameComparer { get; }
= new BirthYearNameRelationalComparer();
}
|
リレーショナル比較クラスを生成する
エディターで、型名または型内のリレーショナル比較クラスを挿入する行にキャレットを置きます。キャレットが型名上にある場合、生成されたコードは型宣言の先頭に追加されます。
Alt+Insert を押すか、メインメニューから
を選択します。あるいは、Control+Shift+A を押して、ポップアップでコマンド名を入力して、そこで選択することもできます。生成ポップアップで、Relational Comparer を選択します。
表示される生成ダイアログには、プロパティとフィールドのリストが表示されます。タイプの比較に使用するメンバーを選択します。
タイプにフィールド / プロパティがない場合、またはそれらのいずれかを選択しない場合、ReSharper は設定に応じて、新しい
NotImplementedException()
をスローし、デフォルト値を返し、生成されたメソッドの本体にコンパイルされないコードを置きます。ReSharper オプションの ページで設定を行うことができます。必要に応じて、ダイアログで次のコントロールを使用します。
フィールドは null 可能 — タイプに null 許容フィールドまたはプロパティがある場合に表示されます。デフォルトでは、このチェックボックスが選択されています。これは、ReSharper が選択されたフィールドに対して null チェックを生成することを意味します。null チェックが必要ない場合は、このチェックボックスをオフにすることができます。
文字列比較 — 型に文字列フィールドがある場合に表示されます。ReSharper は、選択された文字列に対して
string.Compare(string, string, StringComparison)
を生成します。セレクターを使用すると、StringComparison 引数に対して生成する値を選択できます。静的プロパティを介して公開する — 比較クラスをプライベートにし、比較クラスをコンシューマーに公開する静的プロパティを生成します。
Comparer 名の接頭辞 — 生成された比較クラスの名前で使用される接頭辞を指定できます。
完了をクリックしてウィザードを完了します。
オプションをクリックして、ReSharper オプションの ページで一般的なコード生成設定を確認または変更することもできます。
この機能は、次の言語とテクノロジーでサポートされています。
ここで説明する手順と例では、C# の機能の使用について説明します。他の言語の詳細については、言語およびフレームワークセクションの対応するトピックを参照してください。
関連ページ:
さまざまな言語の ReSharper 機能
以下の表は、各 ReSharper 機能がサポートされている言語 / テクノロジーを説明しています。これらは言語固有の機能のみをリストし、プロジェクト依存関係ダイアグラム、名前空間の調整リファクタリング、スタックトレースエクスプローラーなどのプロジェクト / ソリューションスコープの多くの機能を含まず、最近のファイルを表示します。コード解析:コードインスペクション
ASP.NET MVC 特有の機能
ReSharper には、一般的な ASP.NET 機能に加えて、ASP.NET MVC での作業をより簡単にサポートする特殊機能があります。構文のハイライト:ASP.NET MVC メソッド呼び出しとパラメーターの特別な構文のハイライト: コード補完:文字列リテラルでアクションとコントローラーを参照するための専用コード補完: ナビゲーションと検索:さまざまなナビゲーション機能がアクションとコントローラーでも機能します。コード生成:使用箇所から新しいコントローラーとアクションを作成する: 最終...
言語による ReSharper: MSBuild
MSBuild は、アプリケーションを構築するために広く使用されているプラットフォームです。特定の XML タグを使用して、プロジェクトの構築方法や実行方法を定義できます。ReSharper を使用すると、より速く行うことができます。コード検査:あらかじめ定義された要素またはその属性の名前を誤って入力した場合、ReSharper はそのような不一致についてハイライト表示します。まだ定義されていないプロパティを参照しようとすると、ReSharper はそのようなケースも検出します。MSBuild...
言語による ReSharper: Google プロトコルバッファ (Protobuf)
ReSharper オプションのページで Protobuf サポートが明示的に有効になっている場合、ReSharper は Google Protocol Buffers (Protobuf) バージョン 2.x および 3.0 の .proto ファイルでコード分析および支援機能を提供します。ReSharper は、.proto ファイルの言語構文をハイライトし、エラーを検出してハイライトします。基本コード補完と他のタイピング支援機能はエディターで利用可能です。型と値の宣言に行き、それらの使用箇所を...
言語 JSON による ReSharper
JSON および JSON スキーマのサポートは、現在、構文のハイライト(古い Visual Studio バージョンを含む)のような基本的なものから、コードのフォーマットや再配置(たとえば、オブジェクトのプロパティや任意の選択を移動できる)、コードインスペクションおよびクイックフィックスなどのより高度な機能にまでおよびます。スキーマ、パス、正規表現、パッケージを認識するコード補完も同様です。JSON 値ヘルパー:ReSharper では、JSON プロパティの一部を特定の値タイプ(正規表現、...
プロパティの生成
ReSharper は、公開したいすべてのフィールドのプロパティを生成できます。以下の例では、このコマンドを使用して、およびフィールドのプロパティを生成します。class Circle { int _radius; readonly Point _center; public Circle(int radius, Point center) { _radius = radius; _center = center; } }class Circle { int _radius; readonly...