Rob Shearman : atl: Add support for the registrar parameter of AtlModuleUpdateRegistryFromResourceD .

Alexandre Julliard julliard at wine.codeweavers.com
Wed Mar 21 17:02:47 CDT 2007


Module: wine
Branch: master
Commit: d51c1c7a04dc471068b3685d72fdd808c78b3fc3
URL:    http://source.winehq.org/git/wine.git/?a=commit;h=d51c1c7a04dc471068b3685d72fdd808c78b3fc3

Author: Rob Shearman <rob at codeweavers.com>
Date:   Wed Mar 21 09:30:27 2007 +0000

atl: Add support for the registrar parameter of AtlModuleUpdateRegistryFromResourceD.

---

 dlls/atl/registrar.c |   19 ++++++++-----------
 1 files changed, 8 insertions(+), 11 deletions(-)

diff --git a/dlls/atl/registrar.c b/dlls/atl/registrar.c
index 4282b40..f32ebb3 100644
--- a/dlls/atl/registrar.c
+++ b/dlls/atl/registrar.c
@@ -756,12 +756,12 @@ HRESULT WINAPI DllGetClassObject(REFCLSID clsid, REFIID riid, LPVOID *ppvObject)
 
 extern HINSTANCE hInst;
 
-static HRESULT do_register_dll_server(LPCOLESTR wszDll, LPCOLESTR wszId,
-                                      BOOL do_register, const struct _ATL_REGMAP_ENTRY* pMapEntries)
+static HRESULT do_register_dll_server(IRegistrar *pRegistrar, LPCOLESTR wszDll,
+                                      LPCOLESTR wszId, BOOL do_register,
+                                      const struct _ATL_REGMAP_ENTRY* pMapEntries)
 {
     WCHAR buf[MAX_PATH];
     HRESULT hres;
-    IRegistrar *pRegistrar;
     const struct _ATL_REGMAP_ENTRY *pMapEntry;
 
     static const WCHAR wszModule[] = {'M','O','D','U','L','E',0};
@@ -769,7 +769,9 @@ static HRESULT do_register_dll_server(LPCOLESTR wszDll, LPCOLESTR wszId,
     static const WCHAR wszCLSID_ATLRegistrar[] =
             {'C','L','S','I','D','_','A','T','L','R','e','g','i','s','t','r','a','r',0};
 
-    Registrar_create(NULL, &IID_IRegistrar, (void**)&pRegistrar);
+    if (!pRegistrar)
+        Registrar_create(NULL, &IID_IRegistrar, (void**)&pRegistrar);
+
     IRegistrar_AddReplacement(pRegistrar, wszModule, wszDll);
 
     for (pMapEntry = pMapEntries; pMapEntry && pMapEntry->szKey; pMapEntry++)
@@ -790,7 +792,7 @@ static HRESULT do_register_dll_server(LPCOLESTR wszDll, LPCOLESTR wszId,
 static HRESULT do_register_server(BOOL do_register)
 {
     static const WCHAR wszDll[] = {'a','t','l','.','d','l','l',0};
-    return do_register_dll_server(wszDll, MAKEINTRESOURCEW(101), do_register, NULL);
+    return do_register_dll_server(NULL, wszDll, MAKEINTRESOURCEW(101), do_register, NULL);
 }
 
 /***********************************************************************
@@ -806,11 +808,6 @@ HRESULT WINAPI AtlModuleUpdateRegistryFromResourceD(_ATL_MODULEW* pM, LPCOLESTR
      */
     WCHAR module_name[MAX_PATH];
 
-    if(pReg) {
-        FIXME("Registrar parameter not supported\n");
-        return E_FAIL;
-    }
-
     if(!GetModuleFileNameW(lhInst, module_name, MAX_PATH)) {
         FIXME("hinst %p: did not get module name\n",
         lhInst);
@@ -820,7 +817,7 @@ HRESULT WINAPI AtlModuleUpdateRegistryFromResourceD(_ATL_MODULEW* pM, LPCOLESTR
     TRACE("%p (%s), %s, %d, %p, %p\n", hInst, debugstr_w(module_name),
 	debugstr_w(lpszRes), bRegister, pMapEntries, pReg);
 
-    return do_register_dll_server(module_name, lpszRes, bRegister, pMapEntries);
+    return do_register_dll_server(pReg, module_name, lpszRes, bRegister, pMapEntries);
 }
 
 /***********************************************************************




More information about the wine-cvs mailing list