IDiaEnumInputAssemblyFiles
Enumerare i file di assembly di input elencati nell'origine dati.
Sintassi
IDiaEnumInputAssemblyFiles : IUnknown
Metodi nell'ordine Vtable
Nella tabella seguente vengono illustrati i metodi di IDiaEnumInputAssemblyFiles
.
metodo | Descrizione |
---|---|
IDiaEnumInputAssemblyFiles::get__NewEnum | Recupera la versione dell'interfaccia IEnumVARIANT di questo enumeratore. |
IDiaEnumInputAssemblyFiles::get_Count | Recupera il numero di file di assembly di input. |
IDiaEnumInputAssemblyFiles::Item | Recupera un file di assembly di input tramite un indice. |
IDiaEnumInputAssemblyFiles::Next | Recupera un numero specificato di file di assembly di input nella sequenza di enumerazione. |
IDiaEnumInputAssemblyFiles::Skip | Ignora un numero specificato di file di assembly di input in una sequenza di enumerazione. |
IDiaEnumInputAssemblyFiles::Reset | Reimposta una sequenza di enumerazione all'inizio. |
IDiaEnumInputAssemblyFiles::Clone | Crea un enumeratore che contiene lo stesso stato di enumerazione dell'enumeratore corrente. |
Osservazioni:
Note per i chiamanti
Questa interfaccia viene ottenuta chiamando il metodo IDiaSession::findInputAssemblyFiles con il nome di un file di origine specifico o chiamando il metodo IDiaSession::getEnumTables con l'identificatore univoco globale (GUID) dell'interfaccia IDiaEnumInputAssemblyFiles
.
Esempio
In questo esempio viene illustrato come ottenere (la GetEnumInputAssemblyFiles
funzione) e usare (la funzione) l'interfaccia DumpAllInputAssemblyFiles
IDiaEnumInputAssemblyFiles
. Vedere l'interfaccia IDiaPropertyStorage
per un'implementazione della PrintPropertyStorage
funzione. Per un output alternativo, vedere l'interfaccia IDiaInputAssemblyFile
.
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();
}
}
Requisiti
Intestazione: Dia2.h
Libreria: diaguids.lib
DLL: msdia140.dll