El espacio de nombres no coincide con la estructura de carpetas (IDE0130)

Propiedad Value
Identificador de la regla IDE0130
Título El espacio de nombres no coincide con la estructura de carpetas
Categoría Estilo
Subcategoría Reglas del lenguaje (preferencias de nivel de expresión)
Lenguajes aplicables C# y Visual Basic
Opciones dotnet_style_namespace_match_folder

Información general

Esta regla de estilo usa la estructura de carpetas del proyecto para aplicar los requisitos de nomenclatura del espacio de nombres.

Opciones

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

dotnet_style_namespace_match_folder

Propiedad Value Descripción
Nombre de la opción dotnet_style_namespace_match_folder
Valores de opción true Se prefiere que la nomenclatura del espacio de nombres coincida con la estructura de carpetas.
false Deshabilita la regla.
Valor de opción predeterminado true

Nota

La opción dotnet_style_namespace_match_folder depende del conocimiento del proyecto actual y de las propiedades del espacio de nombres raíz. Visual Studio proporciona esta información, pero no está disponible para compilaciones de línea de comandos, como dotnet build. Para que las compilaciones de línea de comandos funcionen, debe agregar las siguientes propiedades al archivo del proyecto:

<ItemGroup>
  <CompilerVisibleProperty Include="RootNamespace" />
  <CompilerVisibleProperty Include="ProjectDir" />
</ItemGroup>

Ejemplo

Supongamos que los siguientes fragmentos de código proceden de un archivo denominado Data/Example.cs o Data/Example.vb, donde Data representa la estructura de carpetas del archivo del proyecto. La nomenclatura de la estructura de carpetas se agrega al espacio de nombres raíz, que en este ejemplo es Root.

// Code with violations
namespace Root.BadExample
{
    class Example
    {
        public void M()
        {
        }
    }
}

// Fixed code
namespace Root.Data
{
    class Example
    {
        public void M()
        {
        }
    }
}
' Code with violations
Namespace Root.BadExample
    Class Example
        Public Sub M()
        End Sub
    End Class
End Namespace

' Fixed code
Namespace Root.Data
    Class Example
        Public Sub M()
        End Sub
    End Class
End Namespace

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 IDE0130
// The code that's violating the rule is on this line.
#pragma warning restore IDE0130

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.IDE0130.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