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
65941a66
Commit
65941a66
authored
Jan 06, 2011
by
Michael Stefaniuc
Committed by
Alexandre Julliard
Jan 07, 2011
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
oleaut32/tests: COM cleanup for vartest.c.
parent
5c40a8a9
Show whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
16 additions
and
9 deletions
+16
-9
vartest.c
dlls/oleaut32/tests/vartest.c
+16
-9
No files found.
dlls/oleaut32/tests/vartest.c
View file @
65941a66
...
@@ -24,6 +24,8 @@
...
@@ -24,6 +24,8 @@
#include <math.h>
#include <math.h>
#include <float.h>
#include <float.h>
#define CONST_VTABLE
#include "windef.h"
#include "windef.h"
#include "winbase.h"
#include "winbase.h"
#include "winsock.h"
#include "winsock.h"
...
@@ -399,26 +401,31 @@ static int IsValidVariantClearVT(VARTYPE vt, VARTYPE extraFlags)
...
@@ -399,26 +401,31 @@ static int IsValidVariantClearVT(VARTYPE vt, VARTYPE extraFlags)
typedef
struct
typedef
struct
{
{
const
IUnknownVtbl
*
lpVtbl
;
IUnknown
IUnknown_iface
;
LONG
ref
;
LONG
ref
;
LONG
events
;
LONG
events
;
}
test_VariantClearImpl
;
}
test_VariantClearImpl
;
static
inline
test_VariantClearImpl
*
impl_from_IUnknown
(
IUnknown
*
iface
)
{
return
CONTAINING_RECORD
(
iface
,
test_VariantClearImpl
,
IUnknown_iface
);
}
static
HRESULT
WINAPI
VC_QueryInterface
(
LPUNKNOWN
iface
,
REFIID
riid
,
LPVOID
*
ppobj
)
static
HRESULT
WINAPI
VC_QueryInterface
(
LPUNKNOWN
iface
,
REFIID
riid
,
LPVOID
*
ppobj
)
{
{
test_VariantClearImpl
*
This
=
(
test_VariantClearImpl
*
)
iface
;
test_VariantClearImpl
*
This
=
impl_from_IUnknown
(
iface
)
;
This
->
events
|=
0x1
;
This
->
events
|=
0x1
;
return
E_NOINTERFACE
;
return
E_NOINTERFACE
;
}
}
static
ULONG
WINAPI
VC_AddRef
(
LPUNKNOWN
iface
)
{
static
ULONG
WINAPI
VC_AddRef
(
LPUNKNOWN
iface
)
{
test_VariantClearImpl
*
This
=
(
test_VariantClearImpl
*
)
iface
;
test_VariantClearImpl
*
This
=
impl_from_IUnknown
(
iface
)
;
This
->
events
|=
0x2
;
This
->
events
|=
0x2
;
return
InterlockedIncrement
(
&
This
->
ref
);
return
InterlockedIncrement
(
&
This
->
ref
);
}
}
static
ULONG
WINAPI
VC_Release
(
LPUNKNOWN
iface
)
{
static
ULONG
WINAPI
VC_Release
(
LPUNKNOWN
iface
)
{
test_VariantClearImpl
*
This
=
(
test_VariantClearImpl
*
)
iface
;
test_VariantClearImpl
*
This
=
impl_from_IUnknown
(
iface
)
;
/* static class, won't be freed */
/* static class, won't be freed */
This
->
events
|=
0x4
;
This
->
events
|=
0x4
;
return
InterlockedDecrement
(
&
This
->
ref
);
return
InterlockedDecrement
(
&
This
->
ref
);
...
@@ -430,7 +437,7 @@ static const IUnknownVtbl test_VariantClear_vtbl = {
...
@@ -430,7 +437,7 @@ static const IUnknownVtbl test_VariantClear_vtbl = {
VC_Release
,
VC_Release
,
};
};
static
test_VariantClearImpl
test_myVariantClearImpl
=
{
&
test_VariantClear_vtbl
,
1
,
0
};
static
test_VariantClearImpl
test_myVariantClearImpl
=
{
{
&
test_VariantClear_vtbl
}
,
1
,
0
};
static
void
test_VariantClear
(
void
)
static
void
test_VariantClear
(
void
)
{
{
...
@@ -509,17 +516,17 @@ static void test_VariantClear(void)
...
@@ -509,17 +516,17 @@ static void test_VariantClear(void)
/* UNKNOWN */
/* UNKNOWN */
V_VT
(
&
v
)
=
VT_UNKNOWN
;
V_VT
(
&
v
)
=
VT_UNKNOWN
;
V_UNKNOWN
(
&
v
)
=
(
IUnknown
*
)
&
test_myVariantClearImpl
;
V_UNKNOWN
(
&
v
)
=
&
test_myVariantClearImpl
.
IUnknown_iface
;
test_myVariantClearImpl
.
events
=
0
;
test_myVariantClearImpl
.
events
=
0
;
hres
=
VariantClear
(
&
v
);
hres
=
VariantClear
(
&
v
);
ok
(
hres
==
S_OK
,
"ret %08x
\n
"
,
hres
);
ok
(
hres
==
S_OK
,
"ret %08x
\n
"
,
hres
);
ok
(
V_VT
(
&
v
)
==
0
,
"vt %04x
\n
"
,
V_VT
(
&
v
));
ok
(
V_VT
(
&
v
)
==
0
,
"vt %04x
\n
"
,
V_VT
(
&
v
));
ok
(
V_UNKNOWN
(
&
v
)
==
(
IUnknown
*
)
&
test_myVariantClearImpl
,
"unknown %p
\n
"
,
V_UNKNOWN
(
&
v
));
ok
(
V_UNKNOWN
(
&
v
)
==
&
test_myVariantClearImpl
.
IUnknown_iface
,
"unknown %p
\n
"
,
V_UNKNOWN
(
&
v
));
/* Check that Release got called, but nothing else */
/* Check that Release got called, but nothing else */
ok
(
test_myVariantClearImpl
.
events
==
0x4
,
"Unexpected call. events %08x
\n
"
,
test_myVariantClearImpl
.
events
);
ok
(
test_myVariantClearImpl
.
events
==
0x4
,
"Unexpected call. events %08x
\n
"
,
test_myVariantClearImpl
.
events
);
/* UNKNOWN BYREF */
/* UNKNOWN BYREF */
punk
=
(
IUnknown
*
)
&
test_myVariantClearImpl
;
punk
=
&
test_myVariantClearImpl
.
IUnknown_iface
;
V_VT
(
&
v
)
=
VT_UNKNOWN
|
VT_BYREF
;
V_VT
(
&
v
)
=
VT_UNKNOWN
|
VT_BYREF
;
V_UNKNOWNREF
(
&
v
)
=
&
punk
;
V_UNKNOWNREF
(
&
v
)
=
&
punk
;
test_myVariantClearImpl
.
events
=
0
;
test_myVariantClearImpl
.
events
=
0
;
...
@@ -542,7 +549,7 @@ static void test_VariantClear(void)
...
@@ -542,7 +549,7 @@ static void test_VariantClear(void)
ok
(
test_myVariantClearImpl
.
events
==
0x4
,
"Unexpected call. events %08x
\n
"
,
test_myVariantClearImpl
.
events
);
ok
(
test_myVariantClearImpl
.
events
==
0x4
,
"Unexpected call. events %08x
\n
"
,
test_myVariantClearImpl
.
events
);
/* DISPATCH BYREF */
/* DISPATCH BYREF */
punk
=
(
IUnknown
*
)
&
test_myVariantClearImpl
;
punk
=
&
test_myVariantClearImpl
.
IUnknown_iface
;
V_VT
(
&
v
)
=
VT_DISPATCH
|
VT_BYREF
;
V_VT
(
&
v
)
=
VT_DISPATCH
|
VT_BYREF
;
V_DISPATCHREF
(
&
v
)
=
(
IDispatch
**
)
&
punk
;
V_DISPATCHREF
(
&
v
)
=
(
IDispatch
**
)
&
punk
;
test_myVariantClearImpl
.
events
=
0
;
test_myVariantClearImpl
.
events
=
0
;
...
...
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