[PATCH 1/2] packager.dll: Add stub Packager implementation
Andrew Eikum
aeikum at codeweavers.com
Tue Jun 17 08:22:32 CDT 2014
---
configure.ac | 1 +
dlls/packager/Makefile.in | 8 +
dlls/packager/packager.rc | 24 +++
dlls/packager/packager.rgs | 15 ++
dlls/packager/packager.spec | 4 +
dlls/packager/packager_classes.idl | 26 +++
dlls/packager/packager_main.c | 369 +++++++++++++++++++++++++++++++++++++
7 files changed, 447 insertions(+)
create mode 100644 dlls/packager/Makefile.in
create mode 100644 dlls/packager/packager.rc
create mode 100644 dlls/packager/packager.rgs
create mode 100644 dlls/packager/packager.spec
create mode 100644 dlls/packager/packager_classes.idl
create mode 100644 dlls/packager/packager_main.c
diff --git a/configure.ac b/configure.ac
index eccf19c..f0a94c9 100644
--- a/configure.ac
+++ b/configure.ac
@@ -3075,6 +3075,7 @@ WINE_CONFIG_DLL(openal32)
WINE_CONFIG_DLL(opencl)
WINE_CONFIG_DLL(opengl32,,[implib])
WINE_CONFIG_TEST(dlls/opengl32/tests)
+WINE_CONFIG_DLL(packager)
WINE_CONFIG_DLL(pdh,,[implib])
WINE_CONFIG_TEST(dlls/pdh/tests)
WINE_CONFIG_DLL(photometadatahandler)
diff --git a/dlls/packager/Makefile.in b/dlls/packager/Makefile.in
new file mode 100644
index 0000000..ffbc2dc
--- /dev/null
+++ b/dlls/packager/Makefile.in
@@ -0,0 +1,8 @@
+MODULE = packager.dll
+IMPORTS = uuid
+
+C_SRCS = \
+ packager_main.c
+
+RC_SRCS = packager.rc
+IDL_SRCS = packager_classes.idl
diff --git a/dlls/packager/packager.rc b/dlls/packager/packager.rc
new file mode 100644
index 0000000..30a595e
--- /dev/null
+++ b/dlls/packager/packager.rc
@@ -0,0 +1,24 @@
+/*
+ * Copyright 2014 Andrew Eikum for CodeWeavers
+ *
+ * This library is free software; you can redistribute it and/or
+ * modify it under the terms of the GNU Lesser General Public
+ * License as published by the Free Software Foundation; either
+ * version 2.1 of the License, or (at your option) any later version.
+ *
+ * This library is distributed in the hope that it will be useful,
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
+ * Lesser General Public License for more details.
+ *
+ * You should have received a copy of the GNU Lesser General Public
+ * License along with this library; if not, write to the Free Software
+ * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301, USA
+ */
+
+#include <windef.h>
+
+LANGUAGE LANG_NEUTRAL, SUBLANG_NEUTRAL
+
+/* @makedep: packager.rgs */
+1 WINE_REGISTRY packager.rgs
diff --git a/dlls/packager/packager.rgs b/dlls/packager/packager.rgs
new file mode 100644
index 0000000..44d6676
--- /dev/null
+++ b/dlls/packager/packager.rgs
@@ -0,0 +1,15 @@
+HKCR
+{
+ NoRemove CLSID
+ {
+ NoRemove '{0003000C-0000-0000-C000-000000000046}'
+ {
+ TreatAs = s '{F20DA720-C02F-11CE-927B-0800095AE340}'
+ NotInsertable
+ }
+ NoRemove '{F20DA720-C02F-11CE-927B-0800095AE340}'
+ {
+ Insertable
+ }
+ }
+}
diff --git a/dlls/packager/packager.spec b/dlls/packager/packager.spec
new file mode 100644
index 0000000..5baed04
--- /dev/null
+++ b/dlls/packager/packager.spec
@@ -0,0 +1,4 @@
+@ stdcall DllCanUnloadNow()
+@ stdcall DllGetClassObject(ptr ptr ptr)
+@ stdcall DllRegisterServer()
+@ stdcall DllUnregisterServer()
diff --git a/dlls/packager/packager_classes.idl b/dlls/packager/packager_classes.idl
new file mode 100644
index 0000000..d57ac29
--- /dev/null
+++ b/dlls/packager/packager_classes.idl
@@ -0,0 +1,26 @@
+/*
+ * Copyright 2014 Andrew Eikum for CodeWeavers
+ *
+ * This library is free software; you can redistribute it and/or
+ * modify it under the terms of the GNU Lesser General Public
+ * License as published by the Free Software Foundation; either
+ * version 2.1 of the License, or (at your option) any later version.
+ *
+ * This library is distributed in the hope that it will be useful,
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
+ * Lesser General Public License for more details.
+ *
+ * You should have received a copy of the GNU Lesser General Public
+ * License along with this library; if not, write to the Free Software
+ * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301, USA
+ */
+
+#pragma makedep register
+
+[
+ helpstring("Package"),
+ threading(apartment),
+ uuid(F20DA720-C02F-11CE-927B-0800095AE340)
+]
+coclass Package { interface IOleObject; }
diff --git a/dlls/packager/packager_main.c b/dlls/packager/packager_main.c
new file mode 100644
index 0000000..c8fdc0c
--- /dev/null
+++ b/dlls/packager/packager_main.c
@@ -0,0 +1,369 @@
+/*
+ * Copyright 2014 Andrew Eikum for CodeWeavers
+ *
+ * This library is free software; you can redistribute it and/or
+ * modify it under the terms of the GNU Lesser General Public
+ * License as published by the Free Software Foundation; either
+ * version 2.1 of the License, or (at your option) any later version.
+ *
+ * This library is distributed in the hope that it will be useful,
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
+ * Lesser General Public License for more details.
+ *
+ * You should have received a copy of the GNU Lesser General Public
+ * License along with this library; if not, write to the Free Software
+ * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301, USA
+ */
+
+#include "config.h"
+
+#include <stdarg.h>
+
+#define COBJMACROS
+#include "initguid.h"
+#include "windef.h"
+#include "winbase.h"
+#include "ole2.h"
+#include "rpcproxy.h"
+#include "wine/debug.h"
+
+#include "packager_classes.h"
+
+WINE_DEFAULT_DEBUG_CHANNEL(packager);
+
+static HINSTANCE g_instance;
+
+struct Package {
+ IOleObject IOleObject_iface;
+
+ LONG ref;
+};
+
+static inline struct Package *impl_from_IOleObject(IOleObject *iface)
+{
+ return CONTAINING_RECORD(iface, struct Package, IOleObject_iface);
+}
+
+static HRESULT WINAPI OleObject_QueryInterface(IOleObject *iface, REFIID riid, void **obj)
+{
+ struct Package *This = impl_from_IOleObject(iface);
+
+ if(IsEqualGUID(riid, &IID_IUnknown) ||
+ IsEqualGUID(riid, &IID_IOleObject)) {
+ TRACE("(%p)->(IID_IOleObject, %p)\n", This, obj);
+ *obj = &This->IOleObject_iface;
+ }else {
+ FIXME("(%p)->(%s, %p)\n", This, debugstr_guid(riid), obj);
+ *obj = NULL;
+ return E_NOINTERFACE;
+ }
+
+ IUnknown_AddRef((IUnknown*)*obj);
+ return S_OK;
+}
+
+static ULONG WINAPI OleObject_AddRef(IOleObject *iface)
+{
+ struct Package *This = impl_from_IOleObject(iface);
+ LONG ref = InterlockedIncrement(&This->ref);
+
+ TRACE("(%p) ref=%d\n", This, ref);
+
+ return ref;
+}
+
+static ULONG WINAPI OleObject_Release(IOleObject *iface)
+{
+ struct Package *This = impl_from_IOleObject(iface);
+ LONG ref = InterlockedDecrement(&This->ref);
+
+ TRACE("(%p) ref=%d\n", This, ref);
+
+ if(!ref)
+ HeapFree(GetProcessHeap(), 0, This);
+
+ return ref;
+}
+
+static HRESULT WINAPI OleObject_SetClientSite(IOleObject *iface, IOleClientSite *pClientSite)
+{
+ struct Package *This = impl_from_IOleObject(iface);
+ FIXME("(%p)->(%p)\n", This, pClientSite);
+ return E_NOTIMPL;
+}
+
+static HRESULT WINAPI OleObject_GetClientSite(IOleObject *iface, IOleClientSite **ppClientSite)
+{
+ struct Package *This = impl_from_IOleObject(iface);
+ FIXME("(%p)->(%p)\n", This, ppClientSite);
+ return E_NOTIMPL;
+}
+
+static HRESULT WINAPI OleObject_SetHostNames(IOleObject *iface, LPCOLESTR szContainerApp, LPCOLESTR szContainerObj)
+{
+ struct Package *This = impl_from_IOleObject(iface);
+ FIXME("(%p)->(%s, %s)\n", This, debugstr_w(szContainerApp), debugstr_w(szContainerObj));
+ return E_NOTIMPL;
+}
+
+static HRESULT WINAPI OleObject_Close(IOleObject *iface, DWORD dwSaveOption)
+{
+ struct Package *This = impl_from_IOleObject(iface);
+ FIXME("(%p)->(0x%x)\n", This, dwSaveOption);
+ return E_NOTIMPL;
+}
+
+static HRESULT WINAPI OleObject_SetMoniker(IOleObject *iface, DWORD dwWhichMoniker, IMoniker *pmk)
+{
+ struct Package *This = impl_from_IOleObject(iface);
+ FIXME("(%p)->(%d, %p)\n", This, dwWhichMoniker, pmk);
+ return E_NOTIMPL;
+}
+
+static HRESULT WINAPI OleObject_GetMoniker(IOleObject *iface, DWORD dwAssign, DWORD dwWhichMoniker, IMoniker **ppmk)
+{
+ struct Package *This = impl_from_IOleObject(iface);
+ FIXME("(%p)->(%d, %d, %p)\n", This, dwAssign, dwWhichMoniker, ppmk);
+ return E_NOTIMPL;
+}
+
+static HRESULT WINAPI OleObject_InitFromData(IOleObject *iface, IDataObject *pDataObject, BOOL fCreation,
+ DWORD dwReserved)
+{
+ struct Package *This = impl_from_IOleObject(iface);
+ FIXME("(%p)->(%p, 0x%x, %d)\n", This, pDataObject, fCreation, dwReserved);
+ return E_NOTIMPL;
+}
+
+static HRESULT WINAPI OleObject_GetClipboardData(IOleObject *iface, DWORD dwReserved, IDataObject **ppDataObject)
+{
+ struct Package *This = impl_from_IOleObject(iface);
+ FIXME("(%p)->(%d, %p)\n", This, dwReserved, ppDataObject);
+ return E_NOTIMPL;
+}
+
+static HRESULT WINAPI OleObject_DoVerb(IOleObject *iface, LONG iVerb, LPMSG lpmsg, IOleClientSite *pActiveSite,
+ LONG lindex, HWND hwndParent, LPCRECT lprcPosRect)
+{
+ struct Package *This = impl_from_IOleObject(iface);
+ FIXME("(%p)->(%d)\n", This, iVerb);
+ return E_NOTIMPL;
+}
+
+static HRESULT WINAPI OleObject_EnumVerbs(IOleObject *iface, IEnumOLEVERB **ppEnumOleVerb)
+{
+ struct Package *This = impl_from_IOleObject(iface);
+ FIXME("(%p)->(%p)\n", This, ppEnumOleVerb);
+ return E_NOTIMPL;
+}
+
+static HRESULT WINAPI OleObject_Update(IOleObject *iface)
+{
+ struct Package *This = impl_from_IOleObject(iface);
+ FIXME("(%p)\n", This);
+ return E_NOTIMPL;
+}
+
+static HRESULT WINAPI OleObject_IsUpToDate(IOleObject *iface)
+{
+ struct Package *This = impl_from_IOleObject(iface);
+ FIXME("(%p)\n", This);
+ return E_NOTIMPL;
+}
+
+static HRESULT WINAPI OleObject_GetUserClassID(IOleObject *iface, CLSID *pClsid)
+{
+ struct Package *This = impl_from_IOleObject(iface);
+ FIXME("(%p)->(%p)\n", This, pClsid);
+ return E_NOTIMPL;
+}
+
+static HRESULT WINAPI OleObject_GetUserType(IOleObject *iface, DWORD dwFormOfType, LPOLESTR *pszUserType)
+{
+ struct Package *This = impl_from_IOleObject(iface);
+ FIXME("(%p)->(%d, %p)\n", This, dwFormOfType, pszUserType);
+ return E_NOTIMPL;
+}
+
+static HRESULT WINAPI OleObject_SetExtent(IOleObject *iface, DWORD dwDrawAspect, SIZEL *psizel)
+{
+ struct Package *This = impl_from_IOleObject(iface);
+ FIXME("(%p)->(%d, %p)\n", This, dwDrawAspect, psizel);
+ return E_NOTIMPL;
+}
+
+static HRESULT WINAPI OleObject_GetExtent(IOleObject *iface, DWORD dwDrawAspect, SIZEL *psizel)
+{
+ struct Package *This = impl_from_IOleObject(iface);
+ FIXME("(%p)->(%d, %p)\n", This, dwDrawAspect, psizel);
+ return E_NOTIMPL;
+}
+
+static HRESULT WINAPI OleObject_Advise(IOleObject *iface, IAdviseSink *pAdvSink, DWORD *pdwConnection)
+{
+ struct Package *This = impl_from_IOleObject(iface);
+ FIXME("(%p)->(%p, %p)\n", This, pAdvSink, pdwConnection);
+ return E_NOTIMPL;
+}
+
+static HRESULT WINAPI OleObject_Unadvise(IOleObject *iface, DWORD dwConnection)
+{
+ struct Package *This = impl_from_IOleObject(iface);
+ FIXME("(%p)->(%d)\n", This, dwConnection);
+ return E_NOTIMPL;
+}
+
+static HRESULT WINAPI OleObject_EnumAdvise(IOleObject *iface, IEnumSTATDATA **ppenumAdvise)
+{
+ struct Package *This = impl_from_IOleObject(iface);
+ FIXME("(%p)->(%p)\n", This, ppenumAdvise);
+ return E_NOTIMPL;
+}
+
+static HRESULT WINAPI OleObject_GetMiscStatus(IOleObject *iface, DWORD dwAspect, DWORD *pdwStatus)
+{
+ struct Package *This = impl_from_IOleObject(iface);
+ FIXME("(%p)->(%d, %p)\n", This, dwAspect, pdwStatus);
+ return E_NOTIMPL;
+}
+
+static HRESULT WINAPI OleObject_SetColorScheme(IOleObject *iface, LOGPALETTE *pLogpal)
+{
+ struct Package *This = impl_from_IOleObject(iface);
+ FIXME("(%p)->(%p)\n", This, pLogpal);
+ return E_NOTIMPL;
+}
+
+static const IOleObjectVtbl OleObject_Vtbl = {
+ OleObject_QueryInterface,
+ OleObject_AddRef,
+ OleObject_Release,
+ OleObject_SetClientSite,
+ OleObject_GetClientSite,
+ OleObject_SetHostNames,
+ OleObject_Close,
+ OleObject_SetMoniker,
+ OleObject_GetMoniker,
+ OleObject_InitFromData,
+ OleObject_GetClipboardData,
+ OleObject_DoVerb,
+ OleObject_EnumVerbs,
+ OleObject_Update,
+ OleObject_IsUpToDate,
+ OleObject_GetUserClassID,
+ OleObject_GetUserType,
+ OleObject_SetExtent,
+ OleObject_GetExtent,
+ OleObject_Advise,
+ OleObject_Unadvise,
+ OleObject_EnumAdvise,
+ OleObject_GetMiscStatus,
+ OleObject_SetColorScheme
+};
+
+static HRESULT WINAPI PackageCF_QueryInterface(IClassFactory *iface, REFIID riid, void **obj)
+{
+ TRACE("(static)->(%s, %p)\n", debugstr_guid(riid), obj);
+
+ if(IsEqualGUID(&IID_IUnknown, riid) ||
+ IsEqualGUID(&IID_IClassFactory, riid))
+ *obj = iface;
+ else
+ *obj = NULL;
+
+ if(*obj){
+ IUnknown_AddRef((IUnknown*)*obj);
+ return S_OK;
+ }
+
+ FIXME("Unknown interface: %s\n", debugstr_guid(riid));
+ return E_NOINTERFACE;
+}
+
+static ULONG WINAPI PackageCF_AddRef(IClassFactory *iface)
+{
+ TRACE("(static)\n");
+ return 2;
+}
+
+static ULONG WINAPI PackageCF_Release(IClassFactory *iface)
+{
+ TRACE("(static)\n");
+ return 1;
+}
+
+static HRESULT WINAPI PackageCF_CreateInstance(IClassFactory *iface, IUnknown *outer,
+ REFIID iid, void **obj)
+{
+ struct Package *package;
+
+ TRACE("(static)->(%p, %s, %p)\n", outer, wine_dbgstr_guid(iid), obj);
+
+ package = HeapAlloc(GetProcessHeap(), HEAP_ZERO_MEMORY, sizeof(*package));
+ if(!package)
+ return E_OUTOFMEMORY;
+
+ package->IOleObject_iface.lpVtbl = &OleObject_Vtbl;
+
+ return IOleObject_QueryInterface(&package->IOleObject_iface, iid, obj);
+}
+
+static HRESULT WINAPI PackageCF_LockServer(IClassFactory *iface, BOOL fLock)
+{
+ TRACE("(%p)->(%x)\n", iface, fLock);
+ return S_OK;
+}
+
+static const IClassFactoryVtbl PackageCF_Vtbl = {
+ PackageCF_QueryInterface,
+ PackageCF_AddRef,
+ PackageCF_Release,
+ PackageCF_CreateInstance,
+ PackageCF_LockServer
+};
+
+static IClassFactory PackageCF = {
+ &PackageCF_Vtbl
+};
+
+HRESULT WINAPI DllGetClassObject(REFCLSID clsid, REFIID iid, void **obj)
+{
+ TRACE("(%s, %s, %p)\n", wine_dbgstr_guid(clsid), wine_dbgstr_guid(iid), obj);
+
+ if(IsEqualGUID(clsid, &CLSID_Package))
+ return IClassFactory_QueryInterface(&PackageCF, iid, obj);
+
+ FIXME("Unknown CLSID: %s\n", wine_dbgstr_guid(clsid));
+
+ return CLASS_E_CLASSNOTAVAILABLE;
+}
+
+HRESULT WINAPI DllCanUnloadNow(void)
+{
+ return S_OK;
+}
+
+HRESULT WINAPI DllRegisterServer(void)
+{
+ return __wine_register_resources(g_instance);
+}
+
+HRESULT WINAPI DllUnregisterServer(void)
+{
+ return __wine_unregister_resources(g_instance);
+}
+
+BOOL WINAPI DllMain(HINSTANCE instance, DWORD reason, void *reserved)
+{
+ TRACE("(%p, %u, %p)\n", instance, reason, reserved);
+
+ switch(reason){
+ case DLL_PROCESS_ATTACH:
+ g_instance = instance;
+ DisableThreadLibraryCalls(instance);
+ break;
+ }
+
+ return TRUE;
+}
--
2.0.0
More information about the wine-patches
mailing list