El espacio de nombres no coincide con la estructura de carpetas (IDE0130)
Propiedad | Valor |
---|---|
Identificador de la regla | IDE0130 |
Título | El espacio de nombres no coincide con la estructura de carpetas |
Categoría | Estilo |
Subcategoría | Reglas de lenguaje (preferencias de nivel de expresión) |
idiomas aplicables | C# y Visual Basic |
Opciones | dotnet_style_namespace_match_folder |
Visió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 desea que aplique la regla. Para obtener información sobre cómo configurar opciones, vea Formato de opción.
dotnet_style_namespace_match_folder
Propiedad | Valor | Descripción |
---|---|---|
nombre de 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 de conocer las propiedades actuales del proyecto y 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
Suprimir una advertencia
Si desea suprimir solo una 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
en el archivo de configuración de .
[*.{cs,vb}]
dotnet_diagnostic.IDE0130.severity = none
Para deshabilitar todas las reglas de estilo de código, establezca la gravedad de la categoría Style
a none
en el archivo de configuración .
[*.{cs,vb}]
dotnet_analyzer_diagnostic.category-Style.severity = none
Para obtener más información, vea Cómo suprimir advertencias de análisis de código.