Commit ba4b88bc authored by Nikolay Sivov's avatar Nikolay Sivov Committed by Alexandre Julliard

ole32: Cleanup IMultiQI interface of proxy manager.

parent 0b5c0855
...@@ -55,7 +55,7 @@ extern const CLSID CLSID_DfMarshal; ...@@ -55,7 +55,7 @@ extern const CLSID CLSID_DfMarshal;
/* imported object / proxy manager */ /* imported object / proxy manager */
struct proxy_manager struct proxy_manager
{ {
const IMultiQIVtbl *lpVtbl; IMultiQI IMultiQI_iface;
const IMarshalVtbl *lpVtblMarshal; const IMarshalVtbl *lpVtblMarshal;
const IClientSecurityVtbl *lpVtblCliSec; const IClientSecurityVtbl *lpVtblCliSec;
struct apartment *parent; /* owning apartment (RO) */ struct apartment *parent; /* owning apartment (RO) */
...@@ -385,19 +385,19 @@ static HRESULT WINAPI StdMarshalImpl_DisconnectObject(LPMARSHAL iface, DWORD dwR ...@@ -385,19 +385,19 @@ static HRESULT WINAPI StdMarshalImpl_DisconnectObject(LPMARSHAL iface, DWORD dwR
static HRESULT WINAPI Proxy_QueryInterface(IMarshal *iface, REFIID riid, void **ppvObject) static HRESULT WINAPI Proxy_QueryInterface(IMarshal *iface, REFIID riid, void **ppvObject)
{ {
struct proxy_manager *This = impl_from_IMarshal( iface ); struct proxy_manager *This = impl_from_IMarshal( iface );
return IMultiQI_QueryInterface((IMultiQI *)&This->lpVtbl, riid, ppvObject); return IMultiQI_QueryInterface(&This->IMultiQI_iface, riid, ppvObject);
} }
static ULONG WINAPI Proxy_AddRef(IMarshal *iface) static ULONG WINAPI Proxy_AddRef(IMarshal *iface)
{ {
struct proxy_manager *This = impl_from_IMarshal( iface ); struct proxy_manager *This = impl_from_IMarshal( iface );
return IMultiQI_AddRef((IMultiQI *)&This->lpVtbl); return IMultiQI_AddRef(&This->IMultiQI_iface);
} }
static ULONG WINAPI Proxy_Release(IMarshal *iface) static ULONG WINAPI Proxy_Release(IMarshal *iface)
{ {
struct proxy_manager *This = impl_from_IMarshal( iface ); struct proxy_manager *This = impl_from_IMarshal( iface );
return IMultiQI_Release((IMultiQI *)&This->lpVtbl); return IMultiQI_Release(&This->IMultiQI_iface);
} }
static HRESULT WINAPI Proxy_MarshalInterface( static HRESULT WINAPI Proxy_MarshalInterface(
...@@ -530,19 +530,19 @@ static const IMarshalVtbl ProxyMarshal_Vtbl = ...@@ -530,19 +530,19 @@ static const IMarshalVtbl ProxyMarshal_Vtbl =
static HRESULT WINAPI ProxyCliSec_QueryInterface(IClientSecurity *iface, REFIID riid, void **ppvObject) static HRESULT WINAPI ProxyCliSec_QueryInterface(IClientSecurity *iface, REFIID riid, void **ppvObject)
{ {
struct proxy_manager *This = impl_from_IClientSecurity( iface ); struct proxy_manager *This = impl_from_IClientSecurity( iface );
return IMultiQI_QueryInterface((IMultiQI *)&This->lpVtbl, riid, ppvObject); return IMultiQI_QueryInterface(&This->IMultiQI_iface, riid, ppvObject);
} }
static ULONG WINAPI ProxyCliSec_AddRef(IClientSecurity *iface) static ULONG WINAPI ProxyCliSec_AddRef(IClientSecurity *iface)
{ {
struct proxy_manager *This = impl_from_IClientSecurity( iface ); struct proxy_manager *This = impl_from_IClientSecurity( iface );
return IMultiQI_AddRef((IMultiQI *)&This->lpVtbl); return IMultiQI_AddRef(&This->IMultiQI_iface);
} }
static ULONG WINAPI ProxyCliSec_Release(IClientSecurity *iface) static ULONG WINAPI ProxyCliSec_Release(IClientSecurity *iface)
{ {
struct proxy_manager *This = impl_from_IClientSecurity( iface ); struct proxy_manager *This = impl_from_IClientSecurity( iface );
return IMultiQI_Release((IMultiQI *)&This->lpVtbl); return IMultiQI_Release(&This->IMultiQI_iface);
} }
static HRESULT WINAPI ProxyCliSec_QueryBlanket(IClientSecurity *iface, static HRESULT WINAPI ProxyCliSec_QueryBlanket(IClientSecurity *iface,
...@@ -754,7 +754,7 @@ static HRESULT proxy_manager_construct( ...@@ -754,7 +754,7 @@ static HRESULT proxy_manager_construct(
} }
} }
This->lpVtbl = &ClientIdentity_Vtbl; This->IMultiQI_iface.lpVtbl = &ClientIdentity_Vtbl;
This->lpVtblMarshal = &ProxyMarshal_Vtbl; This->lpVtblMarshal = &ProxyMarshal_Vtbl;
This->lpVtblCliSec = &ProxyCliSec_Vtbl; This->lpVtblCliSec = &ProxyCliSec_Vtbl;
...@@ -869,8 +869,8 @@ static HRESULT proxy_manager_query_local_interface(struct proxy_manager * This, ...@@ -869,8 +869,8 @@ static HRESULT proxy_manager_query_local_interface(struct proxy_manager * This,
if (IsEqualIID(riid, &IID_IUnknown) || if (IsEqualIID(riid, &IID_IUnknown) ||
IsEqualIID(riid, &IID_IMultiQI)) IsEqualIID(riid, &IID_IMultiQI))
{ {
*ppv = &This->lpVtbl; *ppv = &This->IMultiQI_iface;
IUnknown_AddRef((IUnknown *)*ppv); IMultiQI_AddRef(&This->IMultiQI_iface);
return S_OK; return S_OK;
} }
if (IsEqualIID(riid, &IID_IMarshal)) if (IsEqualIID(riid, &IID_IMarshal))
...@@ -922,8 +922,8 @@ static HRESULT proxy_manager_create_ifproxy( ...@@ -922,8 +922,8 @@ static HRESULT proxy_manager_create_ifproxy(
* proxy associated with the ifproxy as we handle IUnknown ourselves */ * proxy associated with the ifproxy as we handle IUnknown ourselves */
if (IsEqualIID(riid, &IID_IUnknown)) if (IsEqualIID(riid, &IID_IUnknown))
{ {
ifproxy->iface = &This->lpVtbl; ifproxy->iface = &This->IMultiQI_iface;
IMultiQI_AddRef((IMultiQI *)&This->lpVtbl); IMultiQI_AddRef(&This->IMultiQI_iface);
hr = S_OK; hr = S_OK;
} }
else else
...@@ -935,7 +935,7 @@ static HRESULT proxy_manager_create_ifproxy( ...@@ -935,7 +935,7 @@ static HRESULT proxy_manager_create_ifproxy(
* This ensures the COM identity rules are not violated, by having a * This ensures the COM identity rules are not violated, by having a
* one-to-one mapping of objects on the proxy side to objects on the * one-to-one mapping of objects on the proxy side to objects on the
* stub side, no matter which interface you view the object through */ * stub side, no matter which interface you view the object through */
hr = IPSFactoryBuffer_CreateProxy(psfb, (IUnknown *)&This->lpVtbl, riid, hr = IPSFactoryBuffer_CreateProxy(psfb, (IUnknown*)&This->IMultiQI_iface, riid,
&ifproxy->proxy, &ifproxy->iface); &ifproxy->proxy, &ifproxy->iface);
IPSFactoryBuffer_Release(psfb); IPSFactoryBuffer_Release(psfb);
if (hr != S_OK) if (hr != S_OK)
...@@ -1138,7 +1138,7 @@ static BOOL find_proxy_manager(APARTMENT * apt, OXID oxid, OID oid, struct proxy ...@@ -1138,7 +1138,7 @@ static BOOL find_proxy_manager(APARTMENT * apt, OXID oxid, OID oid, struct proxy
/* be careful of a race with ClientIdentity_Release, which would /* be careful of a race with ClientIdentity_Release, which would
* cause us to return a proxy which is in the process of being * cause us to return a proxy which is in the process of being
* destroyed */ * destroyed */
if (ClientIdentity_AddRef((IMultiQI *)&proxy->lpVtbl) != 0) if (IMultiQI_AddRef(&proxy->IMultiQI_iface) != 0)
{ {
*proxy_found = proxy; *proxy_found = proxy;
found = TRUE; found = TRUE;
...@@ -1322,7 +1322,7 @@ static HRESULT unmarshal_object(const STDOBJREF *stdobjref, APARTMENT *apt, ...@@ -1322,7 +1322,7 @@ static HRESULT unmarshal_object(const STDOBJREF *stdobjref, APARTMENT *apt,
/* release our reference to the proxy manager - the client/apartment /* release our reference to the proxy manager - the client/apartment
* will hold on to the remaining reference for us */ * will hold on to the remaining reference for us */
if (proxy_manager) ClientIdentity_Release((IMultiQI*)&proxy_manager->lpVtbl); if (proxy_manager) IMultiQI_Release(&proxy_manager->IMultiQI_iface);
return hr; return 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