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
d5c285dd
Commit
d5c285dd
authored
Dec 14, 2010
by
Michael Stefaniuc
Committed by
Alexandre Julliard
Dec 14, 2010
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
msctf/tests: Standardize the COM usage in inputprocessor.c.
parent
1df7dab1
Hide whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
74 additions
and
38 deletions
+74
-38
inputprocessor.c
dlls/msctf/tests/inputprocessor.c
+74
-38
No files found.
dlls/msctf/tests/inputprocessor.c
View file @
d5c285dd
...
@@ -21,6 +21,7 @@
...
@@ -21,6 +21,7 @@
#include <stdio.h>
#include <stdio.h>
#define COBJMACROS
#define COBJMACROS
#define CONST_VTABLE
#include "wine/test.h"
#include "wine/test.h"
#include "winuser.h"
#include "winuser.h"
#include "initguid.h"
#include "initguid.h"
...
@@ -148,11 +149,16 @@ static inline void _sink_check_ok(INT *sink, const CHAR* name)
...
@@ -148,11 +149,16 @@ static inline void _sink_check_ok(INT *sink, const CHAR* name)
**********************************************************************/
**********************************************************************/
typedef
struct
tagTextStoreACP
typedef
struct
tagTextStoreACP
{
{
const
ITextStoreACPVtbl
*
TextStoreACPVtbl
;
ITextStoreACP
ITextStoreACP_iface
;
LONG
refCount
;
LONG
refCount
;
}
TextStoreACP
;
}
TextStoreACP
;
static
inline
TextStoreACP
*
impl_from_ITextStoreACP
(
ITextStoreACP
*
iface
)
{
return
CONTAINING_RECORD
(
iface
,
TextStoreACP
,
ITextStoreACP_iface
);
}
static
void
TextStoreACP_Destructor
(
TextStoreACP
*
This
)
static
void
TextStoreACP_Destructor
(
TextStoreACP
*
This
)
{
{
HeapFree
(
GetProcessHeap
(),
0
,
This
);
HeapFree
(
GetProcessHeap
(),
0
,
This
);
...
@@ -160,7 +166,7 @@ static void TextStoreACP_Destructor(TextStoreACP *This)
...
@@ -160,7 +166,7 @@ static void TextStoreACP_Destructor(TextStoreACP *This)
static
HRESULT
WINAPI
TextStoreACP_QueryInterface
(
ITextStoreACP
*
iface
,
REFIID
iid
,
LPVOID
*
ppvOut
)
static
HRESULT
WINAPI
TextStoreACP_QueryInterface
(
ITextStoreACP
*
iface
,
REFIID
iid
,
LPVOID
*
ppvOut
)
{
{
TextStoreACP
*
This
=
(
TextStoreACP
*
)
iface
;
TextStoreACP
*
This
=
impl_from_ITextStoreACP
(
iface
)
;
*
ppvOut
=
NULL
;
*
ppvOut
=
NULL
;
if
(
IsEqualIID
(
iid
,
&
IID_IUnknown
)
||
IsEqualIID
(
iid
,
&
IID_ITextStoreACP
))
if
(
IsEqualIID
(
iid
,
&
IID_IUnknown
)
||
IsEqualIID
(
iid
,
&
IID_ITextStoreACP
))
...
@@ -179,13 +185,13 @@ static HRESULT WINAPI TextStoreACP_QueryInterface(ITextStoreACP *iface, REFIID i
...
@@ -179,13 +185,13 @@ static HRESULT WINAPI TextStoreACP_QueryInterface(ITextStoreACP *iface, REFIID i
static
ULONG
WINAPI
TextStoreACP_AddRef
(
ITextStoreACP
*
iface
)
static
ULONG
WINAPI
TextStoreACP_AddRef
(
ITextStoreACP
*
iface
)
{
{
TextStoreACP
*
This
=
(
TextStoreACP
*
)
iface
;
TextStoreACP
*
This
=
impl_from_ITextStoreACP
(
iface
)
;
return
InterlockedIncrement
(
&
This
->
refCount
);
return
InterlockedIncrement
(
&
This
->
refCount
);
}
}
static
ULONG
WINAPI
TextStoreACP_Release
(
ITextStoreACP
*
iface
)
static
ULONG
WINAPI
TextStoreACP_Release
(
ITextStoreACP
*
iface
)
{
{
TextStoreACP
*
This
=
(
TextStoreACP
*
)
iface
;
TextStoreACP
*
This
=
impl_from_ITextStoreACP
(
iface
)
;
ULONG
ret
;
ULONG
ret
;
ret
=
InterlockedDecrement
(
&
This
->
refCount
);
ret
=
InterlockedDecrement
(
&
This
->
refCount
);
...
@@ -421,7 +427,7 @@ static HRESULT TextStoreACP_Constructor(IUnknown **ppOut)
...
@@ -421,7 +427,7 @@ static HRESULT TextStoreACP_Constructor(IUnknown **ppOut)
if
(
This
==
NULL
)
if
(
This
==
NULL
)
return
E_OUTOFMEMORY
;
return
E_OUTOFMEMORY
;
This
->
TextStoreACP
Vtbl
=
&
TextStoreACP_TextStoreACPVtbl
;
This
->
ITextStoreACP_iface
.
lp
Vtbl
=
&
TextStoreACP_TextStoreACPVtbl
;
This
->
refCount
=
1
;
This
->
refCount
=
1
;
*
ppOut
=
(
IUnknown
*
)
This
;
*
ppOut
=
(
IUnknown
*
)
This
;
...
@@ -433,10 +439,15 @@ static HRESULT TextStoreACP_Constructor(IUnknown **ppOut)
...
@@ -433,10 +439,15 @@ static HRESULT TextStoreACP_Constructor(IUnknown **ppOut)
**********************************************************************/
**********************************************************************/
typedef
struct
tagThreadMgrEventSink
typedef
struct
tagThreadMgrEventSink
{
{
const
ITfThreadMgrEventSinkVtbl
*
ThreadMgrEventSinkVtbl
;
ITfThreadMgrEventSink
ITfThreadMgrEventSink_iface
;
LONG
refCount
;
LONG
refCount
;
}
ThreadMgrEventSink
;
}
ThreadMgrEventSink
;
static
inline
ThreadMgrEventSink
*
impl_from_ITfThreadMgrEventSink
(
ITfThreadMgrEventSink
*
iface
)
{
return
CONTAINING_RECORD
(
iface
,
ThreadMgrEventSink
,
ITfThreadMgrEventSink_iface
);
}
static
void
ThreadMgrEventSink_Destructor
(
ThreadMgrEventSink
*
This
)
static
void
ThreadMgrEventSink_Destructor
(
ThreadMgrEventSink
*
This
)
{
{
HeapFree
(
GetProcessHeap
(),
0
,
This
);
HeapFree
(
GetProcessHeap
(),
0
,
This
);
...
@@ -444,7 +455,7 @@ static void ThreadMgrEventSink_Destructor(ThreadMgrEventSink *This)
...
@@ -444,7 +455,7 @@ static void ThreadMgrEventSink_Destructor(ThreadMgrEventSink *This)
static
HRESULT
WINAPI
ThreadMgrEventSink_QueryInterface
(
ITfThreadMgrEventSink
*
iface
,
REFIID
iid
,
LPVOID
*
ppvOut
)
static
HRESULT
WINAPI
ThreadMgrEventSink_QueryInterface
(
ITfThreadMgrEventSink
*
iface
,
REFIID
iid
,
LPVOID
*
ppvOut
)
{
{
ThreadMgrEventSink
*
This
=
(
ThreadMgrEventSink
*
)
iface
;
ThreadMgrEventSink
*
This
=
impl_from_ITfThreadMgrEventSink
(
iface
)
;
*
ppvOut
=
NULL
;
*
ppvOut
=
NULL
;
if
(
IsEqualIID
(
iid
,
&
IID_IUnknown
)
||
IsEqualIID
(
iid
,
&
IID_ITfThreadMgrEventSink
))
if
(
IsEqualIID
(
iid
,
&
IID_IUnknown
)
||
IsEqualIID
(
iid
,
&
IID_ITfThreadMgrEventSink
))
...
@@ -463,14 +474,14 @@ static HRESULT WINAPI ThreadMgrEventSink_QueryInterface(ITfThreadMgrEventSink *i
...
@@ -463,14 +474,14 @@ static HRESULT WINAPI ThreadMgrEventSink_QueryInterface(ITfThreadMgrEventSink *i
static
ULONG
WINAPI
ThreadMgrEventSink_AddRef
(
ITfThreadMgrEventSink
*
iface
)
static
ULONG
WINAPI
ThreadMgrEventSink_AddRef
(
ITfThreadMgrEventSink
*
iface
)
{
{
ThreadMgrEventSink
*
This
=
(
ThreadMgrEventSink
*
)
iface
;
ThreadMgrEventSink
*
This
=
impl_from_ITfThreadMgrEventSink
(
iface
)
;
ok
(
tmSinkRefCount
==
This
->
refCount
,
"ThreadMgrEventSink refcount off %i vs %i
\n
"
,
This
->
refCount
,
tmSinkRefCount
);
ok
(
tmSinkRefCount
==
This
->
refCount
,
"ThreadMgrEventSink refcount off %i vs %i
\n
"
,
This
->
refCount
,
tmSinkRefCount
);
return
InterlockedIncrement
(
&
This
->
refCount
);
return
InterlockedIncrement
(
&
This
->
refCount
);
}
}
static
ULONG
WINAPI
ThreadMgrEventSink_Release
(
ITfThreadMgrEventSink
*
iface
)
static
ULONG
WINAPI
ThreadMgrEventSink_Release
(
ITfThreadMgrEventSink
*
iface
)
{
{
ThreadMgrEventSink
*
This
=
(
ThreadMgrEventSink
*
)
iface
;
ThreadMgrEventSink
*
This
=
impl_from_ITfThreadMgrEventSink
(
iface
)
;
ULONG
ret
;
ULONG
ret
;
ok
(
tmSinkRefCount
==
This
->
refCount
,
"ThreadMgrEventSink refcount off %i vs %i
\n
"
,
This
->
refCount
,
tmSinkRefCount
);
ok
(
tmSinkRefCount
==
This
->
refCount
,
"ThreadMgrEventSink refcount off %i vs %i
\n
"
,
This
->
refCount
,
tmSinkRefCount
);
...
@@ -568,7 +579,7 @@ static HRESULT ThreadMgrEventSink_Constructor(IUnknown **ppOut)
...
@@ -568,7 +579,7 @@ static HRESULT ThreadMgrEventSink_Constructor(IUnknown **ppOut)
if
(
This
==
NULL
)
if
(
This
==
NULL
)
return
E_OUTOFMEMORY
;
return
E_OUTOFMEMORY
;
This
->
ThreadMgrEventSink
Vtbl
=
&
ThreadMgrEventSink_ThreadMgrEventSinkVtbl
;
This
->
ITfThreadMgrEventSink_iface
.
lp
Vtbl
=
&
ThreadMgrEventSink_ThreadMgrEventSinkVtbl
;
This
->
refCount
=
1
;
This
->
refCount
=
1
;
*
ppOut
=
(
IUnknown
*
)
This
;
*
ppOut
=
(
IUnknown
*
)
This
;
...
@@ -588,17 +599,27 @@ typedef HRESULT (*LPFNCONSTRUCTOR)(IUnknown *pUnkOuter, IUnknown **ppvOut);
...
@@ -588,17 +599,27 @@ typedef HRESULT (*LPFNCONSTRUCTOR)(IUnknown *pUnkOuter, IUnknown **ppvOut);
typedef
struct
tagClassFactory
typedef
struct
tagClassFactory
{
{
const
IClassFactoryVtbl
*
vtbl
;
IClassFactory
IClassFactory_iface
;
LONG
ref
;
LONG
ref
;
LPFNCONSTRUCTOR
ctor
;
LPFNCONSTRUCTOR
ctor
;
}
ClassFactory
;
}
ClassFactory
;
static
inline
ClassFactory
*
impl_from_IClassFactory
(
IClassFactory
*
iface
)
{
return
CONTAINING_RECORD
(
iface
,
ClassFactory
,
IClassFactory_iface
);
}
typedef
struct
tagTextService
typedef
struct
tagTextService
{
{
const
ITfTextInputProcessorVtbl
*
TextInputProcessorVtbl
;
ITfTextInputProcessor
ITfTextInputProcessor_iface
;
LONG
refCount
;
LONG
refCount
;
}
TextService
;
}
TextService
;
static
inline
TextService
*
impl_from_ITfTextInputProcessor
(
ITfTextInputProcessor
*
iface
)
{
return
CONTAINING_RECORD
(
iface
,
TextService
,
ITfTextInputProcessor_iface
);
}
static
void
ClassFactory_Destructor
(
ClassFactory
*
This
)
static
void
ClassFactory_Destructor
(
ClassFactory
*
This
)
{
{
HeapFree
(
GetProcessHeap
(),
0
,
This
);
HeapFree
(
GetProcessHeap
(),
0
,
This
);
...
@@ -620,13 +641,13 @@ static HRESULT WINAPI ClassFactory_QueryInterface(IClassFactory *iface, REFIID r
...
@@ -620,13 +641,13 @@ static HRESULT WINAPI ClassFactory_QueryInterface(IClassFactory *iface, REFIID r
static
ULONG
WINAPI
ClassFactory_AddRef
(
IClassFactory
*
iface
)
static
ULONG
WINAPI
ClassFactory_AddRef
(
IClassFactory
*
iface
)
{
{
ClassFactory
*
This
=
(
ClassFactory
*
)
iface
;
ClassFactory
*
This
=
impl_from_IClassFactory
(
iface
)
;
return
InterlockedIncrement
(
&
This
->
ref
);
return
InterlockedIncrement
(
&
This
->
ref
);
}
}
static
ULONG
WINAPI
ClassFactory_Release
(
IClassFactory
*
iface
)
static
ULONG
WINAPI
ClassFactory_Release
(
IClassFactory
*
iface
)
{
{
ClassFactory
*
This
=
(
ClassFactory
*
)
iface
;
ClassFactory
*
This
=
impl_from_IClassFactory
(
iface
)
;
ULONG
ret
=
InterlockedDecrement
(
&
This
->
ref
);
ULONG
ret
=
InterlockedDecrement
(
&
This
->
ref
);
if
(
ret
==
0
)
if
(
ret
==
0
)
...
@@ -636,7 +657,7 @@ static ULONG WINAPI ClassFactory_Release(IClassFactory *iface)
...
@@ -636,7 +657,7 @@ static ULONG WINAPI ClassFactory_Release(IClassFactory *iface)
static
HRESULT
WINAPI
ClassFactory_CreateInstance
(
IClassFactory
*
iface
,
IUnknown
*
punkOuter
,
REFIID
iid
,
LPVOID
*
ppvOut
)
static
HRESULT
WINAPI
ClassFactory_CreateInstance
(
IClassFactory
*
iface
,
IUnknown
*
punkOuter
,
REFIID
iid
,
LPVOID
*
ppvOut
)
{
{
ClassFactory
*
This
=
(
ClassFactory
*
)
iface
;
ClassFactory
*
This
=
impl_from_IClassFactory
(
iface
)
;
HRESULT
ret
;
HRESULT
ret
;
IUnknown
*
obj
;
IUnknown
*
obj
;
...
@@ -672,7 +693,7 @@ static const IClassFactoryVtbl ClassFactoryVtbl = {
...
@@ -672,7 +693,7 @@ static const IClassFactoryVtbl ClassFactoryVtbl = {
static
HRESULT
ClassFactory_Constructor
(
LPFNCONSTRUCTOR
ctor
,
LPVOID
*
ppvOut
)
static
HRESULT
ClassFactory_Constructor
(
LPFNCONSTRUCTOR
ctor
,
LPVOID
*
ppvOut
)
{
{
ClassFactory
*
This
=
HeapAlloc
(
GetProcessHeap
(),
0
,
sizeof
(
ClassFactory
));
ClassFactory
*
This
=
HeapAlloc
(
GetProcessHeap
(),
0
,
sizeof
(
ClassFactory
));
This
->
v
tbl
=
&
ClassFactoryVtbl
;
This
->
IClassFactory_iface
.
lpV
tbl
=
&
ClassFactoryVtbl
;
This
->
ref
=
1
;
This
->
ref
=
1
;
This
->
ctor
=
ctor
;
This
->
ctor
=
ctor
;
*
ppvOut
=
(
LPVOID
)
This
;
*
ppvOut
=
(
LPVOID
)
This
;
...
@@ -687,7 +708,7 @@ static void TextService_Destructor(TextService *This)
...
@@ -687,7 +708,7 @@ static void TextService_Destructor(TextService *This)
static
HRESULT
WINAPI
TextService_QueryInterface
(
ITfTextInputProcessor
*
iface
,
REFIID
iid
,
LPVOID
*
ppvOut
)
static
HRESULT
WINAPI
TextService_QueryInterface
(
ITfTextInputProcessor
*
iface
,
REFIID
iid
,
LPVOID
*
ppvOut
)
{
{
TextService
*
This
=
(
TextService
*
)
iface
;
TextService
*
This
=
impl_from_ITfTextInputProcessor
(
iface
)
;
*
ppvOut
=
NULL
;
*
ppvOut
=
NULL
;
if
(
IsEqualIID
(
iid
,
&
IID_IUnknown
)
||
IsEqualIID
(
iid
,
&
IID_ITfTextInputProcessor
))
if
(
IsEqualIID
(
iid
,
&
IID_IUnknown
)
||
IsEqualIID
(
iid
,
&
IID_ITfTextInputProcessor
))
...
@@ -706,13 +727,13 @@ static HRESULT WINAPI TextService_QueryInterface(ITfTextInputProcessor *iface, R
...
@@ -706,13 +727,13 @@ static HRESULT WINAPI TextService_QueryInterface(ITfTextInputProcessor *iface, R
static
ULONG
WINAPI
TextService_AddRef
(
ITfTextInputProcessor
*
iface
)
static
ULONG
WINAPI
TextService_AddRef
(
ITfTextInputProcessor
*
iface
)
{
{
TextService
*
This
=
(
TextService
*
)
iface
;
TextService
*
This
=
impl_from_ITfTextInputProcessor
(
iface
)
;
return
InterlockedIncrement
(
&
This
->
refCount
);
return
InterlockedIncrement
(
&
This
->
refCount
);
}
}
static
ULONG
WINAPI
TextService_Release
(
ITfTextInputProcessor
*
iface
)
static
ULONG
WINAPI
TextService_Release
(
ITfTextInputProcessor
*
iface
)
{
{
TextService
*
This
=
(
TextService
*
)
iface
;
TextService
*
This
=
impl_from_ITfTextInputProcessor
(
iface
)
;
ULONG
ret
;
ULONG
ret
;
ret
=
InterlockedDecrement
(
&
This
->
refCount
);
ret
=
InterlockedDecrement
(
&
This
->
refCount
);
...
@@ -757,7 +778,7 @@ static HRESULT TextService_Constructor(IUnknown *pUnkOuter, IUnknown **ppOut)
...
@@ -757,7 +778,7 @@ static HRESULT TextService_Constructor(IUnknown *pUnkOuter, IUnknown **ppOut)
if
(
This
==
NULL
)
if
(
This
==
NULL
)
return
E_OUTOFMEMORY
;
return
E_OUTOFMEMORY
;
This
->
TextInputProcessorVtbl
=
&
TextService_TextInputProcessorVtbl
;
This
->
ITfTextInputProcessor_iface
.
lpVtbl
=
&
TextService_TextInputProcessorVtbl
;
This
->
refCount
=
1
;
This
->
refCount
=
1
;
*
ppOut
=
(
IUnknown
*
)
This
;
*
ppOut
=
(
IUnknown
*
)
This
;
...
@@ -998,10 +1019,15 @@ static void test_ThreadMgrUnadviseSinks(void)
...
@@ -998,10 +1019,15 @@ static void test_ThreadMgrUnadviseSinks(void)
**********************************************************************/
**********************************************************************/
typedef
struct
tagKeyEventSink
typedef
struct
tagKeyEventSink
{
{
const
ITfKeyEventSinkVtbl
*
KeyEventSinkVtbl
;
ITfKeyEventSink
ITfKeyEventSink_iface
;
LONG
refCount
;
LONG
refCount
;
}
KeyEventSink
;
}
KeyEventSink
;
static
inline
KeyEventSink
*
impl_from_ITfKeyEventSink
(
ITfKeyEventSink
*
iface
)
{
return
CONTAINING_RECORD
(
iface
,
KeyEventSink
,
ITfKeyEventSink_iface
);
}
static
void
KeyEventSink_Destructor
(
KeyEventSink
*
This
)
static
void
KeyEventSink_Destructor
(
KeyEventSink
*
This
)
{
{
HeapFree
(
GetProcessHeap
(),
0
,
This
);
HeapFree
(
GetProcessHeap
(),
0
,
This
);
...
@@ -1009,7 +1035,7 @@ static void KeyEventSink_Destructor(KeyEventSink *This)
...
@@ -1009,7 +1035,7 @@ static void KeyEventSink_Destructor(KeyEventSink *This)
static
HRESULT
WINAPI
KeyEventSink_QueryInterface
(
ITfKeyEventSink
*
iface
,
REFIID
iid
,
LPVOID
*
ppvOut
)
static
HRESULT
WINAPI
KeyEventSink_QueryInterface
(
ITfKeyEventSink
*
iface
,
REFIID
iid
,
LPVOID
*
ppvOut
)
{
{
KeyEventSink
*
This
=
(
KeyEventSink
*
)
iface
;
KeyEventSink
*
This
=
impl_from_ITfKeyEventSink
(
iface
)
;
*
ppvOut
=
NULL
;
*
ppvOut
=
NULL
;
if
(
IsEqualIID
(
iid
,
&
IID_IUnknown
)
||
IsEqualIID
(
iid
,
&
IID_ITfKeyEventSink
))
if
(
IsEqualIID
(
iid
,
&
IID_IUnknown
)
||
IsEqualIID
(
iid
,
&
IID_ITfKeyEventSink
))
...
@@ -1028,13 +1054,13 @@ static HRESULT WINAPI KeyEventSink_QueryInterface(ITfKeyEventSink *iface, REFIID
...
@@ -1028,13 +1054,13 @@ static HRESULT WINAPI KeyEventSink_QueryInterface(ITfKeyEventSink *iface, REFIID
static
ULONG
WINAPI
KeyEventSink_AddRef
(
ITfKeyEventSink
*
iface
)
static
ULONG
WINAPI
KeyEventSink_AddRef
(
ITfKeyEventSink
*
iface
)
{
{
KeyEventSink
*
This
=
(
KeyEventSink
*
)
iface
;
KeyEventSink
*
This
=
impl_from_ITfKeyEventSink
(
iface
)
;
return
InterlockedIncrement
(
&
This
->
refCount
);
return
InterlockedIncrement
(
&
This
->
refCount
);
}
}
static
ULONG
WINAPI
KeyEventSink_Release
(
ITfKeyEventSink
*
iface
)
static
ULONG
WINAPI
KeyEventSink_Release
(
ITfKeyEventSink
*
iface
)
{
{
KeyEventSink
*
This
=
(
KeyEventSink
*
)
iface
;
KeyEventSink
*
This
=
impl_from_ITfKeyEventSink
(
iface
)
;
ULONG
ret
;
ULONG
ret
;
ret
=
InterlockedDecrement
(
&
This
->
refCount
);
ret
=
InterlockedDecrement
(
&
This
->
refCount
);
...
@@ -1107,10 +1133,10 @@ static HRESULT KeyEventSink_Constructor(ITfKeyEventSink **ppOut)
...
@@ -1107,10 +1133,10 @@ static HRESULT KeyEventSink_Constructor(ITfKeyEventSink **ppOut)
if
(
This
==
NULL
)
if
(
This
==
NULL
)
return
E_OUTOFMEMORY
;
return
E_OUTOFMEMORY
;
This
->
KeyEventSink
Vtbl
=
&
KeyEventSink_KeyEventSinkVtbl
;
This
->
ITfKeyEventSink_iface
.
lp
Vtbl
=
&
KeyEventSink_KeyEventSinkVtbl
;
This
->
refCount
=
1
;
This
->
refCount
=
1
;
*
ppOut
=
(
ITfKeyEventSink
*
)
This
;
*
ppOut
=
&
This
->
ITfKeyEventSink_iface
;
return
S_OK
;
return
S_OK
;
}
}
...
@@ -1253,10 +1279,15 @@ static inline int check_context_refcount(ITfContext *iface)
...
@@ -1253,10 +1279,15 @@ static inline int check_context_refcount(ITfContext *iface)
**********************************************************************/
**********************************************************************/
typedef
struct
tagTextEditSink
typedef
struct
tagTextEditSink
{
{
const
ITfTextEditSinkVtbl
*
TextEditSinkVtbl
;
ITfTextEditSink
ITfTextEditSink_iface
;
LONG
refCount
;
LONG
refCount
;
}
TextEditSink
;
}
TextEditSink
;
static
inline
TextEditSink
*
impl_from_ITfTextEditSink
(
ITfTextEditSink
*
iface
)
{
return
CONTAINING_RECORD
(
iface
,
TextEditSink
,
ITfTextEditSink_iface
);
}
static
void
TextEditSink_Destructor
(
TextEditSink
*
This
)
static
void
TextEditSink_Destructor
(
TextEditSink
*
This
)
{
{
HeapFree
(
GetProcessHeap
(),
0
,
This
);
HeapFree
(
GetProcessHeap
(),
0
,
This
);
...
@@ -1264,7 +1295,7 @@ static void TextEditSink_Destructor(TextEditSink *This)
...
@@ -1264,7 +1295,7 @@ static void TextEditSink_Destructor(TextEditSink *This)
static
HRESULT
WINAPI
TextEditSink_QueryInterface
(
ITfTextEditSink
*
iface
,
REFIID
iid
,
LPVOID
*
ppvOut
)
static
HRESULT
WINAPI
TextEditSink_QueryInterface
(
ITfTextEditSink
*
iface
,
REFIID
iid
,
LPVOID
*
ppvOut
)
{
{
TextEditSink
*
This
=
(
TextEditSink
*
)
iface
;
TextEditSink
*
This
=
impl_from_ITfTextEditSink
(
iface
)
;
*
ppvOut
=
NULL
;
*
ppvOut
=
NULL
;
if
(
IsEqualIID
(
iid
,
&
IID_IUnknown
)
||
IsEqualIID
(
iid
,
&
IID_ITfTextEditSink
))
if
(
IsEqualIID
(
iid
,
&
IID_IUnknown
)
||
IsEqualIID
(
iid
,
&
IID_ITfTextEditSink
))
...
@@ -1283,13 +1314,13 @@ static HRESULT WINAPI TextEditSink_QueryInterface(ITfTextEditSink *iface, REFIID
...
@@ -1283,13 +1314,13 @@ static HRESULT WINAPI TextEditSink_QueryInterface(ITfTextEditSink *iface, REFIID
static
ULONG
WINAPI
TextEditSink_AddRef
(
ITfTextEditSink
*
iface
)
static
ULONG
WINAPI
TextEditSink_AddRef
(
ITfTextEditSink
*
iface
)
{
{
TextEditSink
*
This
=
(
TextEditSink
*
)
iface
;
TextEditSink
*
This
=
impl_from_ITfTextEditSink
(
iface
)
;
return
InterlockedIncrement
(
&
This
->
refCount
);
return
InterlockedIncrement
(
&
This
->
refCount
);
}
}
static
ULONG
WINAPI
TextEditSink_Release
(
ITfTextEditSink
*
iface
)
static
ULONG
WINAPI
TextEditSink_Release
(
ITfTextEditSink
*
iface
)
{
{
TextEditSink
*
This
=
(
TextEditSink
*
)
iface
;
TextEditSink
*
This
=
impl_from_ITfTextEditSink
(
iface
)
;
ULONG
ret
;
ULONG
ret
;
ret
=
InterlockedDecrement
(
&
This
->
refCount
);
ret
=
InterlockedDecrement
(
&
This
->
refCount
);
...
@@ -1323,10 +1354,10 @@ static HRESULT TextEditSink_Constructor(ITfTextEditSink **ppOut)
...
@@ -1323,10 +1354,10 @@ static HRESULT TextEditSink_Constructor(ITfTextEditSink **ppOut)
if
(
This
==
NULL
)
if
(
This
==
NULL
)
return
E_OUTOFMEMORY
;
return
E_OUTOFMEMORY
;
This
->
TextEditSink
Vtbl
=
&
TextEditSink_TextEditSinkVtbl
;
This
->
ITfTextEditSink_iface
.
lp
Vtbl
=
&
TextEditSink_TextEditSinkVtbl
;
This
->
refCount
=
1
;
This
->
refCount
=
1
;
*
ppOut
=
(
ITfTextEditSink
*
)
This
;
*
ppOut
=
&
This
->
ITfTextEditSink_iface
;
return
S_OK
;
return
S_OK
;
}
}
...
@@ -1603,10 +1634,15 @@ static void test_ClientId(void)
...
@@ -1603,10 +1634,15 @@ static void test_ClientId(void)
**********************************************************************/
**********************************************************************/
typedef
struct
tagEditSession
typedef
struct
tagEditSession
{
{
const
ITfEditSessionVtbl
*
EditSessionVtbl
;
ITfEditSession
ITfEditSession_iface
;
LONG
refCount
;
LONG
refCount
;
}
EditSession
;
}
EditSession
;
static
inline
EditSession
*
impl_from_ITfEditSession
(
ITfEditSession
*
iface
)
{
return
CONTAINING_RECORD
(
iface
,
EditSession
,
ITfEditSession_iface
);
}
static
void
EditSession_Destructor
(
EditSession
*
This
)
static
void
EditSession_Destructor
(
EditSession
*
This
)
{
{
HeapFree
(
GetProcessHeap
(),
0
,
This
);
HeapFree
(
GetProcessHeap
(),
0
,
This
);
...
@@ -1614,7 +1650,7 @@ static void EditSession_Destructor(EditSession *This)
...
@@ -1614,7 +1650,7 @@ static void EditSession_Destructor(EditSession *This)
static
HRESULT
WINAPI
EditSession_QueryInterface
(
ITfEditSession
*
iface
,
REFIID
iid
,
LPVOID
*
ppvOut
)
static
HRESULT
WINAPI
EditSession_QueryInterface
(
ITfEditSession
*
iface
,
REFIID
iid
,
LPVOID
*
ppvOut
)
{
{
EditSession
*
This
=
(
EditSession
*
)
iface
;
EditSession
*
This
=
impl_from_ITfEditSession
(
iface
)
;
*
ppvOut
=
NULL
;
*
ppvOut
=
NULL
;
if
(
IsEqualIID
(
iid
,
&
IID_IUnknown
)
||
IsEqualIID
(
iid
,
&
IID_ITfEditSession
))
if
(
IsEqualIID
(
iid
,
&
IID_IUnknown
)
||
IsEqualIID
(
iid
,
&
IID_ITfEditSession
))
...
@@ -1633,13 +1669,13 @@ static HRESULT WINAPI EditSession_QueryInterface(ITfEditSession *iface, REFIID i
...
@@ -1633,13 +1669,13 @@ static HRESULT WINAPI EditSession_QueryInterface(ITfEditSession *iface, REFIID i
static
ULONG
WINAPI
EditSession_AddRef
(
ITfEditSession
*
iface
)
static
ULONG
WINAPI
EditSession_AddRef
(
ITfEditSession
*
iface
)
{
{
EditSession
*
This
=
(
EditSession
*
)
iface
;
EditSession
*
This
=
impl_from_ITfEditSession
(
iface
)
;
return
InterlockedIncrement
(
&
This
->
refCount
);
return
InterlockedIncrement
(
&
This
->
refCount
);
}
}
static
ULONG
WINAPI
EditSession_Release
(
ITfEditSession
*
iface
)
static
ULONG
WINAPI
EditSession_Release
(
ITfEditSession
*
iface
)
{
{
EditSession
*
This
=
(
EditSession
*
)
iface
;
EditSession
*
This
=
impl_from_ITfEditSession
(
iface
)
;
ULONG
ret
;
ULONG
ret
;
ret
=
InterlockedDecrement
(
&
This
->
refCount
);
ret
=
InterlockedDecrement
(
&
This
->
refCount
);
...
@@ -1760,10 +1796,10 @@ static HRESULT EditSession_Constructor(ITfEditSession **ppOut)
...
@@ -1760,10 +1796,10 @@ static HRESULT EditSession_Constructor(ITfEditSession **ppOut)
if
(
This
==
NULL
)
if
(
This
==
NULL
)
return
E_OUTOFMEMORY
;
return
E_OUTOFMEMORY
;
This
->
EditSession
Vtbl
=
&
EditSession_EditSessionVtbl
;
This
->
ITfEditSession_iface
.
lp
Vtbl
=
&
EditSession_EditSessionVtbl
;
This
->
refCount
=
1
;
This
->
refCount
=
1
;
*
ppOut
=
(
ITfEditSession
*
)
This
;
*
ppOut
=
&
This
->
ITfEditSession_iface
;
return
S_OK
;
return
S_OK
;
}
}
...
...
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