Share via


MSBuild 任务

更新:2007 年 11 月

基于一个 MSBuild 项目生成另一个 MSBuild 项目。

参数

下表描述了 MSBuild 任务的参数。

参数

说明

BuildInParallel

可选的 Boolean 参数。

如果为 true,则尽可能并行生成在 Projects 参数中指定的项目。默认值为 true。

Projects

必选的 ITaskItem[] 参数。

指定要生成的项目文件。

Properties

可选的 String 参数。

以分号分隔的属性名称/值对列表,这些属性名称/值对将作为全局属性应用于子项目。当使用 MSBuild.exe 生成项目时,指定此参数在功能上等效于设置具有 /property 开关的属性。例如:

Properties="Configuration=Debug;Optimize=$(Optimize)"

通过 Properties 参数向项目传递属性时,即使已加载项目文件,MSBuild 也会创建该项目的一个新实例。创建项目的新实例后,MSBuild 会将其视为具有不同的全局属性并且可与该项目的其他实例并行生成的不同项目。例如,“发布”配置可与“调试”配置同时生成。

ToolsVersion

可选的 String 参数。

使 MSBuild 任务生成一个项目,该项目面向与项目中指定的版本不同的 .NET Framework 版本。有效值为 2.0、3.0 和 3.5。默认值为 3.5。

RebaseOutputs

可选的 Boolean 参数。

如果设置为 true,生成项目中目标输出项的相对路径将调整为相对于调用项目的路径。默认为值 false。

RunEachTargetSeparately

可选的 Boolean 参数。

如果为 true,MSBuild 任务将一次调用一个传递给 MSBuild 的列表中的目标,而不是同时调用这些目标。将此参数设置为 true 可保证即使先前调用的目标失败,仍调用后续目标。否则,生成错误将停止对所有后续目标的调用。默认值为 false。

StopOnFirstFailure

可选的 Boolean 参数。

如果设置为 true,将会强制任务在剩余的任一项目失败时立即停止生成剩余项目。

TargetOutputs

可选的 ITaskItem[] 只读输出参数。

从所有项目文件返回生成目标的输出。只返回指定目标中的输出,不返回这些目标所依赖的目标中可能存在的任何输出。

TargetOutputs 参数还包含以下元数据:

  • MSBuildProjectFile:包含设置输出的目标的 MSBuild 项目文件。

  • MSBuildTargetName:设置输出的目标。

说明:

如果要单独标识每个项目文件或目标中的输出,可以为每个项目文件或目标单独运行 MSBuild 任务。如果仅通过运行一次 MSBuild 任务来生成所有的项目文件,那么所有目标的输出都将会收集到一个数组中。

Targets

可选的 String 参数。

指定要在项目文件中生成的一个或多个目标。使用分号分隔目标名称列表。如果 MSBuild 任务中未指定目标,将会生成项目文件中指定的默认目标。

说明:

目标必须存在于所有的项目文件中。如果这些目标不存在,将会出现生成错误。

备注

与使用 Exec 任务启动 MSBuild.exe 不同,此任务使用同一个 MSBuild 进程来生成子项目。可以跳过的已生成目标列表在父生成进程与子生成进程之间共享。此外,此任务的速度更快,因为它不创建任何新的 MSBuild 进程。

此任务不但可以处理项目文件,而且还可以处理解决方案文件。

即使配置涉及远程基础结构(例如,端口、协议、超时、重试等),也必须通过使用配置文件使 MSBuild 为了可以同时生成项目而需要的任何配置变得可配置。如果可能,应该能够将配置项指定为 MSBuild 任务中的任务参数。

从 MSBuild 3.5 开始,解决方案项目现在可从它生成的所有子项目中显示 TargetOutputs。

向项目传递属性

在 MSBuild 3.5 之前的 MSBuild 版本中,很难向 MSBuild 项中列出的不同项目传递一系列不同的属性。如果使用 MSBuild 任务的 Properties 属性 (Attribute),则其设置将应用于生成的所有项目,除非分批处理 MSBuild 任务并有条件地为项列表中的每个项目提供不同属性 (Property)。

但是,MSBuild 3.5 提供了两个新的保留元数据项:Properties 和 AdditionalProperties,您可以通过这两个元数据项灵活地向使用 MSBuild 任务生成的不同项目传递不同的属性。

说明:

这些新的元数据项只适用于在 MSBuild 任务的 Projects 属性中传递的项。

多处理器生成的优点

在多处理器系统中并行生成项目时,使用这一新元数据的一个主要优点便会显现出来。通过该元数据,可将所有项目都合并到一个 MSBuild 任务调用中,而无需执行任何批处理或条件 MSBuild 任务。在只调用一个 MSBuild 任务时,Projects 属性中列出的所有项目都将并行生成。(但仅当 MSBuild 任务中存在 BuildInParallel=true 属性时,才会出现上述情况。)有关更多信息,请参见针对多处理器的生成

Properties 元数据

一种常见的情况是使用 MSBuild 任务只通过不同的生成配置来生成多个解决方案文件。您可能要使用“调试”配置生成解决方案 a1,使用“发布”配置生成解决方案 a2。在 MSBuild 2.0 中,此项目文件将类似于以下内容:

说明:

在下面的示例中,“...”表示其他解决方案文件。

a.proj

<Project xmlns="https://schemas.microsoft.com/developer/msbuild/2003">
    <Target Name="Build">
        <MSBuild Projects="a1.sln…" Properties="Configuration=Debug"/>
        <MSBuild Projects="a2.sln" Properties="Configuration=Release"/>
    </Target>
</Project>

但是,通过使用 Properties 元数据,可将此简化为只使用一个 MSBuild 任务,如下所示:

a.proj

<Project xmlns="https://schemas.microsoft.com/developer/msbuild/2003">
    <ItemGroup>
        <ProjectToBuild Include="a1.sln…">
            <Properties>Configuration=Debug</Properties>
        </ProjectToBuild>
        <ProjectToBuild Include="a2.sln">
            <Properties>Configuration=Release</Properties>
        </ProjectToBuild>
    </ItemGroup>
    <Target Name="Build">
        <MSBuild Projects="@(ProjectToBuild)"/>
    </Target>
</Project>

- 或 -

<Project xmlns="https://schemas.microsoft.com/developer/msbuild/2003">
    <ItemGroup>
        <ProjectToBuild Include="a1.sln…"/>
        <ProjectToBuild Include="a2.sln">
            <Properties>Configuration=Release</Properties>
        </ProjectToBuild>
    </ItemGroup>
    <Target Name="Build">
        <MSBuild Projects="@(ProjectToBuild)" 
          Properties="Configuration=Debug"/>
    </Target>
</Project>

AdditionalProperties 元数据

请考虑使用 MSBuild 任务生成两个解决方案文件的情况,两个文件都使用“发布”配置,但其中一个文件使用 x86 体系结构,另一个文件使用 ia64 体系结构。在 MSBuild 2.0 中,您将需要创建 MSBuild 任务的多个实例:一个实例将“发布”配置与 x86 体系结构结合使用来生成项目,另一个实例则将“发布”配置与 ia64 体系结构结合使用。您的项目文件将类似于以下内容:

a.proj

<Project xmlns="https://schemas.microsoft.com/developer/msbuild/2003">
    <Target Name="Build">
        <MSBuild Projects="a1.sln…" Properties="Configuration=Release; 
          Architecture=x86"/>
        <MSBuild Projects="a2.sln" Properties="Configuration=Release; 
          Architecture=ia64"/>
    </Target>
</Project>

通过使用 AdditionalProperties 元数据,可将此操作简化为只使用一个 MSBuild 任务,如下所示:

a.proj

<Project xmlns="https://schemas.microsoft.com/developer/msbuild/2003">
    <ItemGroup>
        <ProjectToBuild Include="a1.sln…">
            <AdditionalProperties>Architecture=x86
              </AdditionalProperties>
        </ProjectToBuild>
        <ProjectToBuild Include="a2.sln">
            <AdditionalProperties>Architecture=ia64
              </AdditionalProperties>
        </ProjectToBuild>
    </ItemGroup>
    <Target Name="Build">
        <MSBuild Projects="@(ProjectToBuild)" 
          Properties="Configuration=Release"/>
    </Target>
</Project>

示例

下面的示例使用 MSBuild 任务来生成 ProjectReferences 项集合指定的项目。生成的目标输出存储在 AssembliesBuiltByChildProjects 项集合中。

<Project xmlns="https://schemas.microsoft.com/developer/msbuild/2003">

    <ItemGroup>
        <ProjectReferences Include="*.*proj" />
    </ItemGroup>

    <Target Name="BuildOtherProjects">
        <MSBuild
            Projects="@(ProjectReferences)"
            Targets="Build">
            <Output
                TaskParameter="TargetOutputs"
                ItemName="AssembliesBuiltByChildProjects" />
        </MSBuild>
    </Target>

</Project>

请参见

概念

MSBuild 任务

其他资源

MSBuild 任务参考