Jacek Caban : hlink: Added HlinkCreateExtensionServices implementation.

Alexandre Julliard julliard at winehq.org
Wed Nov 21 07:47:42 CST 2007


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

Author: Jacek Caban <jacek at codeweavers.com>
Date:   Wed Nov 21 11:35:00 2007 +0100

hlink: Added HlinkCreateExtensionServices implementation.

---

 dlls/hlink/Makefile.in  |    1 +
 dlls/hlink/extserv.c    |  185 +++++++++++++++++++++++++++++++++++++++++++++++
 dlls/hlink/hlink_main.c |   10 ---
 3 files changed, 186 insertions(+), 10 deletions(-)

diff --git a/dlls/hlink/Makefile.in b/dlls/hlink/Makefile.in
index d7ceff2..3d0262c 100644
--- a/dlls/hlink/Makefile.in
+++ b/dlls/hlink/Makefile.in
@@ -10,6 +10,7 @@ EXTRALIBS = -luuid
 
 C_SRCS = \
 	browse_ctx.c \
+	extserv.c \
 	hlink_main.c \
 	link.c
 
diff --git a/dlls/hlink/extserv.c b/dlls/hlink/extserv.c
new file mode 100644
index 0000000..d2abf2e
--- /dev/null
+++ b/dlls/hlink/extserv.c
@@ -0,0 +1,185 @@
+/*
+ * Copyright 2007 Jacek Caban 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 "hlink_private.h"
+
+#include "wine/debug.h"
+#include "wine/unicode.h"
+
+WINE_DEFAULT_DEBUG_CHANNEL(hlink);
+
+#define DEFINE_THIS(cls,ifc,iface) ((cls*)((BYTE*)(iface)-offsetof(cls,lp ## ifc ## Vtbl)))
+
+typedef struct {
+    const IUnknownVtbl        *lpIUnknownVtbl;
+    const IAuthenticateVtbl   *lpIAuthenticateVtbl;
+
+    LONG ref;
+    IUnknown *outer;
+
+    HWND hwnd;
+    LPWSTR username;
+    LPWSTR password;
+} ExtensionService;
+
+#define EXTSERVUNK(x)    ((IUnknown*)       &(x)->lpIUnknownVtbl)
+#define AUTHENTICATE(x)  ((IAuthenticate*)  &(x)->lpIAuthenticateVtbl)
+
+#define EXTSERVUNK_THIS(iface)  DEFINE_THIS(ExtensionService, IUnknown, iface)
+
+static HRESULT WINAPI ExtServUnk_QueryInterface(IUnknown *iface, REFIID riid, void **ppv)
+{
+    ExtensionService *This = EXTSERVUNK_THIS(iface);
+
+    *ppv = NULL;
+
+    if(IsEqualGUID(&IID_IUnknown, riid)) {
+        TRACE("(%p)->(IID_IUnknown %p)\n", This, ppv);
+        *ppv = EXTSERVUNK(This);
+    }else if(IsEqualGUID(&IID_IAuthenticate, riid)) {
+        TRACE("(%p)->(IID_IAuthenticate %p)\n", This, ppv);
+        *ppv = AUTHENTICATE(This);
+    }
+
+    if(*ppv) {
+        IUnknown_AddRef(EXTSERVUNK(This));
+        return S_OK;
+    }
+
+    FIXME("(%p)->(%s %p)\n", This, debugstr_guid(riid), ppv);
+    return E_NOINTERFACE;
+}
+
+static ULONG WINAPI ExtServUnk_AddRef(IUnknown *iface)
+{
+    ExtensionService *This = EXTSERVUNK_THIS(iface);
+    LONG ref = InterlockedIncrement(&This->ref);
+
+    TRACE("(%p) ref=%d\n", This, ref);
+
+    return ref;
+}
+
+static ULONG WINAPI ExtServUnk_Release(IUnknown *iface)
+{
+    ExtensionService *This = EXTSERVUNK_THIS(iface);
+    LONG ref = InterlockedDecrement(&This->ref);
+
+    TRACE("(%p) ref=%d\n", This, ref);
+
+    if(!ref) {
+        hlink_free(This->username);
+        hlink_free(This->password);
+        hlink_free(This);
+    }
+
+    return ref;
+}
+
+#undef EXTSERVUNK_THIS
+
+static const IUnknownVtbl ExtServUnkVtbl = {
+    ExtServUnk_QueryInterface,
+    ExtServUnk_AddRef,
+    ExtServUnk_Release
+};
+
+#define AUTHENTICATE_THIS(iface) DEFINE_THIS(ExtensionService, IAuthenticate, iface)
+
+static HRESULT WINAPI Authenticate_QueryInterface(IAuthenticate *iface, REFIID riid, void **ppv)
+{
+    ExtensionService *This = AUTHENTICATE_THIS(iface);
+    return IUnknown_QueryInterface(This->outer, riid, ppv);
+}
+
+static ULONG WINAPI Authenticate_AddRef(IAuthenticate *iface)
+{
+    ExtensionService *This = AUTHENTICATE_THIS(iface);
+    return IUnknown_AddRef(This->outer);
+}
+
+static ULONG WINAPI Authenticate_Release(IAuthenticate *iface)
+{
+    ExtensionService *This = AUTHENTICATE_THIS(iface);
+    return IUnknown_Release(This->outer);
+}
+
+static HRESULT WINAPI Authenticate_Authenticate(IAuthenticate *iface,
+        HWND *phwnd, LPWSTR *pszUsername, LPWSTR *pszPassword)
+{
+    ExtensionService *This = AUTHENTICATE_THIS(iface);
+
+    TRACE("(%p)->(%p %p %p)\n", This, phwnd, pszUsername, pszPassword);
+
+    if(!phwnd || !pszUsername || !pszPassword)
+        return E_INVALIDARG;
+
+    *phwnd = This->hwnd;
+    *pszUsername = hlink_co_strdupW(This->username);
+    *pszPassword = hlink_co_strdupW(This->password);
+
+    return S_OK;
+}
+
+#undef AUTHENTICATE_THIS
+
+static const IAuthenticateVtbl AuthenticateVtbl = {
+    Authenticate_QueryInterface,
+    Authenticate_AddRef,
+    Authenticate_Release,
+    Authenticate_Authenticate
+};
+
+HRESULT WINAPI HlinkCreateExtensionServices(LPCWSTR pwzAdditionalHeaders,
+        HWND phwnd, LPCWSTR pszUsername, LPCWSTR pszPassword,
+        IUnknown *punkOuter, REFIID riid, void** ppv)
+{
+    ExtensionService *ret;
+    HRESULT hres = S_OK;
+
+    TRACE("%s %p %s %s %p %s %p\n",debugstr_w(pwzAdditionalHeaders),
+            phwnd, debugstr_w(pszUsername), debugstr_w(pszPassword),
+            punkOuter, debugstr_guid(riid), ppv);
+
+    if(pwzAdditionalHeaders)
+        FIXME("Unsupported pwzAdditionalHeaders\n");
+
+    ret = hlink_alloc(sizeof(*ret));
+
+    ret->lpIUnknownVtbl = &ExtServUnkVtbl;
+    ret->lpIAuthenticateVtbl = &AuthenticateVtbl;
+    ret->ref = 1;
+    ret->hwnd = phwnd;
+    ret->username = hlink_strdupW(pszUsername);
+    ret->password = hlink_strdupW(pszPassword);
+
+
+    if(!punkOuter) {
+        ret->outer = EXTSERVUNK(ret);
+        hres = IUnknown_QueryInterface(EXTSERVUNK(ret), riid, ppv);
+        IUnknown_Release(EXTSERVUNK(ret));
+    }else if(IsEqualGUID(&IID_IUnknown, riid)) {
+        ret->outer = punkOuter;
+        *ppv = EXTSERVUNK(ret);
+    }else {
+        IUnknown_Release(EXTSERVUNK(ret));
+        hres = E_INVALIDARG;
+    }
+
+    return hres;
+}
diff --git a/dlls/hlink/hlink_main.c b/dlls/hlink/hlink_main.c
index e45bc0c..4e32189 100644
--- a/dlls/hlink/hlink_main.c
+++ b/dlls/hlink/hlink_main.c
@@ -215,16 +215,6 @@ HRESULT WINAPI HlinkQueryCreateFromData(IDataObject* piDataObj)
     return E_NOTIMPL;
 }
 
-HRESULT WINAPI HlinkCreateExtensionServices(LPCWSTR pwzAdditionalHeaders,
-        HWND phwnd, LPCWSTR pszUsername, LPCWSTR pszPassword,
-        IUnknown *punkOuter, REFIID riid, void** ppvObj)
-{
-    FIXME("%s %p %s %s %p %s %p\n",debugstr_w(pwzAdditionalHeaders),
-            phwnd, debugstr_w(pszUsername), debugstr_w(pszPassword),
-            punkOuter, debugstr_guid(riid), ppvObj);
-    return E_NOTIMPL;
-}
-
 HRESULT WINAPI HlinkNavigateToStringReference( LPCWSTR pwzTarget,
         LPCWSTR pwzLocation, IHlinkSite *pihlsite, DWORD dwSiteData,
         IHlinkFrame *pihlframe, DWORD grfHLNF, LPBC pibc,




More information about the wine-cvs mailing list