ISynchronousDataRetriever::LoadChangeData
Recupera dados de item para uma alteração.
HRESULT LoadChangeData(
ILoadChangeContext * pLoadChangeContext,
IUnknown ** ppUnkData);
Parâmetros
- pLoadChangeContext
[in] Metadados que descrevem a alteração para a qual os dados devem ser recuperados.
- ppUnkData
[out] Retorna os dados de item para a alteração especificada em pLoadChangeContext.
Valor de retorno
S_OK
Códigos de erro determinados pelo provedor
Comentários
O provedor de origem determina a interface de recuperação de dados implementada pelo objeto retornado em ppUnkData. O provedor de destino pode adquirir essa interface usando o método QueryInterface de ppUnkData.
Exemplo
O exemplo a seguir é uma implementação de LoadChangeData
que encontra a alteração especificada em um repositório de dados personalizado e retorna uma cópia desta.
STDMETHODIMP CItemStore::LoadChangeData(
ILoadChangeContext * pLoadChangeContext,
IUnknown ** ppUnkData)
{
HRESULT hr = E_UNEXPECTED;
if (NULL == pLoadChangeContext || NULL == ppUnkData)
{
hr = E_POINTER;
}
else
{
// Find the item in the data store, clone it, and return its IUnknown interface.
ISyncChange* pChange = NULL;
hr = pLoadChangeContext->GetSyncChange(&pChange);
if (SUCCEEDED(hr))
{
SYNC_GID gidItem;
DWORD cbID = sizeof(gidItem);
hr = pChange->GetRootItemId((BYTE*)&gidItem, &cbID);
if (SUCCEEDED(hr))
{
IXMLDOMNode* pNodeItem = NULL;
hr = FindItem(&gidItem, &pNodeItem);
if (SUCCEEDED(hr))
{
IXMLDOMNode* pNodeClone = NULL;
hr = pNodeItem->cloneNode(TRUE, &pNodeClone);
if (SUCCEEDED(hr))
{
hr = pNodeClone->QueryInterface(IID_IUnknown, (void**)ppUnkData);
pNodeClone->Release();
}
pNodeItem->Release();
}
}
pChange->Release();
}
}
return hr;
}