다음을 통해 공유


MSBuild의 예약된 속성 및 잘 알려진 속성

MSBuild에서는 프로젝트 파일과 MSBuild 이진 파일에 대한 정보를 저장하는 미리 정의된 속성 집합을 제공합니다. 이러한 속성은 다른 MSBuild 속성과 동일한 방식으로 평가됩니다. 예를 들어, MSBuildProjectFile 속성을 사용하려면 $(MSBuildProjectFile)을 입력합니다.

MSBuild에서는 다음 표에 있는 값을 사용하여 예약된 속성 및 잘 알려진 속성을 미리 정의할 수 있습니다. 예약된 속성은 재정의할 수 없지만 잘 알려진 속성은 동일하게 이름이 지정된 환경 속성, 전역 속성 또는 프로젝트 파일에 선언된 속성을 사용하여 재정의할 수 있습니다.

예약된 속성 및 잘 알려진 속성

다음 표에서는 MSBuild의 미리 정의된 속성에 대해 설명합니다.

속성

설명

예약됨 또는 잘 알려짐

MSBuildBinPath

현재 사용 중인 MSBuild 이진 파일이 있는 폴더의 절대 경로(예: C:\Windows\Microsoft.Net\Framework\versionNumber)입니다. 이 속성은 MSBuild 디렉터리에 있는 파일을 참조해야 할 경우에 유용합니다.

이 속성에는 마지막 백슬래시를 포함하지 마세요.

예약됨

MSBuildExtensionsPath

.NET Framework 4에서는 MSBuildExtensionsPathMSBuildExtensionsPath32의 기본값 사이에 차이가 없음을 정의했습니다. 이전 버전에서 MSBUILDLEGACYEXTENSIONSPATH의 기본값 동작을 사용으로 설정하려면 환경 변수 MSBuildExtensionsPath를 null이 아닌 값으로 설정하면 됩니다.

.NET Framework 3.5 이전에서는 MSBuildExtensionsPath의 기본값이 현재 프로세스의 비트에 따라 \Program Files\ 또는 \Program Files (x86) 폴더 아래 MSBuild 하위 폴더의 경로를 가리킵니다. 예를 들어, 64비트 컴퓨터에 32비트 프로세스인 경우 이 속성은 \Program Files (x86) 폴더를 가리킵니다. 64비트 컴퓨터에 64비트 프로세스인 경우 이 속성은 \Program Files 폴더를 가리킵니다.

이 속성에는 마지막 백슬래시를 포함하지 마세요.

이 위치는 사용자 지정 대상 파일을 넣는 데 유용합니다. 예를 들어, 대상 파일을 \Program Files\MSBuild\MyFiles\Northwind.targets에 설치한 후 다음 XML 코드를 사용하여 프로젝트 파일로 가져옵니다.

<Import Project="$(MSBuildExtensionsPath)\MyFiles\Northwind.targets"/>

잘 알려짐

MSBuildExtensionsPath32

\Program Files 또는 \Program Files (x86) 폴더 아래에 있는 MSBuild 하위 폴더의 경로입니다. 이 경로는 항상 32비트 컴퓨터의 32비트 \Program Files 폴더를 가리키며 64비트 컴퓨터의 \Program Files (x86)를 가리킵니다. MSBuildExtensionsPathMSBuildExtensionsPath64도 참조하세요.

이 속성에는 마지막 백슬래시를 포함하지 마세요.

잘 알려짐

MSBuildExtensionsPath64

\Program Files 폴더 아래에 있는 MSBuild 하위 폴더의 경로입니다. 64비트 컴퓨터의 경우 이 경로는 항상 \Program Files 폴더를 가리킵니다. 32비트 컴퓨터에서는 이 경로가 비어 있습니다. MSBuildExtensionsPathMSBuildExtensionsPath32도 참조하세요.

이 속성에는 마지막 백슬래시를 포함하지 마세요.

잘 알려짐

MSBuildLastTaskResult

이전 작업이 오류 없이(경고가 있어도) 완료되면 true이고, 이전 작업에 오류가 있으면 false입니다. 일반적으로 작업에서 오류가 발생하면 오류는 해당 프로젝트에서 마지막으로 발생하는 항목입니다. 따라서 이 속성의 값은 false를 사용하지 않습니다. 단, 다음 시나리오에서는 제외됩니다.

예약됨

MSBuildNodeCount

작성 시 사용되는 동시 프로세스의 최대 수입니다. 이 값은 명령줄에서 /maxcpucount에 대해 지정한 값입니다. 값을 지정하지 않고 /maxcpucount를 지정한 경우 MSBuildNodeCount는 컴퓨터의 프로세서 수를 지정합니다. 자세한 내용은 MSBuild 명령줄 참조MSBuild를 사용하여 병렬로 여러 프로젝트 빌드를 참조하세요.

