불필요한 제거(IDE0079)
재산 | 값 |
---|---|
규칙 ID | IDE0079 |
타이틀 | 불필요한 표시 안 함 제거 |
범주 | CodeQuality |
하위 범주 |
불필요한 코드 규칙(비표시 기본 설정) |
적용 가능한 언어 | C# 및 Visual Basic |
옵션 | dotnet_remove_unnecessary_suppression_exclusions |
개요
이 규칙은 소스에서 불필요한 pragma 및 SuppressMessageAttribute 특성 표시 안 함 플래그를 지정합니다.
소스 억제는 소스 코드의 다른 부분이 아닌 특정 위치에서 컴파일러 및 분석기 규칙 위반을 표시하지 않습니다. 일반적으로 가양성 또는 수정하지 않으려는 덜 중요한 위반을 표시하지 않는 데 사용합니다. 그러나 억제는 종종 부실해집니다. 이 문제는 가양성 방지를 위해 규칙이 수정되었거나 코드를 리팩터링하여 제거를 중복 렌더링하는 경우에 발생할 수 있습니다. 이 규칙은 제거할 수 있는 중복 제거를 식별하는 데 도움이 됩니다.
메모
빌드코드 스타일 규칙을 사용하도록 설정할
본보기
using System.Diagnostics.CodeAnalysis;
class C1
{
// Necessary pragma suppression
#pragma warning disable IDE0051 // IDE0051: Remove unused member
private int UnusedMethod() => 0;
#pragma warning restore IDE0051
// IDE0079: Unnecessary pragma suppression
#pragma warning disable IDE0051 // IDE0051: Remove unused member
private int UsedMethod() => 0;
#pragma warning restore IDE0051
public int PublicMethod() => UsedMethod();
}
class C2
{
// Necessary SuppressMessage attribute suppression
[SuppressMessage("CodeQuality", "IDE0051:Remove unused private members", Justification = "<Pending>")]
private int _unusedField;
// IDE0079: Unnecessary SuppressMessage attribute suppression
[SuppressMessage("CodeQuality", "IDE0051:Remove unused private members", Justification = "<Pending>")]
private int _usedField;
public int PublicMethod2() => _usedField;
}
옵션
옵션은 규칙을 적용할 동작을 지정합니다. 옵션 구성에 대한 자세한 내용은 옵션 형식참조하세요.
메모
option_name = value:severity
형식의 심각도 설정은 dotnet_remove_unnecessary_suppression_exclusions
옵션에 적용되지 않으므로 피해야 합니다. 대신 별도의 항목을 사용하여 심각도를 지정합니다. 예를 들면 다음과 같습니다.
dotnet_remove_unnecessary_suppression_exclusions = none
dotnet_diagnostic.IDE0079.severity = warning
dotnet_remove_unnecessary_suppression_exclusions
재산 | 값 | 묘사 |
---|---|---|
옵션 이름 | dotnet_remove_unnecessary_suppression_exclusions | |
옵션 값 | 규칙 ID 또는 범주의 쉼표로 구분된 목록(접두사로 category: ) |
나열된 규칙 또는 범주에 대한 표시 안 함 제외 |
all |
규칙을 사용하지 않도록 설정(모든 규칙 ID 제외) | |
none |
모든 규칙에 규칙을 사용하도록 설정합니다(제외 없음). | |
기본 옵션 값 | none |
using System.Diagnostics.CodeAnalysis;
class C1
{
// 'dotnet_remove_unnecessary_suppression_exclusions = IDE0051'
// Unnecessary pragma suppression, but not flagged by IDE0079
#pragma warning disable IDE0051 // IDE0051: Remove unused member
private int UsedMethod() => 0;
#pragma warning restore IDE0051
public int PublicMethod() => UsedMethod();
}
경고 표시 안 함
단일 위반만 표시하지 않으려면 소스 파일에 전처리기 지시문을 추가하여 규칙을 사용하지 않도록 설정한 다음 다시 사용하도록 설정합니다.
#pragma warning disable IDE0079
// The code that's violating the rule is on this line.
#pragma warning restore IDE0079
파일, 폴더 또는 프로젝트에 대한 규칙을 사용하지 않도록 설정하려면 해당 심각도를 구성 파일none
설정합니다.
[*.{cs,vb}]
dotnet_diagnostic.IDE0079.severity = none
이 전체 규칙 범주를 사용하지 않도록 설정하려면 구성 파일범주의 심각도를 none
설정합니다.
[*.{cs,vb}]
dotnet_analyzer_diagnostic.category-CodeQuality.severity = none
자세한 내용은 코드 분석 경고표시하지 않는 방법을 참조하세요.
참고 항목
.NET