Alistair Leslie-Hughes : comsvcs: Add DispenserManager stubbed interface.

Alexandre Julliard julliard at winehq.org
Wed Aug 29 16:10:45 CDT 2018


Module: wine
Branch: master
Commit: 9b9b4c0dda66f4f950df489bb982b2ebbc4bbc31
URL:    https://source.winehq.org/git/wine.git/?a=commit;h=9b9b4c0dda66f4f950df489bb982b2ebbc4bbc31

Author: Alistair Leslie-Hughes <leslie_alistair at hotmail.com>
Date:   Wed Aug 29 01:30:04 2018 +0000

comsvcs: Add DispenserManager stubbed interface.

Wine-Bug: https://bugs.winehq.org/show_bug.cgi?id=42998
Signed-off-by: Alistair Leslie-Hughes <leslie_alistair at hotmail.com>
Signed-off-by: Alexandre Julliard <julliard at winehq.org>

---

 dlls/comsvcs/Makefile.in |   2 +-
 dlls/comsvcs/main.c      | 167 ++++++++++++++++++++++++++++++++++++++++++++++-
 2 files changed, 165 insertions(+), 4 deletions(-)

diff --git a/dlls/comsvcs/Makefile.in b/dlls/comsvcs/Makefile.in
index bd71e7d..b01c4f2 100644
--- a/dlls/comsvcs/Makefile.in
+++ b/dlls/comsvcs/Makefile.in
@@ -1,6 +1,6 @@
 MODULE    = comsvcs.dll
 IMPORTLIB = comsvcs
-IMPORTS   = ole32
+IMPORTS   = ole32 uuid
 
 C_SRCS = \
 	main.c
diff --git a/dlls/comsvcs/main.c b/dlls/comsvcs/main.c
index 3fc69de..6b7ec14 100644
--- a/dlls/comsvcs/main.c
+++ b/dlls/comsvcs/main.c
@@ -28,13 +28,120 @@
 #include "winbase.h"
 #include "ole2.h"
 #include "rpcproxy.h"
-
+#include "comsvcs.h"
+#include "wine/heap.h"
 #include "wine/debug.h"
 
 WINE_DEFAULT_DEBUG_CHANNEL(comsvcs);
 
 static HINSTANCE COMSVCS_hInstance;
 
+typedef struct dispensermanager
+{
+    IDispenserManager IDispenserManager_iface;
+    LONG ref;
+
+} dispensermanager;
+
+static inline dispensermanager *impl_from_IDispenserManager(IDispenserManager *iface)
+{
+    return CONTAINING_RECORD(iface, dispensermanager, IDispenserManager_iface);
+}
+
+static HRESULT WINAPI dismanager_QueryInterface(IDispenserManager *iface, REFIID riid, void **object)
+{
+    dispensermanager *This = impl_from_IDispenserManager(iface);
+
+    TRACE("(%p)->(%s %p)\n", This, debugstr_guid(riid), object);
+
+    *object = NULL;
+
+    if (IsEqualGUID(riid, &IID_IUnknown) ||
+        IsEqualGUID(riid, &IID_IDispenserManager))
+    {
+        *object = &This->IDispenserManager_iface;
+        IUnknown_AddRef( (IUnknown*)*object);
+
+        return S_OK;
+    }
+
+    WARN("(%p)->(%s,%p),not found\n",This,debugstr_guid(riid),object);
+    return E_NOINTERFACE;
+}
+
+static ULONG WINAPI dismanager_AddRef(IDispenserManager *iface)
+{
+    dispensermanager *This = impl_from_IDispenserManager(iface);
+    ULONG ref = InterlockedIncrement(&This->ref);
+    TRACE("(%p)->(%d)\n", This, ref);
+    return ref;
+}
+
+static ULONG WINAPI dismanager_Release(IDispenserManager *iface)
+{
+    dispensermanager *This = impl_from_IDispenserManager(iface);
+    ULONG ref = InterlockedDecrement(&This->ref);
+    TRACE("(%p)->(%d)\n", This, ref);
+
+    if (!ref)
+    {
+       heap_free(This);
+    }
+
+    return ref;
+}
+
+static HRESULT WINAPI dismanager_RegisterDispenser(IDispenserManager *iface, IDispenserDriver *driver,
+                        LPCOLESTR name, IHolder **dispenser)
+{
+    dispensermanager *This = impl_from_IDispenserManager(iface);
+
+    FIXME("(%p)->(%p, %s, %p) stub\n", This, driver, debugstr_w(name), dispenser);
+
+    return E_NOTIMPL;
+}
+
+static HRESULT WINAPI dismanager_GetContext(IDispenserManager *iface, INSTID *id, TRANSID *transid)
+{
+    dispensermanager *This = impl_from_IDispenserManager(iface);
+
+    FIXME("(%p)->(%p, %p) stub\n", This, id, transid);
+
+    return E_NOTIMPL;
+}
+
+struct IDispenserManagerVtbl dismanager_vtbl =
+{
+    dismanager_QueryInterface,
+    dismanager_AddRef,
+    dismanager_Release,
+    dismanager_RegisterDispenser,
+    dismanager_GetContext
+};
+
+static HRESULT WINAPI comsvcscf_CreateInstance(IClassFactory *cf,IUnknown* outer, REFIID riid,void **object)
+{
+    dispensermanager *dismanager;
+    HRESULT ret;
+
+    TRACE("(%p %s %p)\n", outer, debugstr_guid(riid), object);
+
+    dismanager = heap_alloc(sizeof(*dismanager));
+    if (!dismanager)
+    {
+        *object = NULL;
+        return E_OUTOFMEMORY;
+    }
+
+    dismanager->IDispenserManager_iface.lpVtbl = &dismanager_vtbl;
+    dismanager->ref = 1;
+
+    ret = dismanager_QueryInterface(&dismanager->IDispenserManager_iface, riid, object);
+    dismanager_Release(&dismanager->IDispenserManager_iface);
+
+    return ret;
+}
+
 BOOL WINAPI DllMain(HINSTANCE hinst, DWORD reason, LPVOID lpv)
 {
     switch(reason)
@@ -49,13 +156,67 @@ BOOL WINAPI DllMain(HINSTANCE hinst, DWORD reason, LPVOID lpv)
     return TRUE;
 }
 
