MSHTML: (almost) stub implementation of IOleObject and IOleDocument

Jacek Caban jack at itma.pwr.wroc.pl
Tue Apr 12 06:51:37 CDT 2005


I forgot to release client and attach Makefile.in diff, use this patch
instead.

Something more usefull will be soon... (currently IE just starts...)

Changelog:

    stub implementation of IOleObject and IOleDocument


-------------- next part --------------
Index: dlls/mshtml/mshtml_private.h
===================================================================
RCS file: /home/wine/wine/dlls/mshtml/mshtml_private.h,v
retrieving revision 1.2
diff -u -p -r1.2 mshtml_private.h
--- dlls/mshtml/mshtml_private.h	11 Apr 2005 16:11:52 -0000	1.2
+++ dlls/mshtml/mshtml_private.h	12 Apr 2005 11:43:07 -0000
@@ -21,8 +21,12 @@ typedef struct {
     IPersistMonikerVtbl *lpPersistMonikerVtbl;
     IPersistFileVtbl    *lpPersistFileVtbl;
     IMonikerPropVtbl    *lpMonikerPropVtbl;
+    IOleObjectVtbl      *lpOleObjectVtbl;
+    IOleDocumentVtbl    *lpOleDocumentVtbl;
 
     ULONG ref;
+
+    IOleClientSite *client;
 } HTMLDocument;
 
 #define HTMLDOC(x)       ((IHTMLDocument2*)     &(x)->lpHTMLDocument2Vtbl)
@@ -30,7 +34,10 @@ typedef struct {
 #define PERSISTMON(x)    ((IPersistMoniker*)    &(x)->lpPersistMonikerVtbl)
 #define PERSISTFILE(x)   ((IPersistFile*)       &(x)->lpPersistFileVtbl)
 #define MONPROP(x)       ((IMonikerProp*)       &(x)->lpMonikerPropVtbl)
+#define OLEOBJ(x)        ((IOleObject*)         &(x)->lpOleObjectVtbl)
+#define OLEDOC(x)        ((IOleDocument*)       &(x)->lpOleDocumentVtbl)
 
 HRESULT HTMLDocument_Create(IUnknown*,REFIID,void**);
 
 void HTMLDocument_Persist_Init(HTMLDocument*);
+void HTMLDocument_OleObj_Init(HTMLDocument*);
Index: dlls/mshtml/htmldoc.c
===================================================================
RCS file: /home/wine/wine/dlls/mshtml/htmldoc.c,v
retrieving revision 1.2
diff -u -p -r1.2 htmldoc.c
--- dlls/mshtml/htmldoc.c	11 Apr 2005 16:11:52 -0000	1.2
+++ dlls/mshtml/htmldoc.c	12 Apr 2005 11:43:08 -0000
@@ -27,6 +27,7 @@
 #include "winbase.h"
 #include "winuser.h"
 #include "ole2.h"
+#include "docobj.h"
 
 #include "mshtml.h"
 #include "mshtmdid.h"
@@ -66,6 +67,12 @@ static HRESULT WINAPI HTMLDocument_Query
     }else if(IsEqualGUID(&IID_IMonikerProp, riid)) {
         TRACE("(%p)->(IID_IMonikerProp, %p)\n", This, ppvObject);
         *ppvObject = MONPROP(This);
+    }else if(IsEqualGUID(&IID_IOleObject, riid)) {
+        TRACE("(%p)->(IID_IOleObject, %p)\n", This, ppvObject);
+        *ppvObject = OLEOBJ(This);
+    }else if(IsEqualGUID(&IID_IOleDocument, riid)) {
+        TRACE("(%p)->(IID_IOleDocument, %p)\n", This, ppvObject);
+        *ppvObject = OLEDOC(This);
     }
 
     if(*ppvObject) {
@@ -92,8 +99,11 @@ static ULONG WINAPI HTMLDocument_Release
 
     TRACE("(%p) ref = %lu\n", This, ref);
 
-    if(!ref)
+    if(!ref) {
+        if(This->client)
+            IOleClientSite_Release(This->client);
         HeapFree(GetProcessHeap(), 0, This);
+    }
 
     return ref;
 }
@@ -931,6 +941,7 @@ HRESULT HTMLDocument_Create(IUnknown *pU
         HeapFree(GetProcessHeap(), 0, ret);
 
     HTMLDocument_Persist_Init(ret);
+    HTMLDocument_OleObj_Init(ret);
 
     return hres;
 }
