Commit b63e9a78 authored by Andrey Turkin's avatar Andrey Turkin Committed by Alexandre Julliard

shlwapi: Implement IConnectionPoint_SimpleInvoke.

parent f9a54ebc
...@@ -2856,17 +2856,61 @@ HRESULT WINAPI SHPackDispParams(LPVOID w, LPVOID x, LPVOID y, LPVOID z) ...@@ -2856,17 +2856,61 @@ HRESULT WINAPI SHPackDispParams(LPVOID w, LPVOID x, LPVOID y, LPVOID z)
} }
/************************************************************************* /*************************************************************************
* SHLWAPI_InvokeByIID
*
* This helper function calls IDispatch::Invoke for each sink
* which implements given iid or IDispatch.
*
*/
static HRESULT SHLWAPI_InvokeByIID(
IConnectionPoint* iCP,
REFIID iid,
DISPID dispId,
DISPPARAMS* dispParams)
{
IEnumConnections *enumerator;
CONNECTDATA rgcd;
HRESULT result = IConnectionPoint_EnumConnections(iCP, &enumerator);
if (FAILED(result))
return result;
while(IEnumConnections_Next(enumerator, 1, &rgcd, NULL)==S_OK)
{
IDispatch *dispIface;
if (SUCCEEDED(IUnknown_QueryInterface(rgcd.pUnk, iid, (LPVOID*)&dispIface)) ||
SUCCEEDED(IUnknown_QueryInterface(rgcd.pUnk, &IID_IDispatch, (LPVOID*)&dispIface)))
{
IDispatch_Invoke(dispIface, dispId, &IID_NULL, 0, DISPATCH_METHOD, dispParams, NULL, NULL, NULL);
IDispatch_Release(dispIface);
}
}
IEnumConnections_Release(enumerator);
return S_OK;
}
/*************************************************************************
* @ [SHLWAPI.284] * @ [SHLWAPI.284]
* *
* _IConnectionPoint_SimpleInvoke * IConnectionPoint_SimpleInvoke
*/ */
DWORD WINAPI IConnectionPoint_SimpleInvoke( HRESULT WINAPI IConnectionPoint_SimpleInvoke(
LPVOID x, IConnectionPoint* iCP,
LPVOID y, DISPID dispId,
LPVOID z) DISPPARAMS* dispParams)
{ {
FIXME("(%p %p %p) stub\n",x,y,z); IID iid;
return 0; HRESULT result;
TRACE("(%p)->(0x%x %p)\n",iCP,dispId,dispParams);
result = IConnectionPoint_GetConnectionInterface(iCP, &iid);
if (SUCCEEDED(result))
result = SHLWAPI_InvokeByIID(iCP, &iid, dispId, dispParams);
return result;
} }
/************************************************************************* /*************************************************************************
......
...@@ -281,7 +281,7 @@ ...@@ -281,7 +281,7 @@
281 stdcall -noname SHPackDispParamsV(ptr ptr ptr ptr) 281 stdcall -noname SHPackDispParamsV(ptr ptr ptr ptr)
282 stdcall -noname SHPackDispParams(ptr ptr ptr ptr) 282 stdcall -noname SHPackDispParams(ptr ptr ptr ptr)
283 stub -noname IConnectionPoint_InvokeWithCancel 283 stub -noname IConnectionPoint_InvokeWithCancel
284 stdcall -noname IConnectionPoint_SimpleInvoke(ptr ptr ptr) 284 stdcall -noname IConnectionPoint_SimpleInvoke(ptr long ptr)
285 stdcall -noname IConnectionPoint_OnChanged(ptr long) 285 stdcall -noname IConnectionPoint_OnChanged(ptr long)
286 stub -noname IUnknown_CPContainerInvokeParam 286 stub -noname IUnknown_CPContainerInvokeParam
287 stdcall -noname IUnknown_CPContainerOnChanged(ptr long) 287 stdcall -noname IUnknown_CPContainerOnChanged(ptr long)
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment