分享方式:


MSBuild 工作

從另一個 MSBuild 專案建置 MSBuild 專案。

參數

下表說明 MSBuild 工作的參數。

參數 描述
BuildInParallel 選擇性的 Boolean 參數。

如果是 true,同時也會建置 Projects 參數中指定的專案 (如果可能)。 預設值為 false
Projects 必要的 ITaskItem[] 參數。

指定要建置的專案檔。
Properties 選擇性的 String 參數。

作為全域屬性套用至子專案的屬性名稱/值組的分號分隔清單。 當您指定此參數時,它在功能上相當於當您使用 MSBuild.exe 建置時,設定具有 -property 參數的屬性。 例如:

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

當您透過 Properties 參數將屬性傳遞給專案時,即使已經載入專案檔,MSBuild 也可能建立新的專案執行個體。 MSBuild 會為指定的專案路徑和一組唯一的全域屬性建立單一專案執行個體。 例如,此行為可讓您建立多個呼叫 myproject.proj 的 MSBuild 工作,在 Configuration=Release 的情況下,您會獲得單一的 myproject.proj 執行個體 (如果工作中未指定任何唯一屬性)。 如果您指定 MSBuild 尚未看到的屬性,MSBuild 就會建立新的專案執行個體,此執行個體可與專案的其他執行個體平行建置。 例如,Release 組態可以與 Debug 組態同時建置。
RebaseOutputs 選擇性的 Boolean 參數。

如果是 true,已建置的專案中目標輸出項目的相對路徑就會將其路徑調整為相對於呼叫的專案。 預設值為 false
RemoveProperties 選擇性的 String 參數。

指定要移除的全域屬性組。
RunEachTargetSeparately 選擇性的 Boolean 參數。

如果是 true,MSBuild 工作即會一次一個叫用傳遞至 MSBuild 之清單中的每個目標,而不是同時叫用。 將此參數設定為 true,可保證即使先前叫用的目標失敗,還是會叫用後續的目標。 否則,建置錯誤便會停止叫用所有後續的目標。 預設值為 false
SkipNonexistentProjects 選擇性的 Boolean 參數。

如果是 true,將會略過不存在於磁碟上的專案檔。 否則,這類專案將會造成錯誤。 預設為 false
SkipNonexistentTargets 選擇性的 Boolean 參數。

如果是 true,將會略過存在但不包含具名 Targets 的專案檔。 否則,這類專案將會造成錯誤。 預設為 false。 已在 MSBuild 15.5 中引入。
StopOnFirstFailure 選擇性的 Boolean 參數。

如果是 true,則當其中一個專案無法建置時,將無法建置其他專案。 目前在 (使用多個處理器) 同時建置時不支援此功能。
TargetAndPropertyListSeparators 選擇性的 String[] 參數。

指定目標和屬性的清單做為 Project 中繼資料。 處理之前將不會逸出分隔符號。 例如,%3B (逸出的 ';') 將會被視為是未逸出的 ';'。
TargetOutputs 選擇性的 ITaskItem[] 唯讀輸出參數。

傳回所有專案檔中建置目標的輸出。 只會傳回所指定目標的輸出,而非可能存在於這些目標所依存的任何輸出。

TargetOutputs 參數也會包含下列中繼資料:

- MSBuildSourceProjectFile:MSBuild 專案檔,包含設定輸出的目標。
- MSBuildSourceTargetName:設定輸出的目標。 注意︰如果您想要分別找出每個專案檔或目標的輸出,請針對每個專案檔或目標個別執行 MSBuild 工作。 如果您只執行 MSBuild 工作一次來建置所有專案檔,即會將所有目標的輸出收集到一個陣列。
Targets 選擇性的 String 參數。

指定要在專案檔中建置的一或多個目標。 請使用分號分隔目標名稱清單。 如果未在 MSBuild 工作中指定目標,即會建置專案檔中指定的預設目標。 注意︰目標必須存在於所有的專案檔中。 如果沒有,就會發生建置錯誤。
ToolsVersion 選擇性的 String 參數。

指定要在將建置中專案傳遞給此工作時使用 ToolsVersion

讓 MSBuild 工作能夠建置目標與專案中所指定的 .NET Framework 不同版本的專案。 有效值為 2.03.03.5。 預設值為 3.5

備註

除了上述所列的參數,此項工作還會繼承 TaskExtension 類別中的參數,而該類別本身又繼承 Task 類別。 如需這些其他參數的清單及其描述,請參閱 TaskExtension 基底類別

不同於使用 Exec 工作來啟動 MSBuild.exe,此工作會使用相同的 MSBuild 程序來建置子專案。 父組建和子組建之間能夠共用已經建置且可略過的目標清單。 此工作的速度也會比較快,因為不會建立新的 MSBuild 程序。

此工作不只會處理專案檔,也會處理方案檔。

MSBuild 要讓專案能夠同時建置所需的任何組態,即使組態牽涉到遠端基礎結構 (例如,連接埠、通訊協定、逾時、重試等),還是必須使用組態檔,以使其成為可設定的。 如果可能,應該能夠在 MSBuild 工作上指定組態項目做為工作參數。

從 MSBuild 3.5 開始,Solution 專案現在會呈現來自其所建置之所有子專案的 TargetOutputs。

將屬性傳遞至專案

在早於 MSBuild 3.5 的 MSBuild 版本中,將不同的專案組傳遞到 MSBuild 項目中所列的不同專案是一項挑戰。 如果您使用了 MSBuild 工作的 Properties 屬性,則除非您批次處理了 MSBuild 工作,並且有條件地針對項目清單中的每個專案提供不同的屬性,否則會將其設定套用到所有已建置的專案。

不過,MSBuild 3.5 提供兩個新的保留中繼資料項目 (Properties 和 AdditionalProperties),讓您能夠彈性地使用 MSBuild 工作,為建置的不同專案傳遞不同的屬性。

注意

這些新的中繼資料項目僅適用於 MSBuild 工作的 Projects 屬性中所傳遞的項目。

多處理器組建的優點

使用這個新中繼資料主要優點之一是發生在您於多處理器系統上同時建置專案時。 中繼資料可讓您將所有專案合併成單一 MSBuild 工作呼叫,而不需執行任何批次處理或條件式 MSBuild 工作。 而且,當您只呼叫單一 MSBuild 工作時,將會同時建置 Projects 屬性中列出的所有專案 (不過,只有在 BuildInParallel=true 屬性出現於 MSBuild 工作時)。如需詳細資訊,請參閱同時建置多個專案

Properties 中繼資料

當指定時,Properties 中繼資料會覆寫工作的 Properties 參數,而 AdditionalProperties 中繼資料則會附加至該參數的定義。

常見的案例是當您使用 MSBuild 工作建置多個方案檔時,只會使用不同的建置組態。 您可能想要使用 Debug 組態來建置方案 a1,使用 Release 組態來建置方案 a2。 在 MSBuild 2.0 中,這個專案檔看起來如下:

注意

在下列範例中,"..." 代表其他方案檔。

a.proj

<Project xmlns="http://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="http://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="http://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 工作建置兩個方案檔,同時使用 Release 組態,但一個使用 x86 架構,而另一個使用 ia64 架構。 在 MSBuild 2.0 中,您必須建立 MSBuild 工作的多個執行個體︰一個使用 Release 組態搭配 x86 架構建置專案,另一個則使用 Release 組態搭配 ia64 架構建置專案。 您的專案檔看起來如下:

a.proj

<Project xmlns="http://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="http://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="http://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>

另請參閱