IDiaEnumInputAssemblyFiles
Auflisten der eingabeassembly files listed in the data source.
Syntax
IDiaEnumInputAssemblyFiles : IUnknown
Methoden in Vtable-Reihenfolge
In der folgenden Tabelle sind die Methoden von IDiaEnumInputAssemblyFiles
aufgeführt.
Methode | Beschreibung |
---|---|
IDiaEnumInputAssemblyFiles::get__NewEnum | Hiermit wird die Version der IEnumVARIANT-Schnittstelle dieses Enumerators abgerufen. |
IDiaEnumInputAssemblyFiles::get_Count | Ruft die Anzahl der Eingabeassemblydateien ab. |
IDiaEnumInputAssemblyFiles::Item | Ruft eine Eingabeassemblydatei mithilfe eines Indexes ab. |
IDiaEnumInputAssemblyFiles::Next | Ruft eine angegebene Anzahl von Eingabeassemblydateien in der Enumerationssequenz ab. |
IDiaEnumInputAssemblyFiles::Skip | Überspringt eine angegebene Anzahl von Eingabeassemblydateien in einer Enumerationssequenz. |
IDiaEnumInputAssemblyFiles::Reset | Setzt eine Enumerationsfolge auf den Anfang zurück. |
IDiaEnumInputAssemblyFiles::Clone | Erstellt einen Enumerator mit demselben Enumerationszustand wie der aktuelle Enumerator. |
Bemerkungen
Hinweise für Aufrufer
Diese Schnittstelle wird durch Aufrufen der IDiaSession::findInputAssemblyFiles-Methode mit dem Namen einer bestimmten Quelldatei oder durch Aufrufen der IDiaSession::getEnumTables-Methode mit der GUID (Globally Unique Identifier) der IDiaEnumInputAssemblyFiles
Schnittstelle abgerufen.
Beispiel
In diesem Beispiel wird gezeigt, wie Sie die IDiaEnumInputAssemblyFiles
-Schnittstelle abrufen (GetEnumInputAssemblyFiles
-Funktion) und verwenden (DumpAllInputAssemblyFiles
-Funktion). Eine Implementierung der PrintPropertyStorage
Funktion finden Sie in der IDiaPropertyStorage
Schnittstelle. Eine alternative Ausgabe finden Sie in der IDiaInputAssemblyFile
Schnittstelle.
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();
}
}
Anforderungen
Header: Dia2.h
Bibliothek: diaguids.lib
DLL: msdia140.dll