Método IADsContainer::get__NewEnum (iads.h)
O método IADsContainer::get__NewEnum Recupera um objeto enumerador para o contêiner. O objeto enumerador implementa a interface IEnumVARIANT para enumerar os filhos do objeto contêiner.
Sintaxe
HRESULT get__NewEnum(
[out] IUnknown **retval
);
Parâmetros
[out] retval
Ponteiro para um ponteiro IUnknown que recebe o objeto enumerador. O chamador deve liberar essa interface quando ela não for mais necessária.
Valor retornado
Esse método dá suporte aos valores retornados padrão, incluindo S_OK para uma operação bem-sucedida. Para obter mais informações sobre códigos de erro, consulte Códigos de erro ADSI.
Comentários
Há dois caracteres de sublinhado ("__") no nome da função entre "get" e "NewEnum".
No Visual Basic, use o ForEach... instrução para invocar o método IADsContainer::get__NewEnum implicitamente.
Em C/C++, use as funções auxiliares ADsBuildEnumerator, ADsEnumerateNext e AdsFreeEnumerator .
Exemplos
O exemplo de código a seguir mostra como enumerar objetos filho em um contêiner.
Dim cont As IADsContainer
On Error GoTo Cleanup
Set cont = GetObject("LDAP://OU=Sales,DC=Fabrikam,DC=com")
For Each obj In cont
Debug.Print obj.Name
Next
Cleanup:
If(Err.Number<>0) Then
MsgBox("An error has occurred. " & Err.Number)
End If
Set cont = Nothing
O exemplo de código a seguir mostra como enumerar o objeto contido em um contêiner.
IEnumVARIANT *pEnum = NULL;
IADsContainer *pCont = NULL;
LPUNKNOWN pUnk = NULL;
VARIANT var;
IDispatch *pDisp = NULL;
ulong lFetch;
IADs *pADs = NULL;
// In this sample, skip error checking.
ADsGetObject(L"LDAP://OU=Sales,DC=Fabrikam,DC=COM",
IID_IADsContainer, (void**) &pCont);
pCont->get__NewEnum(&pUnk);
pCont->Release();
pUnk->QueryInterface(IID_IEnumVARIANT, (void**) &pEnum);
pUnk->Release();
// Enumerate.
HRESULT hr = pEnum->Next(1, &var, &lFetch);
while(SUCCEEDED(hr) && lFetch > 0)
{
if (lFetch == 1)
{
BSTR bstr;
pDisp = V_DISPATCH(&var);
pDisp->QueryInterface(IID_IADs, (void**)&pADs);
pDisp->Release();
hr = pADs->get_Name(&bstr);
if(SUCCEEDED(hr))
{
SysFreeString(bstr);
}
pADs->Release();
}
VariantClear(&var);
hr = pEnum->Next(1, &var, &lFetch);
};
pEnum->Release();
Requisitos
Cliente mínimo com suporte | Windows Vista |
Servidor mínimo com suporte | Windows Server 2008 |
Plataforma de Destino | Windows |
Cabeçalho | iads.h |
DLL | Activeds.dll |