Rob Shearman : mshtml: Use the implementation of IHlink in hlink. dll instead of duplicating it.

Alexandre Julliard julliard at wine.codeweavers.com
Wed Jun 13 06:14:08 CDT 2007


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

Author: Rob Shearman <rob at codeweavers.com>
Date:   Tue Jun 12 10:26:50 2007 +0100

mshtml: Use the implementation of IHlink in hlink.dll instead of duplicating it.

---

 dlls/mshtml/hlink.c          |  252 ------------------------------------------
 dlls/mshtml/mshtml_private.h |    1 -
 dlls/mshtml/navigate.c       |    5 +-
 3 files changed, 3 insertions(+), 255 deletions(-)

diff --git a/dlls/mshtml/hlink.c b/dlls/mshtml/hlink.c
index d6238e0..80332a1 100644
--- a/dlls/mshtml/hlink.c
+++ b/dlls/mshtml/hlink.c
@@ -118,255 +118,3 @@ void HTMLDocument_Hlink_Init(HTMLDocument *This)
 {
     This->lpHlinkTargetVtbl = &HlinkTargetVtbl;
 }
-
-typedef struct {
-    const IHlinkVtbl  *lpHlinkVtbl;
-
-    LONG ref;
-
-    IMoniker *mon;
-    LPWSTR location;
-} Hlink;
-
-#define HLINK(x)  ((IHlink*)  &(x)->lpHlinkVtbl)
-
-#define HLINK_THIS(iface) DEFINE_THIS(Hlink, Hlink, iface)
-
-static HRESULT WINAPI Hlink_QueryInterface(IHlink *iface, REFIID riid, void **ppv)
-{
-    Hlink *This = HLINK_THIS(iface);
-
-    *ppv = NULL;
-
-    if(IsEqualGUID(&IID_IUnknown, riid)) {
-        TRACE("(%p)->(IID_IUnknown %p)\n", This, ppv);
-        *ppv = HLINK(This);
-    }else if(IsEqualGUID(&IID_IHlink, riid)) {
-        TRACE("(%p)->(IID_IHlink %p)\n", This, ppv);
-        *ppv = HLINK(This);
-    }
-
-    if(*ppv) {
-        IHlink_AddRef(HLINK(This));
-        return S_OK;
-    }
-
-    WARN("(%p)->(%s %p)\n", This, debugstr_guid(riid), ppv);
-    return E_NOINTERFACE;
-}
-
-static ULONG WINAPI Hlink_AddRef(IHlink *iface)
-{
-    Hlink *This = HLINK_THIS(iface);
-    LONG ref = InterlockedIncrement(&This->ref);
-
-    TRACE("(%p) ref=%d\n", This, ref);
-
-    return ref;
-}
-
-static ULONG WINAPI Hlink_Release(IHlink *iface)
-{
-    Hlink *This = HLINK_THIS(iface);
-    LONG ref = InterlockedDecrement(&This->ref);
-
-    TRACE("(%p) ref=%d\n", This, ref);
-
-    if(!ref) {
-        if(This->mon)
-            IMoniker_Release(This->mon);
-        mshtml_free(This->location);
-        mshtml_free(This);
-    }
-
-    return ref;
-}
-
-static HRESULT WINAPI Hlink_SetHlinkSite(IHlink *iface, IHlinkSite *pihlSite, DWORD dwSiteData)
-{
-    Hlink *This = HLINK_THIS(iface);
-    FIXME("(%p)->(%p %d)\n", This, pihlSite, dwSiteData);
-    return E_NOTIMPL;
-}
-
-static HRESULT WINAPI Hlink_GetHlinkSite(IHlink *iface, IHlinkSite **ppihlSite,
-                                         DWORD *pdwSiteData)
-{
-    Hlink *This = HLINK_THIS(iface);
-
-    TRACE("(%p)->(%p %p)\n", This, ppihlSite, pdwSiteData);
-
-    *ppihlSite = NULL;
-    return S_OK;
-}
-
-static HRESULT WINAPI Hlink_SetMonikerReference(IHlink *iface, DWORD grfHLSETF,
-                                                IMoniker *pimkTarget, LPCWSTR pwzLocation)
-{
-    Hlink *This = HLINK_THIS(iface);
-
-    TRACE("(%p)->(%08x %p %s)\n", This, grfHLSETF, pimkTarget, debugstr_w(pwzLocation));
-
-    if(grfHLSETF)
-        FIXME("unsupported grfHLSETF=%08x\n", grfHLSETF);
-
-    if(This->mon)
-        IMoniker_Release(This->mon);
-    mshtml_free(This->location);
-
-    if(pimkTarget)
-        IMoniker_AddRef(pimkTarget);
-    This->mon = pimkTarget;
-
-    if(pwzLocation) {
-        DWORD len = strlenW(pwzLocation)+1;
-
-        This->location = mshtml_alloc(len*sizeof(WCHAR));
-        memcpy(This->location, pwzLocation, len*sizeof(WCHAR));
-    }else {
-        This->location = NULL;
-    }
-
-    return S_OK;
-}
-
-static HRESULT WINAPI Hlink_GetMonikerReference(IHlink *iface, DWORD dwWhichRef,
-                                                IMoniker **ppimkTarget, LPWSTR *ppwzLocation)
-{
-    Hlink *This = HLINK_THIS(iface);
-
-    TRACE("(%p)->(%d %p %p)\n", This, dwWhichRef, ppimkTarget, ppwzLocation);
-
-    if(dwWhichRef != 1)
-        FIXME("upsupported dwWhichRef = %d\n", dwWhichRef);
-
-    if(This->mon)
-        IMoniker_AddRef(This->mon);
-    *ppimkTarget = This->mon;
-
-    if(This->location) {
-        DWORD len = strlenW(This->location)+1;
-
-        *ppwzLocation = CoTaskMemAlloc(len*sizeof(WCHAR));
-        memcpy(*ppwzLocation, This->location, len*sizeof(WCHAR));
-    }else {
-        *ppwzLocation = NULL;
-    }
-
-    return S_OK;
-}
-
-static HRESULT WINAPI Hlink_SetStringReference(IHlink *iface, DWORD grfHLSETF,
-                                               LPCWSTR pwzTarget, LPCWSTR pwzLocation)
-{
-    Hlink *This = HLINK_THIS(iface);
-    FIXME("(%p)->(%08x %s %s)\n", This, grfHLSETF, debugstr_w(pwzTarget),
-          debugstr_w(pwzLocation));
-    return E_NOTIMPL;
-}
-
-static HRESULT WINAPI Hlink_GetStringReference(IHlink *iface, DWORD dwWhichRef,
-                                               LPWSTR *ppwzTarget, LPWSTR *ppwzLocation)
-{
-    Hlink *This = HLINK_THIS(iface);
-    FIXME("(%p)->(%d %p %p)\n", This, dwWhichRef, ppwzTarget, ppwzLocation);
-    return E_NOTIMPL;
-}
-
-static HRESULT WINAPI Hlink_SetFriendlyName(IHlink *iface, LPCWSTR pwzFriendlyName)
-{
-    Hlink *This = HLINK_THIS(iface);
-    FIXME("(%p)->(%s)\n", This, debugstr_w(pwzFriendlyName));
-    return E_NOTIMPL;
-}
-
-static HRESULT WINAPI Hlink_GetFriendlyName(IHlink *iface, DWORD grfHLNAMEF,
-                                            LPWSTR *ppwzFriendlyName)
-{
-    Hlink *This = HLINK_THIS(iface);
-
-    TRACE("(%p)->(%08x %p)\n", This, grfHLNAMEF, ppwzFriendlyName);
-
-    *ppwzFriendlyName = NULL;
-    return S_FALSE;
-}
-
-static HRESULT WINAPI Hlink_SetTargetFrameName(IHlink *iface, LPCWSTR pwzTargetFrameName)
-{
-    Hlink *This = HLINK_THIS(iface);
-    FIXME("(%p)->(%s)\n", This, debugstr_w(pwzTargetFrameName));
-    return E_NOTIMPL;
-}
-
-static HRESULT WINAPI Hlink_GetTargetFrameName(IHlink *iface, LPWSTR *ppwzTargetFrameName)
-{
-    Hlink *This = HLINK_THIS(iface);
-
-    TRACE("(%p)->(%p)\n", This, ppwzTargetFrameName);
-
-    *ppwzTargetFrameName = NULL;
-    return S_FALSE;
-}
-
-static HRESULT WINAPI Hlink_GetMiscStatus(IHlink *iface, DWORD *pdwStatus)
-{
-    Hlink *This = HLINK_THIS(iface);
-    FIXME("(%p)->(%p)\n", This, pdwStatus);
-    return E_NOTIMPL;
-}
-
-static HRESULT WINAPI Hlink_Navigate(IHlink *iface, DWORD grfHLNF, LPBC pibc,
-        IBindStatusCallback *pibsc, IHlinkBrowseContext *pihlbc)
-{
-    Hlink *This = HLINK_THIS(iface);
-    FIXME("(%p)->(%08x %p %p %p)\n", This, grfHLNF, pibc, pibsc, pihlbc);
-    return E_NOTIMPL;
-}
-
-static HRESULT WINAPI Hlink_SetAdditionalParams(IHlink *iface, LPCWSTR pwzAdditionalParams)
-{
-    Hlink *This = HLINK_THIS(iface);
-    FIXME("(%p)->(%s)\n", This, debugstr_w(pwzAdditionalParams));
-    return E_NOTIMPL;
-}
-
-static HRESULT WINAPI Hlink_GetAdditionalParams(IHlink *iface, LPWSTR *ppwzAdditionalParams)
-{
-    Hlink *This = HLINK_THIS(iface);
-    FIXME("(%p)->(%p)\n", This, ppwzAdditionalParams);
-    return E_NOTIMPL;
-}
-
-#undef HLINK_THIS
-
-static const IHlinkVtbl HlinkVtbl = {
-    Hlink_QueryInterface,
-    Hlink_AddRef,
-    Hlink_Release,
-    Hlink_SetHlinkSite,
-    Hlink_GetHlinkSite,
-    Hlink_SetMonikerReference,
-    Hlink_GetMonikerReference,
-    Hlink_SetStringReference,
-    Hlink_GetStringReference,
-    Hlink_SetFriendlyName,
-    Hlink_GetFriendlyName,
-    Hlink_SetTargetFrameName,
-    Hlink_GetTargetFrameName,
-    Hlink_GetMiscStatus,
-    Hlink_Navigate,
-    Hlink_SetAdditionalParams,
-    Hlink_GetAdditionalParams
-};
-
-IHlink *Hlink_Create(void)
-{
-    Hlink *ret = mshtml_alloc(sizeof(Hlink));
-
-    ret->lpHlinkVtbl = &HlinkVtbl;
-    ret->ref = 1;
-    ret->mon = NULL;
-    ret->location = NULL;
-
-    return HLINK(ret);
-}
diff --git a/dlls/mshtml/mshtml_private.h b/dlls/mshtml/mshtml_private.h
index 5623736..b20354c 100644
--- a/dlls/mshtml/mshtml_private.h
+++ b/dlls/mshtml/mshtml_private.h
@@ -357,7 +357,6 @@ HRESULT load_stream(BSCallback*,IStream*);
 void set_document_bscallback(HTMLDocument*,BSCallback*);
 void set_current_mon(HTMLDocument*,IMoniker*);
 
