Commit f658adff authored by Rob Shearman's avatar Rob Shearman Committed by Alexandre Julliard

ole32: Fix the detection of when we need an additional QueryInterface in CoUnmarshalInterface.

parent fa64950e
...@@ -1671,16 +1671,13 @@ HRESULT WINAPI CoUnmarshalInterface(IStream *pStream, REFIID riid, LPVOID *ppv) ...@@ -1671,16 +1671,13 @@ HRESULT WINAPI CoUnmarshalInterface(IStream *pStream, REFIID riid, LPVOID *ppv)
if (hr) if (hr)
ERR("IMarshal::UnmarshalInterface failed, 0x%08x\n", hr); ERR("IMarshal::UnmarshalInterface failed, 0x%08x\n", hr);
/* IID_NULL means use the interface ID of the marshaled object */
if (!IsEqualIID(riid, &IID_NULL))
iid = *riid;
if (hr == S_OK) if (hr == S_OK)
{ {
if (!IsEqualIID(riid, &iid)) /* IID_NULL means use the interface ID of the marshaled object */
if (!IsEqualIID(riid, &IID_NULL) && !IsEqualIID(riid, &iid))
{ {
TRACE("requested interface != marshalled interface, additional QI needed\n"); TRACE("requested interface != marshalled interface, additional QI needed\n");
hr = IUnknown_QueryInterface(object, &iid, ppv); hr = IUnknown_QueryInterface(object, riid, ppv);
if (hr) if (hr)
ERR("Couldn't query for interface %s, hr = 0x%08x\n", ERR("Couldn't query for interface %s, hr = 0x%08x\n",
debugstr_guid(riid), hr); debugstr_guid(riid), hr);
......
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