IDiaEnumInputAssemblyFiles
Enumere os arquivos de assembly de entrada listados na fonte de dados.
Sintaxe
IDiaEnumInputAssemblyFiles : IUnknown
Métodos na ordem VTable
A tabela a seguir mostra os métodos de IDiaEnumInputAssemblyFiles
.
Método | Descrição |
---|---|
IDiaEnumInputAssemblyFiles::get__NewEnum | Recupera a versão da Interface IEnumVARIANT deste enumerador. |
IDiaEnumInputAssemblyFiles::get_Count | Recupera o número de arquivos de assembly de entrada. |
IDiaEnumInputAssemblyFiles::Item | Recupera um arquivo de assembly de entrada por meio de um índice. |
IDiaEnumInputAssemblyFiles::Next | Recupera um número especificado de arquivos de assembly de entrada na sequência de enumeração. |
IDiaEnumInputAssemblyFiles::Skip | Ignora um número especificado de arquivos de assembly de entrada em uma sequência de enumeração. |
IDiaEnumInputAssemblyFiles::Redefinir | Redefine uma sequência de enumeração para o início. |
IDiaEnumInputAssemblyFiles::Clone | Cria um enumerador que contém o mesmo estado de enumeração que o enumerador atual. |
Comentários
Observações para chamadores
Essa interface é obtida chamando o método IDiaSession::findInputAssemblyFiles com o nome de um arquivo de origem específico ou chamando o método IDiaSession::getEnumTables com o identificador global exclusivo (GUID) da IDiaEnumInputAssemblyFiles
interface.
Exemplo
Esse exemplo mostra como obter (a função GetEnumInputAssemblyFiles
) e usar (a função DumpAllInputAssemblyFiles
) da interface IDiaEnumInputAssemblyFiles
. Consulte a IDiaPropertyStorage
interface para uma implementação da PrintPropertyStorage
função. Para obter uma saída alternativa, consulte a IDiaInputAssemblyFile
interface.
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
Cabeçalho: Dia2.h
Biblioteca: diaguids.lib
DLL: msdia140.dll