예약됨

MSBuildProgramFiles32

32비트 프로그램 폴더의 위치(예: C:\Program Files (x86))입니다.

이 속성에는 마지막 백슬래시를 포함하지 마세요.

예약됨

MSBuildProjectDefaultTargets

DefaultTargets 요소의 Project 특성에 지정된 대상의 전체 목록입니다. 예를 들어, 다음 Project 요소의 MSBuildDefaultTargets 속성 값이 A;B;C입니다.

<Project DefaultTargets="A;B;C" >

예약됨

MSBuildProjectDirectory

프로젝트 파일이 있는 디렉터리의 절대 경로(예: C:\MyCompany\MyProduct)입니다.

이 속성에는 마지막 백슬래시를 포함하지 마세요.

예약됨

MSBuildProjectDirectoryNoRoot

MSBuildProjectDirectory 속성 값입니다. 단, 루트 드라이브를 제외합니다.

이 속성에는 마지막 백슬래시를 포함하지 마세요.

예약됨

MSBuildProjectExtension

마침표가 포함된 프로젝트 파일의 파일 확장명(예: .proj)입니다.

예약됨

MSBuildProjectFile

파일 확장명이 포함된 프로젝트 파일의 전체 파일 이름(예: MyApp.proj)입니다.

예약됨

MSBuildProjectFullPath

파일 확장명이 포함된 프로젝트 파일의 절대 경로와 전체 파일 이름(예: C:\MyCompany\MyProduct\MyApp.proj)입니다.

예약됨

MSBuildProjectName

파일 확장명이 없는 프로젝트 파일의 파일 이름(예: MyApp)입니다.

예약됨

MSBuildStartupDirectory

MSBuild가 호출되는 폴더의 절대 경로입니다. 이 속성을 사용하면 모든 디렉터리에서 dirs.proj 파일을 만들지 않고 프로젝트 트리에서 특정 지점 아래에 모든 것을 빌드할 수 있습니다. 대신 다음과 같이 프로젝트(예: c:\traversal.proj)를 하나만 포함합니다.

<Project ...>
    <ItemGroup>
        <ProjectFiles  
           Include="$
           (MSBuildStartupDirectory)
           **\*.csproj"/>
    </ItemGroup>
    <Target Name="build">
        <MSBuild    
        Projects="@(ProjectFiles)"/>
    </Target>
</Project>

임의의 트리 위치에 빌드하려면 다음을 입력합니다.

msbuild c:\traversal.proj

이 속성에는 마지막 백슬래시를 포함하지 마세요.

예약됨

MSBuildThisFile

MSBuildThisFileFullPath의 파일 이름 및 파일 확장명 부분입니다.

예약됨

MSBuildThisFileDirectory

MSBuildThisFileFullPath의 디렉터리 부분입니다.

경로에 마지막 백슬래시를 포함하세요.

예약됨

MSBuildThisFileDirectoryNoRoot

루트 드라이브를 제외한 MSBuildThisFileFullPath의 디렉터리 부분입니다.

경로에 마지막 백슬래시를 포함하세요.

예약됨

MSBuildThisFileExtension

MSBuildThisFileFullPath의 파일 확장명 부분입니다.

예약됨

MSBuildThisFileFullPath

실행하는 대상을 포함하는 프로젝트 또는 대상 파일의 절대 경로입니다.

대상 파일에 관련되고 원본 프로젝트 파일에는 관련되지 않은 대상 파일의 상대 경로를 지정할 수 있습니다.

예약됨

MSBuildThisFileName

파일 확장명을 제외한 MSBuildThisFileFullPath의 파일 이름 부분입니다.

예약됨

MSBuildToolsPath

MSBuild 버전의 설치 경로는 MSBuildToolsVersion 값과 연결됩니다.

경로에 마지막 백슬래시를 포함하지 마세요.

이 속성은 재정의할 수 없습니다.

예약됨

MSBuildToolsVersion

프로젝트 빌드에 사용된 MSBuild 도구 집합의 버전입니다.

참고

MSBuild 도구 집합은 응용 프로그램 빌드에 사용되는 작업, 대상 및 도구로 구성됩니다.도구에는 csc.exe 및 vbc.exe와 같은 컴파일러가 포함됩니다.자세한 내용은 MSBuild 도구 집합(ToolsVersion)표준 및 사용자 지정 도구 집합 구성을 참조하세요.

예약됨

참고 항목

개념

MSBuild 속성

기타 리소스

MSBuild 참조