Simplificación del patrón de propiedad (IDE0170)

Propiedad Value
Identificador de la regla IDE0170
Título Simplificación del patrón de propiedad
Categoría Estilo
Subcategoría Reglas del lenguaje (preferencias de coincidencia de patrones)
Lenguajes aplicables C#
Opciones csharp_style_prefer_extended_property_pattern

Información general

Esta regla de estilo marca el uso de un patrón anidado en un patrón de propiedad. Los patrones anidados se pueden simplificar para usar un patrón de propiedad ampliado en el que se usen subpatrones de propiedad para hacer referencia a los miembros anidados. Los patrones de propiedad ampliados mejoran la legibilidad del código.

Opciones

Las opciones especifican el comportamiento que se quiere que aplique la regla. Para obtener información sobre la configuración de las opciones, consulte Formato de opción.

csharp_style_prefer_extended_property_pattern

Propiedad Value Descripción
Nombre de la opción csharp_style_prefer_extended_property_pattern
Valores de opción true Prefiere el patrón de propiedad ampliado.
false Deshabilita la regla.
Valor de opción predeterminado true

Ejemplo

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

Supresión de una advertencia

Si solo quiere suprimir una única infracción, agregue directivas de preprocesador al archivo de origen para deshabilitar y volver a habilitar la regla.

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

Para deshabilitar la regla de un archivo, una carpeta o un proyecto, establezca su gravedad en none del archivo de configuración.

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

Para deshabilitar todas las reglas de estilo del código, establezca la gravedad de la categoría Style en none del archivo de configuración.

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

Para obtener más información, consulte Procedimiento para suprimir advertencias de análisis de código.

Vea también