Alexandre Julliard : hlink: Convert dll registration to the IRegistrar mechanism.
Alexandre Julliard
julliard at winehq.org
Thu Dec 2 12:23:58 CST 2010
Module: wine
Branch: master
Commit: 61eb983313fe04813bc8c6f64162ca434e642e23
URL: http://source.winehq.org/git/wine.git/?a=commit;h=61eb983313fe04813bc8c6f64162ca434e642e23
Author: Alexandre Julliard <julliard at winehq.org>
Date: Thu Dec 2 14:40:00 2010 +0100
hlink: Convert dll registration to the IRegistrar mechanism.
---
dlls/hlink/Makefile.in | 2 +
dlls/hlink/hlink.spec | 2 +-
dlls/hlink/hlink_classes.idl | 36 +++++++++++++++++++++++++++++++
dlls/hlink/hlink_main.c | 48 ++++++++++-------------------------------
4 files changed, 51 insertions(+), 37 deletions(-)
diff --git a/dlls/hlink/Makefile.in b/dlls/hlink/Makefile.in
index 2bf15c7..a387802 100644
--- a/dlls/hlink/Makefile.in
+++ b/dlls/hlink/Makefile.in
@@ -9,4 +9,6 @@ C_SRCS = \
hlink_main.c \
link.c
+IDL_R_SRCS = hlink_classes.idl
+
@MAKE_DLL_RULES@
diff --git a/dlls/hlink/hlink.spec b/dlls/hlink/hlink.spec
index ca8144e..6a5bfdf 100644
--- a/dlls/hlink/hlink.spec
+++ b/dlls/hlink/hlink.spec
@@ -30,4 +30,4 @@
@ stdcall -private DllCanUnloadNow()
@ stdcall -private DllGetClassObject(ptr ptr ptr)
@ stdcall -private DllRegisterServer()
-# @ stub -private DllUnregisterServer
+@ stdcall -private DllUnregisterServer()
diff --git a/dlls/hlink/hlink_classes.idl b/dlls/hlink/hlink_classes.idl
new file mode 100644
index 0000000..98b5d32
--- /dev/null
+++ b/dlls/hlink/hlink_classes.idl
@@ -0,0 +1,36 @@
+/*
+ * COM Classes for hlink
+ *
+ * Copyright 2010 Alexandre Julliard
+ *
+ * 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
+ */
+
+[
+ threading(apartment),
+ uuid(79eac9d0-baf9-11ce-8c82-00aa004ba90b)
+]
+coclass StdHlink
+{
+ interface IHlink;
+ interface IPersistStream;
+ interface IDataObject;
+}
+
+[
+ threading(apartment),
+ uuid(79eac9d1-baf9-11ce-8c82-00aa004ba90b)
+]
+coclass StdHlinkBrowseContext { interface IHlinkBrowseContext; }
diff --git a/dlls/hlink/hlink_main.c b/dlls/hlink/hlink_main.c
index cda9683..0300fc0 100644
--- a/dlls/hlink/hlink_main.c
+++ b/dlls/hlink/hlink_main.c
@@ -21,12 +21,15 @@
#include "hlink_private.h"
#include "winreg.h"
+#include "rpcproxy.h"
#include "hlguids.h"
#include "wine/debug.h"
WINE_DEFAULT_DEBUG_CHANNEL(hlink);
+static HINSTANCE instance;
+
typedef HRESULT (CALLBACK *LPFNCREATEINSTANCE)(IUnknown*, REFIID, LPVOID*);
typedef struct
@@ -42,6 +45,7 @@ BOOL WINAPI DllMain(HINSTANCE hinstDLL, DWORD fdwReason, LPVOID lpvReserved)
switch (fdwReason)
{
case DLL_PROCESS_ATTACH:
+ instance = hinstDLL;
DisableThreadLibraryCalls(hinstDLL);
break;
case DLL_PROCESS_DETACH:
@@ -576,46 +580,18 @@ HRESULT WINAPI DllGetClassObject(REFCLSID rclsid, REFIID iid, LPVOID *ppv)
return IClassFactory_QueryInterface(pcf, iid, ppv);
}
-static HRESULT register_clsid(LPCGUID guid)
+/***********************************************************************
+ * DllRegisterServer (HLINK.@)
+ */
+HRESULT WINAPI DllRegisterServer(void)
{
- static const WCHAR clsid[] =
- {'C','L','S','I','D','\\',0};
- static const WCHAR ips[] =
- {'\\','I','n','p','r','o','c','S','e','r','v','e','r','3','2',0};
- static const WCHAR hlink[] =
- {'h','l','i','n','k','.','d','l','l',0};
- static const WCHAR threading_model[] =
- {'T','h','r','e','a','d','i','n','g','M','o','d','e','l',0};
- static const WCHAR apartment[] =
- {'A','p','a','r','t','m','e','n','t',0};
- WCHAR path[80];
- HKEY key = NULL;
- LONG r;
-
- lstrcpyW(path, clsid);
- StringFromGUID2(guid, &path[6], 80);
- lstrcatW(path, ips);
- r = RegCreateKeyW(HKEY_CLASSES_ROOT, path, &key);
- if (r != ERROR_SUCCESS)
- return E_FAIL;
-
- RegSetValueExW(key, NULL, 0, REG_SZ, (const BYTE *)hlink, sizeof hlink);
- RegSetValueExW(key, threading_model, 0, REG_SZ, (const BYTE *)apartment, sizeof apartment);
- RegCloseKey(key);
-
- return S_OK;
+ return __wine_register_resources( instance, NULL );
}
/***********************************************************************
- * DllRegisterServer (HLINK.@)
+ * DllUnregisterServer (HLINK.@)
*/
-HRESULT WINAPI DllRegisterServer(void)
+HRESULT WINAPI DllUnregisterServer(void)
{
- HRESULT r;
-
- r = register_clsid(&CLSID_StdHlink);
- if (SUCCEEDED(r))
- r = register_clsid(&CLSID_StdHlinkBrowseContext);
-
- return S_OK;
+ return __wine_unregister_resources( instance, NULL );
}
More information about the wine-cvs
mailing list