Aracılığıyla paylaş


Özellik düzenini basitleştirme (IDE0170)

Mülk Değer
Kural Kimliği IDE0170
Başlık Özellik düzenini basitleştirme
Kategori Üslup
Alt Kategori Dil kuralları (desen eşleştirme tercihleri)
Geçerli diller C#
Seçenekleri csharp_style_prefer_extended_property_pattern

Genel bakış

Bu stil kuralı, özellik deseni içindeiç içe desen kullanımını işaret eder. İçe içe geçmiş bir desen, özellik alt desenlerinin iç içe geçmiş üyelere başvurmak için kullanıldığı genişletilmiş bir özellik deseni kullanılarak basitleştirilebilir. Genişletilmiş özellik desenleri, kodun okunabilirliğini artırır.

Seçenekler

Seçenekler, kuralın zorlamasını istediğiniz davranışı belirtir. Seçenekleri yapılandırma hakkında bilgi için bkz. Seçenek biçimi.

csharp_style_prefer_extended_property_pattern (C# stili tercih edilen genişletilmiş özellik deseni)

Mülk Değer Açıklama
Seçenek adı csharp_stili_genişletilmiş_özellik_deseni_tercihi
Seçenek değerleri true Genişletilmiş özellik desenini tercih edin.
false Kuralı devre dışı bırakır.
varsayılan seçenek değeri true

Örnek

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 };

Uyarıyı gizleme

Yalnızca tek bir ihlali engellemek istiyorsanız, kuralı devre dışı bırakmak ve sonra yeniden etkinleştirmek için kaynak dosyanıza ön işlemci yönergeleri ekleyin.

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

Bir dosya, klasör veya projenin kuralını devre dışı bırakmak için önem derecesini yapılandırma dosyasında none olarak ayarlayın.

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

Tüm kod stili kurallarını devre dışı bırakmak için kategori Style önem derecesini yapılandırma dosyasında none olarak ayarlayın.

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

Daha fazla bilgi için bkz. Kod analizi uyarılarını gizleme.

Ayrıca bkz.