다음을 통해 공유


IDiaDataSource

디버깅 기호의 소스에 대한 액세스를 시작합니다.

구문

IDiaDataSource : IUnknown

Vtable 순서의 메서드

다음 표에서는 IDiaDataSource 메서드를 보여 줍니다.

메서드 설명
IDiaDataSource::get_lastError 마지막 로드 오류의 파일 이름을 검색합니다.
IDiaDataSource::loadDataFromPdb 프로그램 데이터베이스(.pdb) 파일을 디버그 데이터 소스를 열고 준비합니다.
IDiaDataSource::loadAndValidateDataFromPdb 프로그램 데이터베이스(.pdb) 파일을 열고, 해당 파일이 제공된 시그니처 정보와 일치하는지 확인하고, .pdb 파일을 디버그 데이터 소스로 준비합니다.
IDiaDataSource::loadDataForExe .exe/.dll 파일과 연결된 디버그 데이터를 열고 준비합니다.
IDiaDataSource::loadDataFromIStream 메모리 내 데이터 스트림을 통해 액세스되는 프로그램 데이터베이스(.pdb) 파일에 저장된 디버그 데이터를 준비합니다.
IDiaDataSource::openSession 기호를 쿼리하기 위한 세션을 엽니다.
IDiaDataSource::loadDataFromCodeViewInfo 제공된 CodeView 정보와 연결된 디버그 데이터를 열고 준비합니다.
IDiaDataSource::loadDataFromMiscInfo 제공된 디버그 정보와 연결된 디버그 데이터를 열고 준비합니다.

설명

IDiaDataSource 인터페이스의 로드 메서드 중 하나를 호출하면 기호 소스가 열립니다. IDiaDataSource::openSession 메서드를 성공적으로 호출하면 데이터 소스 쿼리를 지원하는 IDiaSession 인터페이스가 반환됩니다. 로드 메서드가 파일 관련 오류를 반환하는 경우 IDiaDataSource::get_lastError 메서드 반환 값에는 오류와 연결된 파일 이름이 포함됩니다.

호출자 참고 사항

이 인터페이스를 가져오려면 클래스 식별자 CLSID_DiaSource와 인터페이스 ID IID_IDiaDataSource를 사용하여 CoCreateInstance 함수를 호출합니다. 이 예제에서는 이 인터페이스를 가져오는 방법을 보여 줍니다.

예시


      IDiaDataSource* pSource;
HRESULT hr = CoCreateInstance(CLSID_DiaSource,
                              NULL,
                              CLSCTX_INPROC_SERVER,
                              IID_IDiaDataSource,
                              (void**) &pSource);
if (FAILED(hr))
{
    // Report error and exit
}

요구 사항

헤더: Dia2.h

라이브러리: diaguids.lib

DLL: msdia140.dll

참고 항목