Module: wine Branch: master Commit: c11ad1eb48ac419af6599e432258d3bee5a20543 URL: http://source.winehq.org/git/wine.git/?a=commit;h=c11ad1eb48ac419af6599e4322...
Author: Rob Shearman rob@codeweavers.com Date: Wed Mar 21 09:29:48 2007 +0000
atl: Add support for the pMapEntries parameter to AtlModuleUpdateRegistryFromResourceD.
---
dlls/atl/registrar.c | 15 ++++++++++----- 1 files changed, 10 insertions(+), 5 deletions(-)
diff --git a/dlls/atl/registrar.c b/dlls/atl/registrar.c index 353e113..4282b40 100644 --- a/dlls/atl/registrar.c +++ b/dlls/atl/registrar.c @@ -756,11 +756,13 @@ 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) +static HRESULT do_register_dll_server(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}; static const WCHAR wszRegistry[] = {'R','E','G','I','S','T','R','Y',0}; @@ -770,6 +772,9 @@ static HRESULT do_register_dll_server(LPCOLESTR wszDll, LPCOLESTR wszId, BOOL do Registrar_create(NULL, &IID_IRegistrar, (void**)&pRegistrar); IRegistrar_AddReplacement(pRegistrar, wszModule, wszDll);
+ for (pMapEntry = pMapEntries; pMapEntry && pMapEntry->szKey; pMapEntry++) + IRegistrar_AddReplacement(pRegistrar, pMapEntry->szKey, pMapEntry->szData); + StringFromGUID2(&CLSID_ATLRegistrar, buf, sizeof(buf)/sizeof(buf[0])); IRegistrar_AddReplacement(pRegistrar, wszCLSID_ATLRegistrar, buf);
@@ -785,7 +790,7 @@ static HRESULT do_register_dll_server(LPCOLESTR wszDll, LPCOLESTR wszId, BOOL do 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); + return do_register_dll_server(wszDll, MAKEINTRESOURCEW(101), do_register, NULL); }
/*********************************************************************** @@ -801,8 +806,8 @@ HRESULT WINAPI AtlModuleUpdateRegistryFromResourceD(_ATL_MODULEW* pM, LPCOLESTR */ WCHAR module_name[MAX_PATH];
- if(pMapEntries || pReg) { - FIXME("MapEntries and Registrar parameter not supported\n"); + if(pReg) { + FIXME("Registrar parameter not supported\n"); return E_FAIL; }
@@ -815,7 +820,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); + return do_register_dll_server(module_name, lpszRes, bRegister, pMapEntries); }
/***********************************************************************