Excluir archivos de la compilación
En un archivo de proyecto puede utilizar comodines para incluir todos los archivos de un directorio o un conjunto de directorios anidado como entradas para una compilación. Sin embargo, puede haber un archivo en el directorio o un directorio en el conjunto anidado de directorios que no quiera incluir como entrada para una compilación. Puede excluir explícitamente ese archivo o directorio de la lista de entradas. También puede haber un archivo en un proyecto que solo quiera incluir bajo determinadas condiciones. Se pueden declarar explícitamente las condiciones para incluir un archivo en una compilación.
Nota:
Las técnicas descritas en este artículo no son aplicables a F# ni C++. Esos sistemas de proyecto administran los propios archivos de origen.
Exclusión de un archivo mediante Visual Studio
Si usa Visual Studio, seleccione el archivo en el Explorador de soluciones, vea la ventana Propiedades (presione Alt+Entrar) y establezca la acción de compilación en Ninguno.
Esto da como resultado los siguientes cambios en el archivo de proyecto de MSBuild:
<ItemGroup>
<Compile Remove="ClassToExclude.cs" />
</ItemGroup>
<ItemGroup>
<None Include="ClassToExclude.cs" />
</ItemGroup>
Esto funciona bien para algunos archivos, pero no se escala verticalmente a un mayor número de archivos o archivos que coinciden con un patrón determinado. En los proyectos de .NET, puede usar MSBuild para excluir archivos y directorios mediante una expresión comodín, también denominada glob, como se describe a continuación.
Exclusión de archivos o directorios en proyectos de .NET
Las listas de elementos son los archivos de entrada para una compilación. Para la mayoría de los proyectos, como los proyectos del SDK de .NET, hay listas de elementos predefinidos de distintos tipos de elementos (por ejemplo, Compile
para archivos de código fuente, Content
para determinados archivos estáticos, etc.) que ya están definidos por las importaciones estándar. Puede encontrar una lista de estos elementos en Elementos comunes del proyecto de MSBuild. En el código del proyecto, estos están predefinidos para incluir todo lo pertinente; por ejemplo, Compile
en un proyecto de C# incluye todos los archivos con la extensión .cs
.
Para excluir archivos, puede usar el atributo Remove
en el elemento.
<ItemGroup>
<Compile Remove="ClassToExclude.cs" />
</ItemGroup>
Puede especificar varios archivos individuales o varios patrones globales:
<ItemGroup>
<Compile Remove="Contoso*.cs" /> <!-- Wildcard on filename -->
<Compile Remove="File1.cs;File2.cs" /> <!-- List of files with separator -->
<Compile Remove="Contoso/**/*.cs" /> <!-- All .cs files in a directory subtree -->
</ItemGroup>
Para obtener una lista de patrones admitidos, consulte Formatos de patrón.
Incluir y excluir archivos o directorios en el lenguaje MSBuild
En el lenguaje MSBuild sin procesar (es decir, sin ninguna de las importaciones estándar o referencia a un SDK), los elementos que desea incluir se declaran por separado o como un grupo mediante el atributo Include
. Por ejemplo:
<CSFile Include="Form1.cs"/>
<CSFile Include ="File1.cs;File2.cs"/>
<CSFile Include="*.cs"/>
<JPGFile Include="Images\**\*.jpg"/>
Si se han utilizado comodines para incluir todos los archivos de un directorio o un conjunto de directorios anidado como entradas para una compilación, puede haber uno o más archivos en el directorio o un directorio en el conjunto de directorios anidado que no quiera incluir. Para excluir un elemento de la lista de elementos, utilice el atributo Exclude
.
Exclude
no es realmente una operación de elemento; no se puede usar por sí mismo, sino solo como modificador para Include
.
Para incluir todos los archivos .cs
o *.vb
excepto Form2
Utilice uno de los siguientes atributos
Include
yExclude
:<CSFile Include="*.cs" Exclude="Form2.cs"/>
o
<VBFile Include="*.vb" Exclude="Form2.vb"/>
Para incluir todos los archivos .cs
o .vb
excepto Form2
y Form3
Utilice uno de los siguientes atributos
Include
yExclude
:<CSFile Include="*.cs" Exclude="Form2.cs;Form3.cs"/>
o
<VBFile Include="*.vb" Exclude="Form2.vb;Form3.vb"/>
Para incluir todos los archivos .jpg
de los subdirectorios del directorio Images
, excepto los del directorio Version2
Utilice los siguientes atributos
Include
yExclude
:<JPGFile Include="Images\**\*.jpg" Exclude = "Images\**\Version2\*.jpg"/>
Nota
Debe especificar la ruta de acceso de ambos atributos. Si utiliza una ruta de acceso absoluta para especificar ubicaciones de archivos en el atributo
Include
, también debe utilizar una ruta de acceso absoluta en el atributoExclude
; si utiliza una ruta de acceso relativa en el atributoInclude
, también debe utilizar una ruta de acceso relativa en el atributoExclude
.
Excluir y quitar
Si va a definir sus propias listas de elementos, debe usar Exclude
siempre que sea posible. Hay una ventaja de rendimiento para usar Exclude
en la misma declaración que Include
, ya que los elementos que se excluirían no tienen que procesarse.
Use Remove
cuando tenga una lista de elementos predefinida, como en el caso de las listas de elementos estándar como Compile
y Content
. En ese caso, Exclude
no se admite.
Nota:
Si usa un SDK que lo admita, puede establecer la propiedad $(OverrideDefaultCompileItems)
en true
y definir su propio elemento Compile
con Include
y, opcionalmente, Exclude
.
Usar condiciones para excluir un archivo o un directorio de las entradas de una compilación
Si hay elementos que quiere incluir, por ejemplo, en una compilación de depuración, pero no en una compilación de versión, puede utilizar el atributo Condition
para especificar las condiciones en las que se va a incluir el elemento.
Para incluir el archivo Formula.vb solo en compilaciones de versión
Utilice un atributo
Condition
similar al siguiente:<Compile Include="Formula.vb" Condition=" '$(Configuration)' == 'Release' " />
Ejemplo
En el ejemplo de código siguiente se compila un proyecto con todos los archivos .cs del directorio, excepto Form2.cs.
<Project DefaultTargets="Compile"
xmlns="http://schemas.microsoft.com/developer/msbuild/2003" >
<PropertyGroup>
<builtdir>built</builtdir>
</PropertyGroup>
<ItemGroup>
<CSFile Include="*.cs" Exclude="Form2.cs"/>
<Reference Include="System.dll"/>
<Reference Include="System.Data.dll"/>
<Reference Include="System.Drawing.dll"/>
<Reference Include="System.Windows.Forms.dll"/>
<Reference Include="System.XML.dll"/>
</ItemGroup>
<Target Name="PreBuild">
<Exec Command="if not exist $(builtdir) md $(builtdir)"/>
</Target>
<Target Name="Compile" DependsOnTargets="PreBuild">
<Csc Sources="@(CSFile)"
References="@(Reference)"
OutputAssembly="$(builtdir)\$(MSBuildProjectName).exe"
TargetType="exe" />
</Target>
</Project>