Zjednodušení vzoru vlastností (IDE0170)
Vlastnost | Hodnota |
---|---|
ID pravidla | IDE0170 |
Název | Zjednodušení vzoru vlastností |
Kategorie | Styl |
Subcategory | Pravidla jazyka (předvolby porovnávání vzorů) |
Příslušné jazyky | C# |
Možnosti | csharp_style_prefer_extended_property_pattern |
Přehled
Toto pravidlo stylu označuje použití vnořeného vzoru ve vzoru vlastnosti. Vnořený vzor lze zjednodušit tak, aby používal rozšířený vzor vlastností, ve kterém se dílčípatterny vlastností používají k odkazování na vnořené členy. Rozšířené vzory vlastností zlepšují čitelnost kódu.
Možnosti
Možnosti určují chování, které má pravidlo vynutit. Informace o konfiguraci možností najdete v tématu Formát možností.
csharp_style_prefer_extended_property_pattern
Vlastnost | Hodnota | Popis |
---|---|---|
Název možnosti | csharp_style_prefer_extended_property_pattern | |
Hodnoty možností | true |
Upřednostňujte vzor rozšířené vlastnosti. |
false |
Zakáže pravidlo. | |
Výchozí hodnota možnosti | true |
Příklad
public record Point(int X, int Y);
public record Segment(Point Start, Point End);
// Violates IDE0170.
static bool IsEndOnXAxis(Segment segment) =>
segment is { Start: { Y: 0 } } or { End: { Y: 0 } };
// Fixed code.
static bool IsEndOnXAxis(Segment segment) =>
segment is { Start.Y: 0 } or { End.Y: 0 };
Potlačení upozornění
Pokud chcete potlačit pouze jedno porušení, přidejte do zdrojového souboru direktivy preprocesoru, které pravidlo zakažou a znovu ho povolí.
#pragma warning disable IDE0170
// The code that's violating the rule is on this line.
#pragma warning restore IDE0170
Pokud chcete pravidlo pro soubor, složku nebo projekt zakázat, nastavte jeho závažnost v konfiguračním souboru na none
.
[*.{cs,vb}]
dotnet_diagnostic.IDE0170.severity = none
Pokud chcete zakázat všechna pravidla stylu kódu, nastavte v konfiguračním souboru závažnost pro kategorii Style
na none
.
[*.{cs,vb}]
dotnet_analyzer_diagnostic.category-Style.severity = none
Další informace najdete v tématu Jak potlačit upozornění analýzy kódu.