When 要素 (MSBuild)

Choose 要素で選ぶ対象のコード ブロックを指定します。

<Project><Choose><When><Choose> ... <Otherwise><Choose> ...

構文

<When Condition="'StringA'=='StringB'">
    <PropertyGroup>... </PropertyGroup>
    <ItemGroup>... </ItemGroup>
    <Choose>... </Choose>
</When>

属性と要素

以降のセクションでは、属性、子要素、および親要素について説明します。

属性

属性 説明
条件 必須の属性です。

評価する条件です。 詳細については、「条件」を参照してください。

子要素

要素 説明
Choose 省略可能な要素です。

子要素を評価して、実行するコードのセクションを 1 つ選びます。 Choose 要素に 0 個以上の When 要素があります。
ItemGroup 省略可能な要素です。

ユーザー定義 Item 要素のセットが含まれます。 ItemGroup 要素に 0 個以上の When 要素があります。
PropertyGroup 省略可能な要素です。

ユーザー定義の Property 要素のセットを格納します。 PropertyGroup 要素に 0 個以上の When 要素があります。

親要素

要素 説明
Choose 要素 (MSBuild) 子要素を評価して、実行するコードのセクションを 1 つ選びます。

解説

Condition 属性が true と評価された場合、その When 要素の子の ItemGroup 要素と PropertyGroup 要素が実行されて、後続の When 要素はすべてスキップされます。

ChooseWhenOtherwise 要素を組み合わせて使って、実行される可能性のある複数のコード セクションから 1 つを選びます。 詳細については、「条件構造」を参照してください。

次のプロジェクトでは、Choose 要素を使って、設定する When 要素のプロパティ値のセットを選んでいます。 両方の When 要素の Condition 属性が false と評価された場合、Otherwise 要素のプロパティ値が設定されます。 この例を実行するときは、コマンド ラインからさまざまなプロパティ設定を渡してみて (msbuild myproj.proj -p:Configuration=Test;Platform=x86 など)、出力パスがどのようになるか確認してください。 この例で想定されている要件は、デバッグ ビルドとリリース ビルド用に特定のプロパティを設定することと (実際のプラットフォーム名ではなく、プラットフォームのビット数に基づく出力フォルダーなど)、"Test" と "Retail" の構成をサポートし、ただし "Retail" を "Release" として扱うことです。

<Project>
    <PropertyGroup>
       <Configuration Condition="$(Configuration) == ''">Debug</Configuration>
       <Platform Condition="$(Platform) == ''">x64</Platform>
    </PropertyGroup>

  <Choose>
     <When Condition="$(Configuration)=='Test'">
        <PropertyGroup>
            <DebugSymbols>true</DebugSymbols>
            <DebugType>full</DebugType>
            <Optimize>false</Optimize>
            <DefineConstants>DEBUG;TRACE</DefineConstants>
        </PropertyGroup>
        <Choose>
          <When Condition="$(Platform)=='x86' Or $(Platform) == 'ARM32'">
            <PropertyGroup>
                <OutputPath>.\bin\Test\32-bit\</OutputPath>
            </PropertyGroup>
          </When>
          <When Condition="$(Platform)=='x64' Or $(Platform) == 'ARM64'">
            <PropertyGroup>
                <OutputPath>.\bin\Test\64-bit\</OutputPath>
            </PropertyGroup>
          </When>
          <!-- For any other platform, use the platform name -->
          <Otherwise>
            <PropertyGroup>
              <OutputPath>.\bin\Test\$(Platform)\</OutputPath>
            </PropertyGroup>
          </Otherwise>
        </Choose>
      </When>
      <When Condition="$(Configuration)=='Retail' Or $(Configuration)=='Release'">
        <PropertyGroup>
            <DebugSymbols>false</DebugSymbols>
            <Optimize>true</Optimize>
            <DefineConstants>TRACE</DefineConstants>
        </PropertyGroup>
        <Choose>
          <When Condition="$(Platform)=='x86' Or $(Platform) == 'ARM32'">
             <PropertyGroup>
                <OutputPath>.\bin\Release\32-bit\</OutputPath>
             </PropertyGroup>
          </When>
          <When Condition="$(Platform)=='x64' Or $(Platform) == 'ARM64'">
             <PropertyGroup>
                <OutputPath>.\bin\Release\64-bit\</OutputPath>
             </PropertyGroup>
          </When>
          <!-- For any other platform, use the platform name -->
          <Otherwise>
            <PropertyGroup>
                <OutputPath>.\bin\Release\$(Platform)\</OutputPath>
            </PropertyGroup>
          </Otherwise>
        </Choose>
      </When>
      <!-- For any other configuration, use debug properties-->
      <Otherwise>
        <PropertyGroup>
            <DebugSymbols>true</DebugSymbols>
            <DebugType>full</DebugType>
            <Optimize>false</Optimize>
            <DefineConstants>DEBUG;TRACE</DefineConstants>
        </PropertyGroup>
        <Choose>
          <When Condition="$(Platform)=='x86' Or $(Platform)=='ARM32'">
            <PropertyGroup>
              <OutputPath>.\bin\$(Configuration)\32-bit\</OutputPath>
            </PropertyGroup>
          </When>
          <When Condition="$(Platform)=='x64' Or $(Platform)=='ARM64'">
            <PropertyGroup>
              <OutputPath>.\bin\$(Configuration)\64-bit\</OutputPath>
            </PropertyGroup>
          </When>
        </Choose>
       </Otherwise>
  </Choose>

  <Target Name="ShowProperties">
    <Message Text="DebugSymbols: $(DebugSymbols)"/>
    <Message Text="Optimize: $(Optimize)"/>
    <Message Text="DefineConstants: $(DefineConstants)"/>
    <Message Text="OutputPath: $(OutputPath)"/>
  </Target>
</Project>

関連項目