+static HRESULT WINAPI comsvcscf_QueryInterface(IClassFactory *iface, REFIID riid, void **ppv )
+{
+    *ppv = NULL;
+
+    if(IsEqualGUID(&IID_IUnknown, riid)) {
+        TRACE("(%p)->(IID_IUnknown %p)\n", iface, ppv);
+        *ppv = iface;
+    }else if(IsEqualGUID(&IID_IClassFactory, riid)) {
+        TRACE("(%p)->(IID_IClassFactory %p)\n", iface, ppv);
+        *ppv = iface;
+    }
+
+    if(*ppv) {
+        IUnknown_AddRef((IUnknown*)*ppv);
+        return S_OK;
+    }
+
+    WARN("(%p)->(%s %p)\n", iface, debugstr_guid(riid), ppv);
+    return E_NOINTERFACE;
+}
+
+static ULONG WINAPI comsvcscf_AddRef(IClassFactory *iface )
+{
+    TRACE("(%p)\n", iface);
+    return 2;
+}
+
+static ULONG WINAPI comsvcscf_Release(IClassFactory *iface )
+{
+    TRACE("(%p)\n", iface);
+    return 1;
+}
+
+static HRESULT WINAPI comsvcscf_LockServer(IClassFactory *iface, BOOL fLock)
+{
+    TRACE("(%p)->(%x)\n", iface, fLock);
+    return S_OK;
+}
+
+static const struct IClassFactoryVtbl comsvcscf_vtbl =
+{
+    comsvcscf_QueryInterface,
+    comsvcscf_AddRef,
+    comsvcscf_Release,
+    comsvcscf_CreateInstance,
+    comsvcscf_LockServer
+};
+
+static IClassFactory DispenserManageFactory = { &comsvcscf_vtbl };
+
 /******************************************************************
  * DllGetClassObject
  */
-HRESULT WINAPI DllGetClassObject(REFCLSID rclsid, REFIID iid, LPVOID *ppv)
+HRESULT WINAPI DllGetClassObject(REFCLSID rclsid, REFIID riid, void **ppv)
 {
-    FIXME("(%s,%s,%p) stub\n", debugstr_guid(rclsid), debugstr_guid(iid), ppv);
+    if(IsEqualGUID(&CLSID_DispenserManager, rclsid)) {
+        TRACE("(CLSID_DispenserManager %s %p)\n", debugstr_guid(riid), ppv);
+        return IClassFactory_QueryInterface(&DispenserManageFactory, riid, ppv);
+    }
 
+    FIXME("%s %s %p\n", debugstr_guid(rclsid), debugstr_guid(riid), ppv);
     return CLASS_E_CLASSNOTAVAILABLE;
 }
 




More information about the wine-cvs mailing list