프로젝트 하위 형식은 나중에 사용하기 위해 하위 형식별 데이터를 프로젝트 파일에 유지해야 할 수 있습니다. 프로젝트 하위 형식은 프로젝트 파일 지속성을 사용하여 다음 요구 사항을 충족합니다.
프로젝트 빌드의 일부로 사용되는 데이터를 유지합니다. (Microsoft 빌드 엔진에 대한 자세한 내용은 MSBuild를 참조하세요.) 빌드 관련 정보는 다음 중 하나일 수 있습니다.
구성 독립적인 데이터입니다. 즉, 비어 있거나 누락된 조건이 있는 MSBuild 요소에 저장된 데이터입니다.
구성 종속 데이터입니다. 즉, 특정 프로젝트 구성에 대해 조건부로 제공되는 MSBuild 요소에 저장된 데이터입니다. 다음은 그 예입니다.
<PropertyGroup Condition=" '$(Configuration)' == 'Debug' ">
빌드와 관련이 없는 데이터를 유지합니다. 이 데이터는 XML 스키마에 대해 유효성이 검사되지 않은 자유 형식 XML로 표현할 수 있습니다.
구성 독립적 데이터입니다.
구성 종속 데이터입니다.
빌드 관련 정보를 유지하기
프로젝트 빌드에 유용한 데이터의 지속성은 MSBuild를 통해 처리됩니다. MSBuild 시스템은 빌드 관련 정보의 마스터 테이블을 유지 관리합니다. 프로젝트 하위 형식은 이 데이터에 액세스하여 속성 값을 가져와서 설정하는 작업을 담당합니다. 프로젝트 하위 형식은 유지할 속성을 추가하고 유지되지 않도록 속성을 제거하여 빌드 관련 데이터 테이블을 보강할 수도 있습니다.
MSBuild 데이터를 수정하기 위해 프로젝트 하위 형식은 기본 프로젝트 시스템에서 MSBuild 속성 개체를 검색 IVsBuildPropertyStorage하는 작업을 담당합니다.
IVsBuildPropertyStorage 은 핵심 프로젝트 시스템에 구현된 인터페이스이며, 프로젝트 하위 집계 형식은 QueryInterface을 실행하여 이를 쿼리합니다.
다음 절차에서는 .를 사용하여 IVsBuildPropertyStorage속성을 제거하는 단계를 간략하게 설명합니다.
MSBuild 프로젝트 파일에서 속성을 제거하려면
IVsBuildPropertyStorage 프로젝트의 하위 형식에
QueryInterface를 호출합니다.RemoveProperty을(를) 호출할 때, 제거할 속성으로
pszPropName을(를) 설정하십시오.
빌드가 아닌 관련 정보 유지
빌드에 중요하지 않은 프로젝트 파일의 데이터 지속성은 다음을 통해 IPersistXMLFragment처리됩니다.
IPersistXMLFragment를 주 project subtype aggregator 개체, project subtype project configuration 개체 또는 두 개체 모두에 구현할 수 있습니다.
다음 포인트는 빌드가 아닌 관련 정보의 지속성과 관련된 주요 개념을 간략하게 설명합니다.
기본 프로젝트는 기본 프로젝트 하위 유형(즉, 가장 바깥쪽 프로젝트 하위 형식) 집계 개체를 호출하여 구성 독립적 데이터를 로드하고 저장하며, 프로젝트 하위 형식 프로젝트 구성 개체를 호출하여 구성 종속 데이터를 로드하거나 저장합니다.
기본 프로젝트는 프로젝트 하위 형식 집계의 IPersistXMLFragment 각 수준에 대해 여러 번 메서드를 호출하고 각 수준에 대한 GUID를 전달합니다.
기본 프로젝트는 특정 프로젝트 하위 형식에 전용인 XML 조각을 전달하거나 수신하며 집계 수준 간에 상태를 유지하는 방법으로 이 메커니즘을 사용합니다.
기본 프로젝트는 GUID를 전달하는 가장 바깥쪽 프로젝트 하위 형식의 IPersistXMLFragment구현을 호출합니다. GUID가 가장 바깥쪽 프로젝트 하위 형식에 속하는 경우 호출 자체를 처리합니다. 그렇지 않으면 GUID에 해당하는 프로젝트 하위 형식이 발견될 때까지 내부 프로젝트 하위 형식에 대한 호출을 위임합니다.
또한 프로젝트 하위 형식은 내부 프로젝트 하위 형식에 대한 호출을 위임하기 전이나 후에 XML 조각을 수정할 수 있습니다. 다음 예제에서는 프로젝트 하위 형식과 관련된 속성을 포함하는 파일의 이름이 해당 프로젝트 하위 형식으로 전달되는 프로젝트 파일에서 발췌한 항목을 보여 줍니다.
<ProjectExtensions> <VisualStudio> <FlavorProperties GUID="{<FlavorGUID>}"> <FlavorProject TestFileFolder="TestFile" /> </FlavorProperties> </VisualStudio> </ProjectExtensions>