IDiaEnumInputAssemblyFiles
Enumere los archivos de ensamblado de entrada enumerados en el origen de datos.
Sintaxis
IDiaEnumInputAssemblyFiles : IUnknown
Métodos en orden de Vtable
En la tabla siguiente se muestran los métodos de IDiaEnumInputAssemblyFiles
.
Método | Descripción |
---|---|
IDiaEnumInputAssemblyFiles::get__NewEnum | Recupera la versión de la interfaz IEnumVARIANT de este enumerador. |
IDiaEnumInputAssemblyFiles::get_Count | Recupera el número de archivos de ensamblado de entrada. |
IDiaEnumInputAssemblyFiles::Item | Recupera un archivo de ensamblado de entrada mediante un índice. |
IDiaEnumInputAssemblyFiles::Next | Recupera un número especificado de archivos de ensamblado de entrada en la secuencia de enumeración. |
IDiaEnumInputAssemblyFiles::Skip | Omite un número especificado de archivos de ensamblado de entrada en una secuencia de enumeración. |
IDiaEnumInputAssemblyFiles::Reset | Restablece una secuencia de enumeración al principio. |
IDiaEnumInputAssemblyFiles::Clone | Crea un enumerador que contiene el mismo estado de enumeración que el enumerador actual. |
Comentarios
Notas para autores de la llamada
Esta interfaz se obtiene llamando al método IDiaSession::findInputAssemblyFiles con el nombre de un archivo de origen específico o llamando al método IDiaSession::getEnumTables con el identificador único global (GUID) de la IDiaEnumInputAssemblyFiles
interfaz.
Ejemplo
En este ejemplo se muestra cómo obtener (la función GetEnumInputAssemblyFiles
) y usar (la función DumpAllInputAssemblyFiles
) la interfaz IDiaEnumInputAssemblyFiles
. Consulte la IDiaPropertyStorage
interfaz para obtener una implementación de la PrintPropertyStorage
función. Para obtener una salida alternativa, consulte la IDiaInputAssemblyFile
interfaz .
IDiaEnumInputAssemblyFiles* GetEnumInputAssemblyInputFiles(IDiaSession *pSession)
{
IDiaEnumInputAssemblyFiles* pUnknown = NULL;
REFIID iid = __uuidof(IDiaEnumInputAssemblyFiles);
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 DumpAllInputAssemblyFiles( IDiaSession* pSession)
{
IDiaEnumInputAssemblyFiles* pEnumInpAsmFiles;
pEnumInpAsmFiles = GetEnumInputAssemblyInputFiles(pSession);
if (pEnumInpAsmFiles != NULL)
{
IDiaInputAssemblyFile* pInpAsmFile;
ULONG celt = 0;
while(pEnumInpAsmFiles->Next(1, &pInpAsmFile, &celt) == S_OK &&
celt == 1)
{
IDiaPropertyStorage *pPropertyStorage;
if (pInpAsmFile->QueryInterface(__uuidof(IDiaPropertyStorage),
(void **)&pPropertyStorage) == S_OK)
{
PrintPropertyStorage(pPropertyStorage);
pPropertyStorage->Release();
}
pInpAsmFile->Release();
}
pEnumInpAsmFiles->Release();
}
}
Requisitos
Encabezado: Dia2.h
Biblioteca: diaguids.lib
DLL: msdia140.dll