Share via


IDiaEnumInjectedSources

Enumere los distintos códigos fuentes insertados contenidos en el origen de datos.

Sintaxis

IDiaEnumInjectedSources : IUnknown

Métodos en orden de Vtable

En la tabla siguiente se muestran los métodos de IDiaEnumInjectedSources.

Método Descripción
IDiaEnumInjectedSources::get__NewEnum Recupera la versión de la interfaz IEnumVARIANT de este enumerador.
IDiaEnumInjectedSources::get_Count Recupera el número de códigos fuente insertados.
IDiaEnumInjectedSources::Item Recupera un código fuente insertado mediante un índice.
IDiaEnumInjectedSources::Next Omite un número especificado de códigos fuente insertados en una secuencia de enumeración.
IDiaEnumInjectedSources::Skip Omite un número especificado de códigos fuente insertados en una secuencia de enumeración.
IDiaEnumInjectedSources::Reset Restablece una secuencia de enumeración al principio.
IDiaEnumInjectedSources::Clone Crea un enumerador que contiene el mismo estado de enumeración que el enumerador actual.

Comentarios

Notas para autores de la llamada

Esta interfaz se obtiene llamando al método IDiaSession::findInjectedSource con el nombre de un archivo de origen específico o llamando al método IDiaSession::getEnumTables con el GUID de la interfaz IDiaEnumInjectedSources.

Ejemplo

En este ejemplo se muestra cómo obtener (la función GetEnumInjectedSources) y usar (la función DumpAllInjectedSources) la interfaz IDiaEnumInjectedSources. Consulte la interfaz IDiaPropertyStorage para ver una implementación de la función PrintPropertyStorage. Para obtener una salida alternativa, consulte la interfaz IDiaInjectedSource.


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();
    }
}

Requisitos

Encabezado: Dia2.h

Biblioteca: diaguids.lib

DLL: msdia80.dll

Vea también