빌드 시 환경 변수 사용

프로젝트를 빌드할 때 프로젝트 파일이나 프로젝트를 구성하는 파일에 없는 정보를 사용하여 빌드 옵션을 설치해야 하는 경우가 많습니다. 이 정보는 대개 환경 변수에 저장되어 있습니다.

환경 변수 참조

유효한 MSBuild 속성 이름인 모든 환경 변수를 Microsoft Build Engine(MSBuild) 프로젝트 파일에 속성으로 사용할 수 있습니다. 유효한 속성 이름은 MSBuild 속성에 설명되어 있습니다. 예를 들어 숫자로 시작하는 환경 변수는 MSBuild에서 사용할 수 없습니다.

참고 항목

프로젝트 파일에 환경 변수와 이름이 같은 명시적 속성 정의가 포함되어 있으면 프로젝트 파일의 속성이 환경 변수의 값을 재정의합니다.

MSBuild 프로젝트에서 환경 변수를 사용하려면

  • 프로젝트 파일에서 선언된 변수를 참조하는 것과 같은 방식으로 환경 변수를 참조합니다. 예를 들어 다음 코드는 BIN_PATH 환경 변수를 참조합니다.

    <FinalOutput>$(BIN_PATH)\MyAssembly.dll</FinalOutput>

    환경 변수가 설정되지 않은 경우 Condition 특성을 사용하여 속성의 기본값을 제공할 수 있습니다.

속성의 기본값을 제공하려면

  • 속성에 값이 없는 경우에만 속성에서 Condition 특성을 사용하여 값을 설정합니다. 예를 들어 다음 코드는 ToolsPath 환경 변수가 설정되지 않은 경우에만 ToolsPath 속성을 c:\tools로 설정합니다.

    <ToolsPath Condition="'$(TOOLSPATH)' == ''">c:\tools</ToolsPath>

    참고 항목

    속성 이름은 대/소문자를 구분하지 않으므로 $(ToolsPath)$(TOOLSPATH)는 둘 다 같은 속성 또는 환경 변수를 참조합니다.

예시

다음 프로젝트 파일에서는 환경 변수를 사용하여 디렉터리의 위치를 지정합니다.

<Project DefaultTargets="FakeBuild">
    <PropertyGroup>
        <FinalOutput>$(BIN_PATH)\myassembly.dll</FinalOutput>
        <ToolsPath Condition=" '$(ToolsPath)' == '' ">
            C:\Tools
        </ToolsPath>
    </PropertyGroup>
    <Target Name="FakeBuild">
        <Message Text="Building $(FinalOutput) using the tools at $(ToolsPath)..."/>
    </Target>
</Project>