Choose 要素 (MSBuild)
子要素を評価して、評価対象となる一連の ItemGroup 要素や PropertyGroup 要素を選択します。
<Choose>
<When Condition="'StringA'=='StringB'">... </When>
<Otherwise>... </Otherwise>
</Choose>
属性および要素
以降のセクションでは、属性、子要素、および親要素について説明します。
属性
なし。
子要素
要素 |
Description |
---|---|
省略可能な要素です。 すべての When 要素が false と評価された場合に評価する、PropertyGroup 要素および ItemGroup 要素のコード ブロックを指定します。Choose 要素で持つことのできる Otherwise 要素の数は、0 か 1 です。また、これは最後の要素となる必要があります。 |
|
必須の要素。 Choose 要素で選択する、コード ブロックの候補を指定します。Choose 要素には、When 要素を 1 つ以上指定できます。 |
親要素
要素 |
Description |
---|---|
すべての When 要素が false と評価された場合に実行するコード ブロックを指定します。 |
|
MSBuild プロジェクト ファイルの必須のルート要素です。 |
|
Choose 要素で選択する、コード ブロックの候補を指定します。 |
解説
Choose 要素、When 要素、および Otherwise 要素は、いくつかのコード セクションの中から、実行する 1 つを選択するために、一緒に使用します。詳細については、「MSBuild の条件構造」を参照してください。
使用例
次のプロジェクトでは、Choose 要素を使用して、When 要素内のプロパティ値の組のうち、設定対象となる組を選択しています。両方の When 要素の Condition 属性の評価結果が false の場合には、Otherwise 要素内のプロパティ値が設定されます。
<Project
xmlns="https://schemas.microsoft.com/developer/msbuild/2003" >
<PropertyGroup>
<Configuration Condition="'$(Configuration)' == ''">Debug</Configuration>
<OutputType>Exe</OutputType>
<RootNamespace>ConsoleApplication1</RootNamespace>
<AssemblyName>ConsoleApplication1</AssemblyName>
<WarningLevel>4</WarningLevel>
</PropertyGroup>
<Choose>
<When Condition=" '$(Configuration)'=='debug' ">
<PropertyGroup>
<DebugSymbols>true</DebugSymbols>
<DebugType>full</DebugType>
<Optimize>false</Optimize>
<OutputPath>.\bin\Debug\</OutputPath>
<DefineConstants>DEBUG;TRACE</DefineConstants>
</PropertyGroup>
<ItemGroup>
<Compile Include="UnitTesting\*.cs" />
<Reference Include="NUnit.dll" />
</ItemGroup>
</When>
<When Condition=" '$(Configuration)'=='retail' ">
<PropertyGroup>
<DebugSymbols>false</DebugSymbols>
<Optimize>true</Optimize>
<OutputPath>.\bin\Release\</OutputPath>
<DefineConstants>TRACE</DefineConstants>
</PropertyGroup>
</When>
<Otherwise>
<PropertyGroup>
<DebugSymbols>true</DebugSymbols>
<Optimize>false</Optimize>
<OutputPath>.\bin\$(Configuration)\</OutputPath>
<DefineConstants>DEBUG;TRACE</DefineConstants>
</PropertyGroup>
</Otherwise>
</Choose>
<Import Project="$(MSBuildBinPath)\Microsoft.CSharp.targets" />
</Project>