Freigeben über


IDiaEnumInjectedSources

Listen Sie die verschiedenen eingefügten Quellen aufgeführt, die in der Datenquelle enthalten sind.

IDiaEnumInjectedSources : IUnknown

Methoden in die Vtable-Reihenfolge

In der folgenden Tabelle werden die Methoden von IDiaEnumInjectedSourcesan.

Methode

Beschreibung

IDiaEnumInjectedSources::get__NewEnum

Ruft die IEnumVARIANT Interface-Version dieses Enumerators ab.

IDiaEnumInjectedSources::get_Count

Ruft die Anzahl der eingefügten Quellen ab.

IDiaEnumInjectedSources::Item

Ruft eine eingefügte Quelle mithilfe eines Indexes ab.

IDiaEnumInjectedSources::Next

Ruft eine angegebene Anzahl eingefügte Quellen in der Enumerationsfolge ab.

IDiaEnumInjectedSources::Skip

Überspringt eine angegebene Anzahl eingefügte Quellen in der Enumerationsfolge.

IDiaEnumInjectedSources::Reset

Setzt die Enumerationsfolge auf den Anfang zurück.

IDiaEnumInjectedSources::Clone

Erstellt einen Enumerator, der den gleichen Enumerationszustand wie der aktuelle Enumerator enthält.

Hinweise

Hinweise für Aufrufer

Diese Schnittstelle wird abgerufen, indem die IDiaSession::findInjectedSource-Methode mit dem Namen einer bestimmten Quelldatei aufgerufen wird oder indem die IDiaSession::getEnumTables-Methode mit dem IDiaEnumInjectedSources GUID der Schnittstelle aufruft.

Beispiel

Dieses Beispiel zeigt, wie die GetEnumInjectedSources erhält (Funktion) und ( DumpAllInjectedSources die Funktion) IDiaEnumInjectedSources-Schnittstelle verwendet.Zeigen Sie die IDiaPropertyStorage-Schnittstelle für eine Implementierung PrintPropertyStorage zu arbeiten.Bei einer Ausgabe Alternativen finden Sie in der IDiaInjectedSource-Schnittstelle.

 
IDiaEnumInjectedSources* GetEnumInjectedSources(IDiaSession *pSession)
{
    IDiaEnumInjectedSources* pUnknown    = NULL;
    REFIID                   iid         = __uuidof(IDiaEnumInjectedSources);
    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 DumpAllInjectedSources( IDiaSession* pSession)
{
    IDiaEnumInjectedSources* pEnumInjSources;

    pEnumInjSources = GetEnumInjectedSources(pSession);
    if (pEnumInjSources != NULL)
    {
        IDiaInjectedSource* pInjSource;
        ULONG celt = 0;

        while(pEnumInjSources->Next(1, &pInjSource, &celt) == S_OK &&
              celt == 1)
        {
            IDiaPropertyStorage *pPropertyStorage;
            if (pInjSource->QueryInterface(__uuidof(IDiaPropertyStorage),
                                           (void **)&pPropertyStorage) == S_OK)
            {
                PrintPropertyStorage(pPropertyStorage);
                pPropertyStorage->Release();
            }
            pInjSource->Release();
        }
        pEnumInjSources->Release();
    }
}

Anforderungen

Header: Dia2.h

Bibliothek: diaguids.lib

DLLs: msdia80.dll

Siehe auch

Referenz

IDiaSession::findInjectedSource

IDiaSession::getEnumTables

IDiaPropertyStorage

IDiaInjectedSource

Weitere Ressourcen

Schnittstellen (Debug Interface Access SDK)