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.