Skip to content
Projects
Groups
Snippets
Help
This project
Loading...
Sign in / Register
Toggle navigation
W
wine-winehq
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-winehq
Commits
3673f6b7
Commit
3673f6b7
authored
Aug 03, 2011
by
Michael Stefaniuc
Committed by
Alexandre Julliard
Aug 03, 2011
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
ole32/tests: COM cleanup in compobj.c.
parent
c97a2ecd
Hide whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
27 additions
and
20 deletions
+27
-20
compobj.c
dlls/ole32/tests/compobj.c
+27
-20
No files found.
dlls/ole32/tests/compobj.c
View file @
3673f6b7
...
@@ -115,7 +115,7 @@ static ULONG WINAPI Test_IClassFactory_Release(LPCLASSFACTORY iface)
...
@@ -115,7 +115,7 @@ static ULONG WINAPI Test_IClassFactory_Release(LPCLASSFACTORY iface)
static
HRESULT
WINAPI
Test_IClassFactory_CreateInstance
(
static
HRESULT
WINAPI
Test_IClassFactory_CreateInstance
(
LPCLASSFACTORY
iface
,
LPCLASSFACTORY
iface
,
LPUNKNOWN
pUnkOuter
,
IUnknown
*
pUnkOuter
,
REFIID
riid
,
REFIID
riid
,
LPVOID
*
ppvObj
)
LPVOID
*
ppvObj
)
{
{
...
@@ -570,7 +570,7 @@ static void test_CoRegisterMessageFilter(void)
...
@@ -570,7 +570,7 @@ static void test_CoRegisterMessageFilter(void)
}
}
static
HRESULT
WINAPI
Test_IUnknown_QueryInterface
(
static
HRESULT
WINAPI
Test_IUnknown_QueryInterface
(
LPUNKNOWN
iface
,
IUnknown
*
iface
,
REFIID
riid
,
REFIID
riid
,
LPVOID
*
ppvObj
)
LPVOID
*
ppvObj
)
{
{
...
@@ -588,12 +588,12 @@ static HRESULT WINAPI Test_IUnknown_QueryInterface(
...
@@ -588,12 +588,12 @@ static HRESULT WINAPI Test_IUnknown_QueryInterface(
return
E_NOINTERFACE
;
return
E_NOINTERFACE
;
}
}
static
ULONG
WINAPI
Test_IUnknown_AddRef
(
LPUNKNOWN
iface
)
static
ULONG
WINAPI
Test_IUnknown_AddRef
(
IUnknown
*
iface
)
{
{
return
2
;
/* non-heap-based object */
return
2
;
/* non-heap-based object */
}
}
static
ULONG
WINAPI
Test_IUnknown_Release
(
LPUNKNOWN
iface
)
static
ULONG
WINAPI
Test_IUnknown_Release
(
IUnknown
*
iface
)
{
{
return
1
;
/* non-heap-based object */
return
1
;
/* non-heap-based object */
}
}
...
@@ -1271,10 +1271,15 @@ static void test_CoGetObjectContext(void)
...
@@ -1271,10 +1271,15 @@ static void test_CoGetObjectContext(void)
}
}
typedef
struct
{
typedef
struct
{
const
IUnknownVtbl
*
lpVtbl
;
IUnknown
IUnknown_iface
;
LONG
refs
;
LONG
refs
;
}
Test_CallContext
;
}
Test_CallContext
;
static
inline
Test_CallContext
*
impl_from_IUnknown
(
IUnknown
*
iface
)
{
return
CONTAINING_RECORD
(
iface
,
Test_CallContext
,
IUnknown_iface
);
}
static
HRESULT
WINAPI
Test_CallContext_QueryInterface
(
static
HRESULT
WINAPI
Test_CallContext_QueryInterface
(
IUnknown
*
iface
,
IUnknown
*
iface
,
REFIID
riid
,
REFIID
riid
,
...
@@ -1295,13 +1300,13 @@ static HRESULT WINAPI Test_CallContext_QueryInterface(
...
@@ -1295,13 +1300,13 @@ static HRESULT WINAPI Test_CallContext_QueryInterface(
static
ULONG
WINAPI
Test_CallContext_AddRef
(
IUnknown
*
iface
)
static
ULONG
WINAPI
Test_CallContext_AddRef
(
IUnknown
*
iface
)
{
{
Test_CallContext
*
This
=
(
Test_CallContext
*
)
iface
;
Test_CallContext
*
This
=
impl_from_IUnknown
(
iface
)
;
return
InterlockedIncrement
(
&
This
->
refs
);
return
InterlockedIncrement
(
&
This
->
refs
);
}
}
static
ULONG
WINAPI
Test_CallContext_Release
(
IUnknown
*
iface
)
static
ULONG
WINAPI
Test_CallContext_Release
(
IUnknown
*
iface
)
{
{
Test_CallContext
*
This
=
(
Test_CallContext
*
)
iface
;
Test_CallContext
*
This
=
impl_from_IUnknown
(
iface
)
;
ULONG
refs
=
InterlockedDecrement
(
&
This
->
refs
);
ULONG
refs
=
InterlockedDecrement
(
&
This
->
refs
);
if
(
!
refs
)
if
(
!
refs
)
HeapFree
(
GetProcessHeap
(),
0
,
This
);
HeapFree
(
GetProcessHeap
(),
0
,
This
);
...
@@ -1320,7 +1325,7 @@ static void test_CoGetCallContext(void)
...
@@ -1320,7 +1325,7 @@ static void test_CoGetCallContext(void)
HRESULT
hr
;
HRESULT
hr
;
ULONG
refs
;
ULONG
refs
;
IUnknown
*
pUnk
;
IUnknown
*
pUnk
;
IUnknown
*
test_object
;
Test_CallContext
*
test_object
;
if
(
!
pCoSwitchCallContext
)
if
(
!
pCoSwitchCallContext
)
{
{
...
@@ -1331,41 +1336,43 @@ static void test_CoGetCallContext(void)
...
@@ -1331,41 +1336,43 @@ static void test_CoGetCallContext(void)
CoInitialize
(
NULL
);
CoInitialize
(
NULL
);
test_object
=
HeapAlloc
(
GetProcessHeap
(),
0
,
sizeof
(
Test_CallContext
));
test_object
=
HeapAlloc
(
GetProcessHeap
(),
0
,
sizeof
(
Test_CallContext
));
((
Test_CallContext
*
)
test_object
)
->
lpVtbl
=
&
TestCallContext_Vtbl
;
test_object
->
IUnknown_iface
.
lpVtbl
=
&
TestCallContext_Vtbl
;
((
Test_CallContext
*
)
test_object
)
->
refs
=
1
;
test_object
->
refs
=
1
;
hr
=
CoGetCallContext
(
&
IID_IUnknown
,
(
void
**
)
&
pUnk
);
hr
=
CoGetCallContext
(
&
IID_IUnknown
,
(
void
**
)
&
pUnk
);
ok
(
hr
==
RPC_E_CALL_COMPLETE
,
"Expected RPC_E_CALL_COMPLETE, got 0x%08x
\n
"
,
hr
);
ok
(
hr
==
RPC_E_CALL_COMPLETE
,
"Expected RPC_E_CALL_COMPLETE, got 0x%08x
\n
"
,
hr
);
pUnk
=
(
IUnknown
*
)
0xdeadbeef
;
pUnk
=
(
IUnknown
*
)
0xdeadbeef
;
hr
=
pCoSwitchCallContext
(
test_object
,
&
pUnk
);
hr
=
pCoSwitchCallContext
(
&
test_object
->
IUnknown_iface
,
&
pUnk
);
ok_ole_success
(
hr
,
"CoSwitchCallContext"
);
ok_ole_success
(
hr
,
"CoSwitchCallContext"
);
ok
(
pUnk
==
NULL
,
"expected NULL, got %p
\n
"
,
pUnk
);
ok
(
pUnk
==
NULL
,
"expected NULL, got %p
\n
"
,
pUnk
);
refs
=
IUnknown_AddRef
(
test_object
);
refs
=
IUnknown_AddRef
(
&
test_object
->
IUnknown_iface
);
ok
(
refs
==
2
,
"Expected refcount 2, got %d
\n
"
,
refs
);
ok
(
refs
==
2
,
"Expected refcount 2, got %d
\n
"
,
refs
);
IUnknown_Release
(
test_object
);
IUnknown_Release
(
&
test_object
->
IUnknown_iface
);
pUnk
=
(
IUnknown
*
)
0xdeadbeef
;
pUnk
=
(
IUnknown
*
)
0xdeadbeef
;
hr
=
CoGetCallContext
(
&
IID_IUnknown
,
(
void
**
)
&
pUnk
);
hr
=
CoGetCallContext
(
&
IID_IUnknown
,
(
void
**
)
&
pUnk
);
ok_ole_success
(
hr
,
"CoGetCallContext"
);
ok_ole_success
(
hr
,
"CoGetCallContext"
);
ok
(
pUnk
==
test_object
,
"expected %p, got %p
\n
"
,
test_object
,
pUnk
);
ok
(
pUnk
==
&
test_object
->
IUnknown_iface
,
"expected %p, got %p
\n
"
,
refs
=
IUnknown_AddRef
(
test_object
);
&
test_object
->
IUnknown_iface
,
pUnk
);
refs
=
IUnknown_AddRef
(
&
test_object
->
IUnknown_iface
);
ok
(
refs
==
3
,
"Expected refcount 3, got %d
\n
"
,
refs
);
ok
(
refs
==
3
,
"Expected refcount 3, got %d
\n
"
,
refs
);
IUnknown_Release
(
test_object
);
IUnknown_Release
(
&
test_object
->
IUnknown_iface
);
IUnknown_Release
(
pUnk
);
IUnknown_Release
(
pUnk
);
pUnk
=
(
IUnknown
*
)
0xdeadbeef
;
pUnk
=
(
IUnknown
*
)
0xdeadbeef
;
hr
=
pCoSwitchCallContext
(
NULL
,
&
pUnk
);
hr
=
pCoSwitchCallContext
(
NULL
,
&
pUnk
);
ok_ole_success
(
hr
,
"CoSwitchCallContext"
);
ok_ole_success
(
hr
,
"CoSwitchCallContext"
);
ok
(
pUnk
==
test_object
,
"expected %p, got %p
\n
"
,
test_object
,
pUnk
);
ok
(
pUnk
==
&
test_object
->
IUnknown_iface
,
"expected %p, got %p
\n
"
,
refs
=
IUnknown_AddRef
(
test_object
);
&
test_object
->
IUnknown_iface
,
pUnk
);
refs
=
IUnknown_AddRef
(
&
test_object
->
IUnknown_iface
);
ok
(
refs
==
2
,
"Expected refcount 2, got %d
\n
"
,
refs
);
ok
(
refs
==
2
,
"Expected refcount 2, got %d
\n
"
,
refs
);
IUnknown_Release
(
test_object
);
IUnknown_Release
(
&
test_object
->
IUnknown_iface
);
hr
=
CoGetCallContext
(
&
IID_IUnknown
,
(
void
**
)
&
pUnk
);
hr
=
CoGetCallContext
(
&
IID_IUnknown
,
(
void
**
)
&
pUnk
);
ok
(
hr
==
RPC_E_CALL_COMPLETE
,
"Expected RPC_E_CALL_COMPLETE, got 0x%08x
\n
"
,
hr
);
ok
(
hr
==
RPC_E_CALL_COMPLETE
,
"Expected RPC_E_CALL_COMPLETE, got 0x%08x
\n
"
,
hr
);
IUnknown_Release
(
test_object
);
IUnknown_Release
(
&
test_object
->
IUnknown_iface
);
CoUninitialize
();
CoUninitialize
();
}
}
...
...
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