Nota
L'accesso a questa pagina richiede l'autorizzazione. È possibile provare ad accedere o modificare le directory.
L'accesso a questa pagina richiede l'autorizzazione. È possibile provare a modificare le directory.
Enumerare vari database di origine inseriti contenuti nell'origine dati.
IDiaEnumInjectedSources : IUnknown
Metodi nell'ordine di Vtable
Nella tabella seguente sono elencati i metodi di IDiaEnumInjectedSources.
Metodo |
Descrizione |
|---|---|
recupera interfaccia di IEnumVARIANT versione di questo enumeratore. |
|
Recupera il numero di database di origine inseriti. |
|
Recupera un database di origine inserito mediante un indice. |
|
Recupera un numero specificato di database di origine inseriti nella sequenza di enumerazione. |
|
Ignora un numero specificato di database di origine inseriti in una sequenza di enumerazione. |
|
Reimposta una sequenza di enumerazione all'inizio. |
|
Crea un enumeratore che contiene lo stesso stato di enumerazione dell'enumeratore corrente. |
Note
Note per i chiamanti
Questa interfaccia è ottenuto chiamando IDiaSession::findInjectedSource metodo con il nome di un file di origine specifico o chiamando IDiaSession::getEnumTables metodo con il GUID di IDiaEnumInjectedSources interfaccia.
Esempio
In questo esempio viene illustrato come verificare ( GetEnumInjectedSources la funzione) e utilizza ( DumpAllInjectedSources funzione) IDiaEnumInjectedSources interfaccia.vedere IDiaPropertyStorage interfaccia per l'implementazione di PrintPropertyStorage funzione.per un output di alternativa, vedere IDiaInjectedSource interfaccia.
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();
}
}
Requisiti
intestazione: Dia2.h
raccolta: diaguids.lib
DLL: msdia80.dll
Vedere anche
Riferimenti
IDiaSession::findInjectedSource