-IHlink *Hlink_Create(void);
 IHTMLSelectionObject *HTMLSelectionObject_Create(nsISelection*);
 IHTMLTxtRange *HTMLTxtRange_Create(nsIDOMRange*);
 IHTMLStyle *HTMLStyle_Create(nsIDOMCSSStyleDeclaration*);
diff --git a/dlls/mshtml/navigate.c b/dlls/mshtml/navigate.c
index 459cc63..15a2f9c 100644
--- a/dlls/mshtml/navigate.c
+++ b/dlls/mshtml/navigate.c
@@ -28,6 +28,7 @@
 #include "winbase.h"
 #include "winuser.h"
 #include "ole2.h"
+#include "hlguids.h"
 
 #include "wine/debug.h"
 #include "wine/unicode.h"
@@ -761,8 +762,8 @@ void hlink_frame_navigate(HTMLDocument *doc, IHlinkFrame *hlink_frame,
         return;
     }
 
-    hlink = Hlink_Create();
-    if (!hlink) {
+    hr = CoCreateInstance(&CLSID_StdHlink, NULL, CLSCTX_INPROC_SERVER, &IID_IHlink, (LPVOID*)&hlink);
+    if (FAILED(hr)) {
         IBindCtx_Release(bindctx);
         IBindStatusCallback_Release(STATUSCLB(callback));
         return;




More information about the wine-cvs mailing list