Skip to content
Projects
Groups
Snippets
Help
This project
Loading...
Sign in / Register
Toggle navigation
W
wine-cw
Project
Project
Details
Activity
Cycle Analytics
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Issues
0
Issues
0
List
Board
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Charts
Registry
Registry
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
wine
wine-cw
Commits
ba4b88bc
Commit
ba4b88bc
authored
Oct 15, 2012
by
Nikolay Sivov
Committed by
Alexandre Julliard
Oct 15, 2012
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
ole32: Cleanup IMultiQI interface of proxy manager.
parent
0b5c0855
Hide whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
15 additions
and
15 deletions
+15
-15
marshal.c
dlls/ole32/marshal.c
+15
-15
No files found.
dlls/ole32/marshal.c
View file @
ba4b88bc
...
@@ -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
;
I
Unknown_AddRef
((
IUnknown
*
)
*
ppv
);
I
MultiQI_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
;
}
}
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment