IDiaEnumSectionContribs
데이터 소스에 포함된 다양한 섹션 기여를 열거합니다.
구문
IDiaEnumSectionContribs : IUnknown
Vtable 순서의 메서드
다음 표에서는 IDiaEnumSectionContribs
메서드를 보여 줍니다.
메서드 | 설명 |
---|---|
IDiaEnumSectionContribs::get__NewEnum | 이 열거자의 IEnumVARIANT Interface 버전을 검색합니다. |
IDiaEnumSectionContribs::get_Count | 섹션 기여 수를 검색합니다. |
IDiaEnumSectionContribs::Item | 인덱스를 사용하여 섹션 기여를 검색합니다. |
IDiaEnumSectionContribs::Next | 열거형 시퀀스에서 지정된 수의 섹션 기여를 검색합니다. |
IDiaEnumSectionContribs::Skip | 열거형 시퀀스에서 지정된 수의 섹션 기여를 건너뜁니다. |
IDiaEnumSectionContribs::Reset | 열거형 시퀀스를 초기화합니다. |
IDiaEnumSectionContribs::Clone | 현재 열거자와 동일한 열거 상태를 포함하는 열거자를 만듭니다. |
설명
호출자 참고 사항
IDiaSession:: getEnumTables 메서드에서 이 인터페이스를 가져옵니다. 자세한 내용은 예제를 참조하세요.
예시
이 예제에서는 (GetEnumSectionContribs
함수)를 가져오고 (ShowSectionContribs
함수) IDiaEnumSectionContribs
인터페이스를 사용하는 방법을 보여 줍니다. 섹션 기여 사용에 관한 자세한 예제는 IDiaSectionContrib 인터페이스를 참조하세요.
IDiaEnumSectionContribs* GetEnumSectionContribs(IDiaSession *pSession)
{
IDiaEnumSectionContribs* pUnknown = NULL;
REFIID iid = __uuidof(IDiaEnumSectionContribs);
IDiaEnumTables* pEnumTables = NULL;
IDiaTable* pTable = NULL;
ULONG celt = 0;
if (pSession->getEnumTables(&pEnumTables) != S_OK)
{
wprintf(L"ERROR - GetTable() getEnumTables\n");
return NULL;
}
while (pEnumTables->Next(1, &pTable, &celt) == S_OK && celt == 1)
{
// There is only one table that matches the given iid
HRESULT hr = pTable->QueryInterface(iid, (void**)&pUnknown);
pTable->Release();
if (hr == S_OK)
{
break;
}
}
pEnumTables->Release();
return pUnknown;
}
void ShowSectionContribs(IDiaSession *pSession)
{
IDiaEnumSectionContribs* pEnumSectionContribs;
pEnumSectionContribs = GetEnumSectionContribs(pSession);
if (pSectionContrib != NULL)
{
IDiaSectionContrib* pSectionContrib;
ULONG celt = 0;
while(pEnumSectionContribs->Next(1, &pSectionContrib, &celt) == S_OK &&
celt == 1)
{
PrintSectionContrib(pSectionContrib, pSession);
pSectionContrib->Release();
}
pSectionContrib->Release();
}
}
요구 사항
헤더: Dia2.h
라이브러리: diaguids.lib
DLL: msdia80.dll