다음을 통해 공유


방법: 빌드 시 환경 변수 사용

업데이트: 2007년 11월

프로젝트를 빌드할 때 프로젝트 파일 또는 프로젝트를 구성하는 파일에 없는 정보를 사용하여 빌드 옵션을 설정해야 할 경우가 있습니다. 이 정보는 일반적으로 환경 변수에 저장됩니다.

환경 변수 참조

모든 환경 변수는 Microsoft Build Engine(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>

참고 항목

작업

방법: 동일한 소스 파일을 다른 옵션을 사용하여 빌드

개념

MSBuild

MSBuild 속성