Freigeben über


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

Siehe auch