グローバル 'SuppressMessageAttribute' のレガシ形式ターゲットを避ける (IDE0077)

プロパティ
ルール ID IDE0077
Title グローバルな SuppressMessageAttribute でレガシ形式のターゲットを回避する
カテゴリ CodeQuality
Subcategory その他の規則
該当言語 C# および Visual Basic

概要

この規則は、レガシ形式の FxCop ターゲット文字列を使用する Target を指定するグローバルの SuppressMessageAttributes にフラグを設定します。 レガシ形式の Target を使用すると、パフォーマンスの問題が発生することがわかっているため、回避する必要があります。 詳細については、dotnet/roslyn issue 44362 を参照してください。

Target に推奨される形式は "ドキュメント ID" 形式です。 ドキュメント ID の詳細については、ドキュメント ID 形式に関する記事を参照してください。

ヒント

Visual Studio 2019 では、属性の Target を推奨される形式に自動的に変更するコード修正プログラムを提供しています。

オプション

この規則には、関連付けられているコード スタイル オプションはありません。

// IDE0077: Legacy format target 'N.C.#F'
[assembly: System.Diagnostics.CodeAnalysis.SuppressMessage("Category", "Id: Title", Scope = "member", Target = "N.C.#F")]

// Fixed code
[assembly: System.Diagnostics.CodeAnalysis.SuppressMessage("Category", "Id: Title", Scope = "member", Target = "~F:N.C.F")]

namespace N
{
    class C
    {
        public int F;
    }
}

警告を抑制する

単一の違反だけを抑制する場合は、ソース ファイルにプリプロセッサ ディレクティブを追加して無効にしてから、規則を再度有効にします。

#pragma warning disable IDE0077
// The code that's violating the rule is on this line.
#pragma warning restore IDE0077

ファイル、フォルダー、またはプロジェクトのルールを無効にするには、構成ファイルでその重要度を none に設定します。

[*.{cs,vb}]
dotnet_diagnostic.IDE0077.severity = none

規則のこのカテゴリ全体を無効にするには、構成ファイルでカテゴリの重要度を none に設定します。

[*.{cs,vb}]
dotnet_analyzer_diagnostic.category-CodeQuality.severity = none

詳細については、「コード分析の警告を抑制する方法」を参照してください。

関連項目