Visual Studio 통합(MSBuild)
업데이트: 2007년 11월
Visual Studio 2005에서는 관리되는 프로젝트를 로드 및 빌드하기 위해 MSBuild를 호스팅합니다. MSBuild에서 프로젝트를 관리하므로 MSBuild 형식의 거의 모든 프로젝트는 다른 도구에서 프로젝트가 작성된 후 사용자 지정된 빌드 프로세스를 갖고 있어도 Visual Studio에서 사용될 수 있습니다.
이 항목에서는 Visual Studio의 MSBuild 호스팅 중 Visual Studio에서 로드하고 빌드할 프로젝트와 .targets 파일을 사용자 지정할 때 고려해야 하는 부분을 설명합니다. 이것으로 IntelliSense와 디버깅 같은 Visual Studio 기능이 사용자 지정 프로젝트에서 작동하는지 확인할 수 있습니다.
프로젝트 파일 이름 확장명
MSBuild.exe에서는 .*proj 패턴과 일치하는 모든 프로젝트 파일 이름 확장명을 인식합니다. 하지만 Visual Studio에서는 프로젝트를 로드할 언어별 프로젝트 시스템을 결정하는 이러한 프로젝트 파일 이름 확장명의 일부만 인식합니다. Visual Studio에는 언어 중립 MSBuild 기반 프로젝트 시스템이 없습니다.
예를 들어, Visual C# 프로젝트 시스템에서는 .csproj 파일을 로드하지만 Visual Studio에서는 .xxproj 파일을 로드할 수 없습니다. 임의의 언어로 된 소스 파일의 프로젝트 파일은 Visual Studio에 로드되는 Visual Basic, Visual C# 또는 Visual J# 프로젝트 파일과 같은 확장명을 사용해야 합니다.
잘 알려진 대상 이름
Visual Studio에서 빌드 명령을 클릭하면 프로젝트의 기본 대상이 실행됩니다. 보통 이 대상을 Build라고도 합니다. 다시 빌드 또는 정리 명령을 선택하면 프로젝트에서 같은 이름의 대상이 실행됩니다. 게시를 클릭하면 프로젝트에서 PublishOnly라는 대상이 실행됩니다.
구성 및 플랫폼
구성은 Condition 특성을 포함하는 PropertyGroup 요소에서 그룹화된 속성으로 MSBuild 프로젝트에 표시됩니다. Visual Studio에서는 표시할 프로젝트 구성과 플랫폼 목록을 만들기 위해 이러한 조건을 확인합니다. 이 목록을 추출하려면 조건의 형식이 다음과 비슷해야 합니다.
Condition=" '$(Configuration)|$(Platform)' == 'Debug|AnyCPU' "
Condition=" '$(Configuration)' == 'Release' "
Condition=" '$(Something)|$(Configuration)|$(SomethingElse)' == 'xxx|Debug|yyy' "
Visual Studio에서는 이를 위해 PropertyGroup, ItemGroup, Import, 속성 및 항목 요소에서 조건을 확인합니다.
추가 빌드 작업
Visual Studio에서는 파일 속성 창의 빌드 작업 속성을 사용하여 프로젝트에 있는 파일의 항목 컬렉션 이름을 변경할 수 있습니다. Compile, EmbeddedResource, Content, None 등의 항목 컬렉션 이름은 프로젝트에 이미 있는 다른 모든 항목 컬렉션 이름과 함께 항상 이 메뉴에 표시됩니다. 사용자 지정 항목 컬렉션 이름이 항상 이 메뉴에 표시되도록 하려면 AvailableItemName이라는 항목 컬렉션에 해당 이름을 추가하면 됩니다. 예를 들어, 프로젝트 파일에 다음을 추가하면 해당 파일을 가져오는 모든 프로젝트에 대해 JScript 사용자 지정 형식이 이 메뉴에 추가됩니다.
<ItemGroup>
<AvailableItemName Include="JScript"/>
</ItemGroup>
참고: |
---|
일부 항목 컬렉션 이름은 Visual Studio에 대해 고유하지만 이 드롭다운에는 나열되어 있지 않습니다. |
In-Process 컴파일러
가능한 경우 Visual Studio에서는 성능 향상을 위해 in-process 버전의 Visual Basic 또는 Visual C# 컴파일러를 사용하려고 시도합니다. 이러한 시도는 다음 조건이 충족되어야 제대로 작동합니다.
프로젝트의 대상에 Csc 작업(Visual C# 프로젝트의 경우) 또는 Vbc 작업(Visual Basic 프로젝트의 경우)이 있어야 합니다.
작업의 UseHostCompilerIfAvailable 매개 변수가 true로 설정되어 있어야 합니다.
지원되는 매개 변수 값만 지정해야 합니다. 작업에 지정된 모든 매개 변수는 in-process 컴파일러에서 지원되지만 일부 매개 변수 값은 지원되지 않습니다. 다음 Csc 작업 매개 변수 값은 Visual C# in-process 컴파일러에서 지원되지 않습니다.
NoConfig: false 및 빈 값은 지원되지 않습니다.
ResponseFiles: 빈 값만 지원됩니다.
AdditionalLibPaths: 빈 값만 지원됩니다.
AddModules: 빈 값만 지원됩니다.
CodePage: 0이 아닌 값은 지원되지 않습니다.
GenerateFullPaths: true는 지원되지 않습니다.
LinkResources: 빈 값만 지원됩니다.
이러한 조건이 충족되지 않으면 프로젝트는 in-process 컴파일러 대신 명령줄 컴파일러를 사용하여 컴파일됩니다.
디자인 타임 IntelliSense
빌드에서 출력 어셈블리를 생성하기 전에 Visual Studio에서 IntelliSense 지원을 받으려면 다음 조건이 충족되어야 합니다.
Compile이라는 대상이 있어야 합니다.
Compile 대상 또는 해당 종속 대상 중 하나는 프로젝트에 대해 Csc 또는 Vbc와 같은 컴파일러 작업을 호출해야 합니다.
Compile 대상 또는 해당 종속 대상 중 하나를 통해 컴파일러가 IntelliSense에 필요한 모든 매개 변수, 특히 모든 참조를 받도록 해야 합니다.
"In-Process 컴파일러" 단원에 나열된 조건이 충족되어야 합니다.
솔루션 빌드
Visual Studio 내에서 솔루션 파일 및 프로젝트 빌드 순서는 Visual Studio 자체에서 제어합니다. 명령줄에서 msbuild.exe를 사용하여 솔루션을 빌드할 때 MSBuild에서는 솔루션 파일을 구문 분석하고 프로젝트 빌드 순서를 정합니다. 두 경우 모두 프로젝트는 종속성 순서에 따라 개별적으로 빌드되며 프로젝트 간 참조는 검색되지 않습니다. 이와 대조적으로 msbuild.exe를 사용하여 개별 프로젝트를 빌드하면 프로젝트 간 참조가 검색됩니다.
Visual Studio 내에서 빌드할 때 $(BuildingInsideVisualStudio) 속성은 true로 설정됩니다. 프로젝트 또는 .targets 파일에서 이 속성을 사용하여 빌드가 다르게 동작하도록 할 수 있습니다.
속성 및 항목 표시
Visual Studio에서는 특정 속성 이름과 값을 인식합니다. 예를 들어, 프로젝트의 다음 속성을 사용하면 Windows 응용 프로그램이 프로젝트 디자이너의 응용 프로그램 형식 상자에 나타납니다.
<OutputType>WinExe</OutputType>
속성 값은 프로젝트 디자이너에서 편집할 수 있으며 프로젝트 파일에 저장할 수 있습니다. 이러한 속성을 직접 편집하여 잘못된 값이 지정되면 프로젝트가 로드될 때 Visual Studio에서 경고를 표시하고 잘못된 값을 기본값으로 바꿉니다.
Visual Studio에서는 일부 속성의 기본값을 기억하고 있습니다. 이러한 속성은 기본값이 아닌 값을 가져야 프로젝트 파일에서 지속됩니다.
임의의 이름을 갖는 속성은 Visual Studio에 표시되지 않습니다. Visual Studio에서 임의의 속성을 수정하려면 XML 편집기에서 프로젝트 파일을 열고 직접 편집해야 합니다. 자세한 내용은 방법: 프로젝트 파일 편집을 참조하십시오.
임의의 항목 컬렉션 이름을 사용하여 프로젝트에 정의된 항목은 기본적으로 솔루션 탐색기에서 해당 프로젝트 노드 아래 표시됩니다. 항목이 표시되지 않도록 하려면 Visible 메타데이터를 false로 설정합니다. 예를 들어, 다음 항목은 빌드 프로세스에 사용되지만 솔루션 탐색기에는 표시되지 않습니다.
<ItemGroup>
<IntermediateFile Include="cache.temp">
<Visible>false</Visible>
</IntermediateFile>
</ItemGroup>
프로젝트로 가져온 파일에 선언한 항목은 기본적으로 표시되지 않습니다. 빌드 프로세스 동안 만들어진 항목은 솔루션 탐색기에 표시되지 않습니다.
항목 및 속성에 대한 조건
빌드하는 동안 모든 조건이 완전히 고려됩니다.
표시할 속성 값을 결정할 때 Visual Studio에서 구성에 종속적인 속성은 구성에 무관한 속성과 다르게 확인됩니다. 구성에 종속적인 속성인 경우 Visual Studio에서는 Configuration 및 Platform 속성을 적절하게 설정하고 MSBuild에 프로젝트를 다시 확인하도록 지시합니다. 구성에 무관한 속성인 경우 조건이 확인되는 방법이 확실하지 않습니다.
항목을 솔루션 탐색기에 표시해야 하는지 여부를 결정할 수 있도록 항목에 대한 조건식은 항상 무시됩니다.
디버깅
출력 어셈블리를 찾아서 시작하고 디버거를 연결하려면 Visual Studio에서 OutputPath, AssemblyName 및 OutputType 속성이 올바르게 정의되어 있어야 합니다. 빌드 프로세스에서 컴파일러를 통해 .pdb 파일을 생성하지 않으면 디버거가 연결되지 않습니다.
디자인 타임 대상 실행
Visual Studio에서는 프로젝트를 로드할 때 특정 이름의 대상을 실행하려고 시도합니다. 이러한 대상에는 Compile, ResolveAssemblyReferences, ResolveCOMReferences, GetFrameworkPaths, CopyRunEnvironmentFiles 등이 있습니다. Visual Studio에서는 이러한 대상을 실행하여 컴파일러가 IntelliSense를 제공하도록 초기화되거나, 디버거가 초기화되거나, 솔루션 탐색기에 표시된 참조가 확인될 수 있도록 합니다. 이러한 대상이 없어도 프로젝트를 제대로 로드하고 빌드할 수는 있지만 Visual Studio에서 디자인 타임 환경이 완전하게 작동하지 않습니다.
Visual Studio에서 프로젝트 파일 편집
MSBuild 프로젝트를 직접 편집해야 할 경우 Visual Studio XML 편집기에서 프로젝트 파일을 열 수 있습니다. 자세한 내용은 방법: 프로젝트 파일 편집을 참조하십시오.
IntelliSense 및 유효성 검사
XML 편집기를 사용하여 프로젝트 파일을 편집할 경우 MSBuild 스키마 파일에서 IntelliSense 및 유효성 검사를 실행합니다. 이러한 스키마 파일은 Visual Studio에 의해 [Visual Studio 설치 위치]\Xml\Schemas 폴더에 있는 스키마 캐시에 설치됩니다.
핵심 MSBuild 형식은 Microsoft.Build.Core.xsd에 정의되고 Visual Studio에서 사용되는 일반 형식은 Microsoft.Build.CommonTypes.xsd에 정의됩니다. 사용자 지정 항목 컬렉션 이름, 속성, 작업 등에 대해 IntelliSense 및 유효성 검사를 적용하도록 스키마를 사용자 지정하려면 Microsoft.Build.xsd를 편집하거나 CommonTypes 또는 핵심 스키마를 포함하는 스키마를 직접 만들면 됩니다. 스키마를 직접 만들 경우 속성 창을 사용하여 해당 스키마를 찾도록 XML 편집기에 지시해야 합니다.
로드된 프로젝트 파일 편집
Visual Studio에서는 프로젝트 파일과 프로젝트 파일이 가져온 파일의 내용을 캐시합니다. 로드된 프로젝트 파일을 편집할 경우 Visual Studio에서는 변경 내용이 적용되도록 프로젝트를 다시 로드하라는 메시지를 자동으로 표시합니다. 하지만 로드된 프로젝트에서 가져온 파일을 편집할 경우에는 다시 로드하라는 메시지가 표시되지 않으므로 변경 내용을 적용하려면 수동으로 프로젝트를 언로드한 후 다시 직접 로드해야 합니다.
출력 그룹
Microsoft.Common.targets에 정의된 몇 가지 대상의 이름은 OutputGroups 또는 OutputGroupDependencies로 끝납니다. Visual Studio에서는 이러한 대상을 호출하여 특정한 프로젝트 출력 목록을 얻습니다. 예를 들어, SatelliteDllsProjectOutputGroup 대상은 빌드에서 만드는 모든 위성 어셈블리 목록을 만듭니다. 이러한 출력 그룹은 게시, 배포 및 프로젝트 간 참조와 같은 기능에서 사용됩니다. 출력 그룹이 정의되지 않은 프로젝트는 Visual Studio에서 로드되고 빌드되지만 일부 기능은 제대로 작동하지 않을 수 있습니다.
참조 확인
참조 확인은 프로젝트 파일에 저장된 참조 항목을 사용하여 실제 어셈블리를 찾는 과정입니다. Visual Studio에서는 속성 창에 각 참조에 대한 자세한 속성을 표시하기 위해 참조 확인을 트리거해야 합니다. 다음 목록에서는 세 가지 참조 형식과 참조 확인 방법을 설명합니다.
어셈블리 참조:
프로젝트 시스템에서 잘 알려진 이름이 ResolveAssemblyReferences인 대상을 호출합니다. 이 대상은 항목 컬렉션 이름이 ReferencePath인 항목을 출력해야 합니다. 이러한 항목에는 각각 참조에 대한 전체 경로를 포함하는 항목 사양(항목의 Include 특성 값)이 있어야 합니다. 항목에는 다음과 같은 새 메타데이터 외에 전달된 입력 항목의 모든 메타데이터가 있어야 합니다.
CopyLocal: 어셈블리를 출력 폴더로 복사할지 여부를 true 또는 false로 설정하여 나타냅니다.
OriginalItemSpec: 참조의 원래 항목 사양이 포함되어 있습니다.
ResolvedFrom: .NET Framework 디렉터리에서 확인된 경우 "{TargetFrameworkDirectory}"로 설정됩니다.
COM 참조:
프로젝트 시스템에서 잘 알려진 이름이 ResolveCOMReferences인 대상을 호출합니다. 이 대상은 항목 컬렉션 이름이 ComReferenceWrappers인 항목을 출력해야 합니다. 이러한 항목에는 각각 COM 참조에 대해 Interop 어셈블리의 전체 경로를 포함하는 항목 사양이 있어야 합니다. 항목에는 전달된 입력 항목의 모든 메타데이터와 함께, 어셈블리를 출력 폴더로 복사할지 여부를 true 또는 false로 설정하여 나타내는 CopyLocal이라는 이름의 새 메타데이터가 있어야 합니다.
네이티브 참조
프로젝트 시스템에서 잘 알려진 이름이 ResolveNativeReferences인 대상을 호출합니다. 이 대상은 항목 컬렉션 이름이 NativeReferenceFile인 항목을 출력해야 합니다. 항목에는 전달된 입력 항목의 모든 메타데이터와 함께, 참조의 원래 항목 사양이 포함되어 있는 OriginalItemSpec이라는 새로운 메타데이터 부분이 있어야 합니다.