Index: dlls/mshtml/main.c
===================================================================
RCS file: /home/wine/wine/dlls/mshtml/main.c,v
retrieving revision 1.7
diff -u -p -r1.7 main.c
--- dlls/mshtml/main.c	31 Mar 2005 10:08:02 -0000	1.7
+++ dlls/mshtml/main.c	12 Apr 2005 11:43:08 -0000
@@ -33,6 +33,7 @@
 #include "winnls.h"
 #include "winreg.h"
 #include "ole2.h"
+#include "docobj.h"
 
 #include "mshtml.h"
 #include "mshtml_private.h"
Index: dlls/mshtml/persist.c
===================================================================
RCS file: /home/wine/wine/dlls/mshtml/persist.c,v
retrieving revision 1.1
diff -u -p -r1.1 persist.c
--- dlls/mshtml/persist.c	11 Apr 2005 16:11:52 -0000	1.1
+++ dlls/mshtml/persist.c	12 Apr 2005 11:43:08 -0000
@@ -27,6 +27,7 @@
 #include "winbase.h"
 #include "winuser.h"
 #include "ole2.h"
+#include "docobj.h"
 
 #include "mshtml.h"
 
--- /dev/null	1970-01-01 01:00:00.000000000 +0100
+++ dlls/mshtml/oleobj.c	2005-04-11 21:08:52.000000000 +0200
@@ -0,0 +1,324 @@
+/*
+ * Copyright 2005 Jacek Caban
+ *
+ * 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., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA
+ */
+
+#include "config.h"
+
+#include <stdarg.h>
+#include <stdio.h>
+
+#define COBJMACROS
+
+#include "windef.h"
+#include "winbase.h"
+#include "winuser.h"
+#include "ole2.h"
+#include "docobj.h"
+
+#include "mshtml.h"
+
+#include "wine/debug.h"
+
+#include "mshtml_private.h"
+
+WINE_DEFAULT_DEBUG_CHANNEL(mshtml);
+
+/**********************************************************
+ * IOleObject implementation
+ */
+
+#define OLEOBJ_THIS \
+    HTMLDocument* const This=(HTMLDocument*)((char*)(iface)-offsetof(HTMLDocument,lpOleObjectVtbl));
+
+static HRESULT WINAPI OleObject_QueryInterface(IOleObject *iface, REFIID riid, void **ppvObject)
+{
+    OLEOBJ_THIS
+    return IHTMLDocument2_QueryInterface(HTMLDOC(This), riid, ppvObject);
+}
+
+static ULONG WINAPI OleObject_AddRef(IOleObject *iface)
+{
+    OLEOBJ_THIS
+    return IHTMLDocument2_AddRef(HTMLDOC(This));
+}
+
+static ULONG WINAPI OleObject_Release(IOleObject *iface)
+{
+    OLEOBJ_THIS
+    return IHTMLDocument2_Release(HTMLDOC(This));
+}
+
+static HRESULT WINAPI OleObject_SetClientSite(IOleObject *iface, IOleClientSite *pClientSite)
+{
+    OLEOBJ_THIS
+    TRACE("(%p)->(%p)\n", This, pClientSite);
+
+    if(This->client)
+        IOleClientSite_Release(This->client);
+    if(pClientSite)
+        IOleClientSite_AddRef(pClientSite);
+    This->client = pClientSite;
+
+    return S_OK;
+}
+
+static HRESULT WINAPI OleObject_GetClientSite(IOleObject *iface, IOleClientSite **ppClientSite)
+{
+    OLEOBJ_THIS
+    TRACE("(%p)->(%p)\n", This, ppClientSite);
+
+    if(!ppClientSite)
+        return E_INVALIDARG;
+
+    if(This->client)
+        IOleClientSite_AddRef(This->client);
+    *ppClientSite = This->client;
+
+    return S_OK;
+}
+
+static HRESULT WINAPI OleObject_SetHostNames(IOleObject *iface, LPCOLESTR szContainerApp, LPCOLESTR szContainerObj)
+{
+    OLEOBJ_THIS
+    FIXME("(%p)->(%s %s)\n", This, debugstr_w(szContainerApp), debugstr_w(szContainerObj));
+    return E_NOTIMPL;
+}
+
+static HRESULT WINAPI OleObject_Close(IOleObject *iface, DWORD dwSaveOption)
+{
+    OLEOBJ_THIS
+    FIXME("(%p)->(%08lx)\n", This, dwSaveOption);
+    return E_NOTIMPL;
+}
+
+static HRESULT WINAPI OleObject_SetMoniker(IOleObject *iface, DWORD dwWhichMoniker, IMoniker *pmk)
+{
+    OLEOBJ_THIS
+    FIXME("(%p %ld %p)->()\n", This, dwWhichMoniker, pmk);
+    return E_NOTIMPL;
+}
+
+static HRESULT WINAPI OleObject_GetMoniker(IOleObject *iface, DWORD dwAssign, DWORD dwWhichMoniker, IMoniker **ppmk)
+{
+    OLEOBJ_THIS
+    FIXME("(%p)->(%ld %ld %p)\n", This, dwAssign, dwWhichMoniker, ppmk);
+    return E_NOTIMPL;
+}
+
+static HRESULT WINAPI OleObject_InitFromData(IOleObject *iface, IDataObject *pDataObject, BOOL fCreation,
+                                        DWORD dwReserved)
+{
+    OLEOBJ_THIS
+    FIXME("(%p)->(%p %x %ld)\n", This, pDataObject, fCreation, dwReserved);
+    return E_NOTIMPL;
+}
+
+static HRESULT WINAPI OleObject_GetClipboardData(IOleObject *iface, DWORD dwReserved, IDataObject **ppDataObject)
+{
+    OLEOBJ_THIS
+    FIXME("(%p)->(%ld %p)\n", This, dwReserved, ppDataObject);
+    return E_NOTIMPL;
+}
+
+static HRESULT WINAPI OleObject_DoVerb(IOleObject *iface, LONG iVerb, LPMSG lpmsg, IOleClientSite *pActiveSite,
+                                        LONG lindex, HWND hwndParent, LPCRECT lprcPosRect)
+{
+    OLEOBJ_THIS
+    FIXME("(%p)->(%ld %p %p %ld %p %p)\n", This, iVerb, lpmsg, pActiveSite, lindex, hwndParent, lprcPosRect);
+    return E_NOTIMPL;
+}
+
+static HRESULT WINAPI OleObject_EnumVerbs(IOleObject *iface, IEnumOLEVERB **ppEnumOleVerb)
+{
+    OLEOBJ_THIS
+    FIXME("(%p)->(%p)\n", This, ppEnumOleVerb);
+    return E_NOTIMPL;
+}
+
+static HRESULT WINAPI OleObject_Update(IOleObject *iface)
+{
+    OLEOBJ_THIS
+    FIXME("(%p)\n", This);
+    return E_NOTIMPL;
+}
+
+static HRESULT WINAPI OleObject_IsUpToDate(IOleObject *iface)
+{
+    OLEOBJ_THIS
+    FIXME("(%p)\n", This);
+    return E_NOTIMPL;
+}
+
+static HRESULT WINAPI OleObject_GetUserClassID(IOleObject *iface, CLSID *pClsid)
+{
+    OLEOBJ_THIS
+    TRACE("(%p)->(%p)\n", This, pClsid);
+
+    if(!pClsid)
+        return E_INVALIDARG;
+
+    memcpy(pClsid, &CLSID_HTMLDocument, sizeof(GUID));
+    return S_OK;
+}
+
+static HRESULT WINAPI OleObject_GetUserType(IOleObject *iface, DWORD dwFormOfType, LPOLESTR *pszUserType)
+{
+    OLEOBJ_THIS
+    FIXME("(%p)->(%ld %p)\n", This, dwFormOfType, pszUserType);
+    return E_NOTIMPL;
+}
+
+static HRESULT WINAPI OleObject_SetExtent(IOleObject *iface, DWORD dwDrawAspect, SIZEL *psizel)
+{
+    OLEOBJ_THIS
+    FIXME("(%p)->(%ld %p)\n", This, dwDrawAspect, psizel);
+    return E_NOTIMPL;
+}
+
+static HRESULT WINAPI OleObject_GetExtent(IOleObject *iface, DWORD dwDrawAspect, SIZEL *psizel)
+{
+    OLEOBJ_THIS
+    FIXME("(%p)->(%ld %p)\n", This, dwDrawAspect, psizel);
+    return E_NOTIMPL;
+}
+
+static HRESULT WINAPI OleObject_Advise(IOleObject *iface, IAdviseSink *pAdvSink, DWORD *pdwConnection)
+{
+    OLEOBJ_THIS
+    FIXME("(%p)->(%p %p)\n", This, pAdvSink, pdwConnection);
+    return E_NOTIMPL;
+}
+
+static HRESULT WINAPI OleObject_Unadvise(IOleObject *iface, DWORD dwConnection)
+{
+    OLEOBJ_THIS
+    FIXME("(%p)->(%ld)\n", This, dwConnection);
+    return E_NOTIMPL;
+}
+
+static HRESULT WINAPI OleObject_EnumAdvise(IOleObject *iface, IEnumSTATDATA **ppenumAdvise)
+{
+    OLEOBJ_THIS
+    FIXME("(%p)->(%p)\n", This, ppenumAdvise);
+    return E_NOTIMPL;
+}
+
+static HRESULT WINAPI OleObject_GetMiscStatus(IOleObject *iface, DWORD dwAspect, DWORD *pdwStatus)
+{
+    OLEOBJ_THIS
+    FIXME("(%p)->(%ld %p)\n", This, dwAspect, pdwStatus);
+    return E_NOTIMPL;
+}
+
+static HRESULT WINAPI OleObject_SetColorScheme(IOleObject *iface, LOGPALETTE *pLogpal)
+{
+    OLEOBJ_THIS
+    FIXME("(%p)->(%p)\n", This, pLogpal);
+    return E_NOTIMPL;
+}
+
+static IOleObjectVtbl OleObjectVtbl = {
+    OleObject_QueryInterface,
+    OleObject_AddRef,
+    OleObject_Release,
+    OleObject_SetClientSite,
+    OleObject_GetClientSite,
+    OleObject_SetHostNames,
+    OleObject_Close,
+    OleObject_SetMoniker,
+    OleObject_GetMoniker,
+    OleObject_InitFromData,
+    OleObject_GetClipboardData,
+    OleObject_DoVerb,
+    OleObject_EnumVerbs,
+    OleObject_Update,
+    OleObject_IsUpToDate,
+    OleObject_GetUserClassID,
+    OleObject_GetUserType,
+    OleObject_SetExtent,
+    OleObject_GetExtent,
+    OleObject_Advise,
+    OleObject_Unadvise,
+    OleObject_EnumAdvise,
+    OleObject_GetMiscStatus,
+    OleObject_SetColorScheme
+};
+
+/**********************************************************
+ * IOleDocument implementation
+ */
+
+#define OLEDOC_THIS \
+    HTMLDocument* const This=(HTMLDocument*)((char*)(iface)-offsetof(HTMLDocument,lpOleDocumentVtbl));
+
+static HRESULT WINAPI OleDocument_QueryInterface(IOleDocument *iface, REFIID riid, void **ppvObject)
+{
+    OLEDOC_THIS
+    return IHTMLDocument2_QueryInterface(HTMLDOC(This), riid, ppvObject);
+}
+
+static ULONG WINAPI OleDocument_AddRef(IOleDocument *iface)
+{
+    OLEDOC_THIS
+    return IHTMLDocument2_AddRef(HTMLDOC(This));
+}
+
+static ULONG WINAPI OleDocument_Release(IOleDocument *iface)
+{
+    OLEDOC_THIS
+    return IHTMLDocument2_Release(HTMLDOC(This));
+}
+
+static HRESULT WINAPI OleDocument_CreateView(IOleDocument *iface, IOleInPlaceSite *pIPSite, IStream *pstm,
+                                   DWORD dwReserved, IOleDocumentView **ppView)
+{
+    OLEDOC_THIS
+    FIXME("(%p)->(%p %p %ld %p)\n", This, pIPSite, pstm, dwReserved, ppView);
+    return E_NOTIMPL;
+}
+
+static HRESULT WINAPI OleDocument_GetDocMiscStatus(IOleDocument *iface, DWORD *pdwStatus)
+{
+    OLEDOC_THIS
+    FIXME("(%p)->(%p)\n", This, pdwStatus);
+    return E_NOTIMPL;
+}
+
+static HRESULT WINAPI OleDocument_EnumViews(IOleDocument *iface, IEnumOleDocumentViews **ppEnum,
+                                   IOleDocumentView **ppView)
+{
+    OLEDOC_THIS
+    FIXME("(%p)->(%p %p)\n", This, ppEnum, ppView);
+    return E_NOTIMPL;
+}
+
+static IOleDocumentVtbl OleDocumentVtbl = {
+    OleDocument_QueryInterface,
+    OleDocument_AddRef,
+    OleDocument_Release,
+    OleDocument_CreateView,
+    OleDocument_GetDocMiscStatus,
+    OleDocument_EnumViews
+};
+
+void HTMLDocument_OleObj_Init(HTMLDocument *This)
+{
+    This->lpOleObjectVtbl = &OleObjectVtbl;
+    This->lpOleDocumentVtbl = &OleDocumentVtbl;
+
+    This->client = NULL;
+}


More information about the wine-patches mailing list