* Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301, USA
*/
-#define WIN32_NO_STATUS
-#define _INC_WINDOWS
-#define COM_NO_WINDOWS_H
+#include "config.h"
-#include <config.h>
-
-//#include <stdarg.h>
+#include <stdarg.h>
#define COBJMACROS
-#include <wine/debug.h>
-//#include "windef.h"
-#include <winbase.h>
-//#include "winreg.h"
-//#include "winuser.h"
-//#include "shlwapi.h"
-//#include "winerror.h"
-#include <objbase.h>
+#include "wine/debug.h"
+#include "windef.h"
+#include "winbase.h"
+#include "winreg.h"
+#include "winuser.h"
+#include "shlwapi.h"
+#include "winerror.h"
+#include "objbase.h"
-//#include "wine/unicode.h"
+#include "wine/unicode.h"
-#include <msctf.h>
+#include "msctf.h"
#include "msctf_internal.h"
WINE_DEFAULT_DEBUG_CHANNEL(msctf);
ITfContext* contextStack[2]; /* limit of 2 contexts */
ITfThreadMgrEventSink* ThreadMgrSink;
+
+ struct list TransitoryExtensionSink;
} DocumentMgr;
typedef struct tagEnumTfContext {
return CONTAINING_RECORD(iface, DocumentMgr, ITfSource_iface);
}
-static inline EnumTfContext *impl_from_IEnumTfContexts(IEnumTfContexts *iface)\
+static inline EnumTfContext *impl_from_IEnumTfContexts(IEnumTfContexts *iface)
{
return CONTAINING_RECORD(iface, EnumTfContext, IEnumTfContexts_iface);
}
ITfContext_Release(This->contextStack[0]);
if (This->contextStack[1])
ITfContext_Release(This->contextStack[1]);
+ free_sinks(&This->TransitoryExtensionSink);
CompartmentMgr_Destructor(This->CompartmentMgr);
HeapFree(GetProcessHeap(),0,This);
}
if (IsEqualIID(iid, &IID_IUnknown) || IsEqualIID(iid, &IID_ITfDocumentMgr))
{
- *ppvOut = This;
+ *ppvOut = &This->ITfDocumentMgr_iface;
}
else if (IsEqualIID(iid, &IID_ITfSource))
{
if (*ppvOut)
{
- IUnknown_AddRef(iface);
+ ITfDocumentMgr_AddRef(iface);
return S_OK;
}
if (This->contextStack[1]) /* FUll */
return TF_E_STACKFULL;
- if (!pic || FAILED(IUnknown_QueryInterface(pic,&IID_ITfContext,(LPVOID*) &check)))
+ if (!pic || FAILED(ITfContext_QueryInterface(pic,&IID_ITfContext,(LPVOID*) &check)))
return E_INVALIDARG;
if (This->contextStack[0] == NULL)
if (dwFlags == TF_POPF_ALL)
{
- if (This->contextStack[0])
- {
- ITfThreadMgrEventSink_OnPopContext(This->ThreadMgrSink,This->contextStack[0]);
- ITfContext_Release(This->contextStack[0]);
- Context_Uninitialize(This->contextStack[0]);
- }
- if (This->contextStack[1])
- {
- ITfThreadMgrEventSink_OnPopContext(This->ThreadMgrSink,This->contextStack[1]);
- ITfContext_Release(This->contextStack[1]);
- Context_Uninitialize(This->contextStack[1]);
- }
- This->contextStack[0] = This->contextStack[1] = NULL;
+ int i;
+
+ for (i = 0; i < sizeof(This->contextStack)/sizeof(This->contextStack[0]); i++)
+ if (This->contextStack[i])
+ {
+ ITfThreadMgrEventSink_OnPopContext(This->ThreadMgrSink, This->contextStack[i]);
+ Context_Uninitialize(This->contextStack[i]);
+ ITfContext_Release(This->contextStack[i]);
+ This->contextStack[i] = NULL;
+ }
+
ITfThreadMgrEventSink_OnUninitDocumentMgr(This->ThreadMgrSink, iface);
return S_OK;
}
return E_FAIL;
ITfThreadMgrEventSink_OnPopContext(This->ThreadMgrSink,This->contextStack[0]);
- ITfContext_Release(This->contextStack[0]);
Context_Uninitialize(This->contextStack[0]);
+ ITfContext_Release(This->contextStack[0]);
This->contextStack[0] = This->contextStack[1];
This->contextStack[1] = NULL;
return EnumTfContext_Constructor(This, ppEnum);
}
-static const ITfDocumentMgrVtbl DocumentMgr_DocumentMgrVtbl =
+static const ITfDocumentMgrVtbl DocumentMgrVtbl =
{
DocumentMgr_QueryInterface,
DocumentMgr_AddRef,
DocumentMgr_Release,
-
DocumentMgr_CreateContext,
DocumentMgr_Push,
DocumentMgr_Pop,
DocumentMgr_EnumContexts
};
-
-static HRESULT WINAPI Source_QueryInterface(ITfSource *iface, REFIID iid, LPVOID *ppvOut)
+static HRESULT WINAPI DocumentMgrSource_QueryInterface(ITfSource *iface, REFIID iid, LPVOID *ppvOut)
{
DocumentMgr *This = impl_from_ITfSource(iface);
- return DocumentMgr_QueryInterface(&This->ITfDocumentMgr_iface, iid, *ppvOut);
+ return ITfDocumentMgr_QueryInterface(&This->ITfDocumentMgr_iface, iid, ppvOut);
}
-static ULONG WINAPI Source_AddRef(ITfSource *iface)
+static ULONG WINAPI DocumentMgrSource_AddRef(ITfSource *iface)
{
DocumentMgr *This = impl_from_ITfSource(iface);
- return DocumentMgr_AddRef(&This->ITfDocumentMgr_iface);
+ return ITfDocumentMgr_AddRef(&This->ITfDocumentMgr_iface);
}
-static ULONG WINAPI Source_Release(ITfSource *iface)
+static ULONG WINAPI DocumentMgrSource_Release(ITfSource *iface)
{
DocumentMgr *This = impl_from_ITfSource(iface);
- return DocumentMgr_Release(&This->ITfDocumentMgr_iface);
+ return ITfDocumentMgr_Release(&This->ITfDocumentMgr_iface);
}
/*****************************************************
REFIID riid, IUnknown *punk, DWORD *pdwCookie)
{
DocumentMgr *This = impl_from_ITfSource(iface);
- FIXME("STUB:(%p)\n",This);
+
+ TRACE("(%p) %s %p %p\n", This, debugstr_guid(riid), punk, pdwCookie);
+
+ if (!riid || !punk || !pdwCookie)
+ return E_INVALIDARG;
+
+ if (IsEqualIID(riid, &IID_ITfTransitoryExtensionSink))
+ {
+ WARN("semi-stub for ITfTransitoryExtensionSink: callback won't be used.\n");
+ return advise_sink(&This->TransitoryExtensionSink, &IID_ITfTransitoryExtensionSink,
+ COOKIE_MAGIC_DMSINK, punk, pdwCookie);
+ }
+
+ FIXME("(%p) Unhandled Sink: %s\n",This,debugstr_guid(riid));
return E_NOTIMPL;
}
static HRESULT WINAPI DocumentMgrSource_UnadviseSink(ITfSource *iface, DWORD pdwCookie)
{
DocumentMgr *This = impl_from_ITfSource(iface);
- FIXME("STUB:(%p)\n",This);
- return E_NOTIMPL;
+
+ TRACE("(%p) %x\n",This,pdwCookie);
+
+ if (get_Cookie_magic(pdwCookie)!=COOKIE_MAGIC_DMSINK)
+ return E_INVALIDARG;
+
+ return unadvise_sink(pdwCookie);
}
-static const ITfSourceVtbl DocumentMgr_SourceVtbl =
+static const ITfSourceVtbl DocumentMgrSourceVtbl =
{
- Source_QueryInterface,
- Source_AddRef,
- Source_Release,
-
+ DocumentMgrSource_QueryInterface,
+ DocumentMgrSource_AddRef,
+ DocumentMgrSource_Release,
DocumentMgrSource_AdviseSink,
DocumentMgrSource_UnadviseSink,
};
if (This == NULL)
return E_OUTOFMEMORY;
- This->ITfDocumentMgr_iface.lpVtbl = &DocumentMgr_DocumentMgrVtbl;
- This->ITfSource_iface.lpVtbl = &DocumentMgr_SourceVtbl;
+ This->ITfDocumentMgr_iface.lpVtbl = &DocumentMgrVtbl;
+ This->ITfSource_iface.lpVtbl = &DocumentMgrSourceVtbl;
This->refCount = 1;
This->ThreadMgrSink = ThreadMgrSink;
+ list_init(&This->TransitoryExtensionSink);
- CompartmentMgr_Constructor((IUnknown*)This, &IID_IUnknown, (IUnknown**)&This->CompartmentMgr);
+ CompartmentMgr_Constructor((IUnknown*)&This->ITfDocumentMgr_iface, &IID_IUnknown, (IUnknown**)&This->CompartmentMgr);
- TRACE("returning %p\n", This);
*ppOut = &This->ITfDocumentMgr_iface;
+ TRACE("returning %p\n", *ppOut);
return S_OK;
}
if (IsEqualIID(iid, &IID_IUnknown) || IsEqualIID(iid, &IID_IEnumTfContexts))
{
- *ppvOut = This;
+ *ppvOut = &This->IEnumTfContexts_iface;
}
if (*ppvOut)
{
- IUnknown_AddRef(iface);
+ IEnumTfContexts_AddRef(iface);
return S_OK;
}
This->refCount = 1;
This->docmgr = mgr;
- TRACE("returning %p\n", This);
*ppOut = &This->IEnumTfContexts_iface;
+ TRACE("returning %p\n", *ppOut);
return S_OK;
}