Commit ca353c9b authored by Jacek Caban's avatar Jacek Caban Committed by Alexandre Julliard

shdocvw: Get rid of CLIENTSITE_THIS.

parent 12be1988
...@@ -25,20 +25,21 @@ ...@@ -25,20 +25,21 @@
WINE_DEFAULT_DEBUG_CHANNEL(shdocvw); WINE_DEFAULT_DEBUG_CHANNEL(shdocvw);
#define CLIENTSITE_THIS(iface) DEFINE_THIS(DocHost, OleClientSite, iface) static inline DocHost *impl_from_IOleClientSite(IOleClientSite *iface)
{
return (DocHost*)((char*)iface - FIELD_OFFSET(DocHost, IOleClientSite_iface));
}
static HRESULT WINAPI ClientSite_QueryInterface(IOleClientSite *iface, REFIID riid, void **ppv) static HRESULT WINAPI ClientSite_QueryInterface(IOleClientSite *iface, REFIID riid, void **ppv)
{ {
DocHost *This = CLIENTSITE_THIS(iface); DocHost *This = impl_from_IOleClientSite(iface);
*ppv = NULL;
if(IsEqualGUID(&IID_IUnknown, riid)) { if(IsEqualGUID(&IID_IUnknown, riid)) {
TRACE("(%p)->(IID_IUnknown %p)\n", This, ppv); TRACE("(%p)->(IID_IUnknown %p)\n", This, ppv);
*ppv = CLIENTSITE(This); *ppv = &This->IOleClientSite_iface;
}else if(IsEqualGUID(&IID_IOleClientSite, riid)) { }else if(IsEqualGUID(&IID_IOleClientSite, riid)) {
TRACE("(%p)->(IID_IOleClientSite %p)\n", This, ppv); TRACE("(%p)->(IID_IOleClientSite %p)\n", This, ppv);
*ppv = CLIENTSITE(This); *ppv = &This->IOleClientSite_iface;
}else if(IsEqualGUID(&IID_IOleWindow, riid)) { }else if(IsEqualGUID(&IID_IOleWindow, riid)) {
TRACE("(%p)->(IID_IOleWindow %p)\n", This, ppv); TRACE("(%p)->(IID_IOleWindow %p)\n", This, ppv);
*ppv = INPLACESITE(This); *ppv = INPLACESITE(This);
...@@ -66,33 +67,31 @@ static HRESULT WINAPI ClientSite_QueryInterface(IOleClientSite *iface, REFIID ri ...@@ -66,33 +67,31 @@ static HRESULT WINAPI ClientSite_QueryInterface(IOleClientSite *iface, REFIID ri
}else if(IsEqualGUID(&IID_IServiceProvider, riid)) { }else if(IsEqualGUID(&IID_IServiceProvider, riid)) {
TRACE("(%p)->(IID_IServiceProvider %p)\n", This, ppv); TRACE("(%p)->(IID_IServiceProvider %p)\n", This, ppv);
*ppv = SERVPROV(This); *ppv = SERVPROV(This);
}else {
*ppv = NULL;
WARN("Unsupported interface %s\n", debugstr_guid(riid));
return E_NOINTERFACE;
} }
if(*ppv) { IOleClientSite_AddRef((IUnknown*)*ppv);
IOleClientSite_AddRef(CLIENTSITE(This)); return S_OK;
return S_OK;
}
WARN("Unsupported interface %s\n", debugstr_guid(riid));
return E_NOINTERFACE;
} }
static ULONG WINAPI ClientSite_AddRef(IOleClientSite *iface) static ULONG WINAPI ClientSite_AddRef(IOleClientSite *iface)
{ {
DocHost *This = CLIENTSITE_THIS(iface); DocHost *This = impl_from_IOleClientSite(iface);
return IDispatch_AddRef(This->disp); return IDispatch_AddRef(This->disp);
} }
static ULONG WINAPI ClientSite_Release(IOleClientSite *iface) static ULONG WINAPI ClientSite_Release(IOleClientSite *iface)
{ {
DocHost *This = CLIENTSITE_THIS(iface); DocHost *This = impl_from_IOleClientSite(iface);
return IDispatch_Release(This->disp); return IDispatch_Release(This->disp);
} }
static HRESULT WINAPI ClientSite_SaveObject(IOleClientSite *iface) static HRESULT WINAPI ClientSite_SaveObject(IOleClientSite *iface)
{ {
DocHost *This = CLIENTSITE_THIS(iface); DocHost *This = impl_from_IOleClientSite(iface);
FIXME("(%p)\n", This); FIXME("(%p)\n", This);
return E_NOTIMPL; return E_NOTIMPL;
} }
...@@ -100,41 +99,39 @@ static HRESULT WINAPI ClientSite_SaveObject(IOleClientSite *iface) ...@@ -100,41 +99,39 @@ static HRESULT WINAPI ClientSite_SaveObject(IOleClientSite *iface)
static HRESULT WINAPI ClientSite_GetMoniker(IOleClientSite *iface, DWORD dwAssign, static HRESULT WINAPI ClientSite_GetMoniker(IOleClientSite *iface, DWORD dwAssign,
DWORD dwWhichMoniker, IMoniker **ppmk) DWORD dwWhichMoniker, IMoniker **ppmk)
{ {
DocHost *This = CLIENTSITE_THIS(iface); DocHost *This = impl_from_IOleClientSite(iface);
FIXME("(%p)->(%d %d %p)\n", This, dwAssign, dwWhichMoniker, ppmk); FIXME("(%p)->(%d %d %p)\n", This, dwAssign, dwWhichMoniker, ppmk);
return E_NOTIMPL; return E_NOTIMPL;
} }
static HRESULT WINAPI ClientSite_GetContainer(IOleClientSite *iface, IOleContainer **ppContainer) static HRESULT WINAPI ClientSite_GetContainer(IOleClientSite *iface, IOleContainer **ppContainer)
{ {
DocHost *This = CLIENTSITE_THIS(iface); DocHost *This = impl_from_IOleClientSite(iface);
FIXME("(%p)->(%p)\n", This, ppContainer); FIXME("(%p)->(%p)\n", This, ppContainer);
return E_NOTIMPL; return E_NOTIMPL;
} }
static HRESULT WINAPI ClientSite_ShowObject(IOleClientSite *iface) static HRESULT WINAPI ClientSite_ShowObject(IOleClientSite *iface)
{ {
DocHost *This = CLIENTSITE_THIS(iface); DocHost *This = impl_from_IOleClientSite(iface);
FIXME("(%p)\n", This); FIXME("(%p)\n", This);
return E_NOTIMPL; return E_NOTIMPL;
} }
static HRESULT WINAPI ClientSite_OnShowWindow(IOleClientSite *iface, BOOL fShow) static HRESULT WINAPI ClientSite_OnShowWindow(IOleClientSite *iface, BOOL fShow)
{ {
DocHost *This = CLIENTSITE_THIS(iface); DocHost *This = impl_from_IOleClientSite(iface);
FIXME("(%p)->(%x)\n", This, fShow); FIXME("(%p)->(%x)\n", This, fShow);
return E_NOTIMPL; return E_NOTIMPL;
} }
static HRESULT WINAPI ClientSite_RequestNewObjectLayout(IOleClientSite *iface) static HRESULT WINAPI ClientSite_RequestNewObjectLayout(IOleClientSite *iface)
{ {
DocHost *This = CLIENTSITE_THIS(iface); DocHost *This = impl_from_IOleClientSite(iface);
FIXME("(%p)\n", This); FIXME("(%p)\n", This);
return E_NOTIMPL; return E_NOTIMPL;
} }
#undef CLIENTSITE_THIS
static const IOleClientSiteVtbl OleClientSiteVtbl = { static const IOleClientSiteVtbl OleClientSiteVtbl = {
ClientSite_QueryInterface, ClientSite_QueryInterface,
ClientSite_AddRef, ClientSite_AddRef,
...@@ -152,19 +149,19 @@ static const IOleClientSiteVtbl OleClientSiteVtbl = { ...@@ -152,19 +149,19 @@ static const IOleClientSiteVtbl OleClientSiteVtbl = {
static HRESULT WINAPI InPlaceSite_QueryInterface(IOleInPlaceSite *iface, REFIID riid, void **ppv) static HRESULT WINAPI InPlaceSite_QueryInterface(IOleInPlaceSite *iface, REFIID riid, void **ppv)
{ {
DocHost *This = INPLACESITE_THIS(iface); DocHost *This = INPLACESITE_THIS(iface);
return IOleClientSite_QueryInterface(CLIENTSITE(This), riid, ppv); return IOleClientSite_QueryInterface(&This->IOleClientSite_iface, riid, ppv);
} }
static ULONG WINAPI InPlaceSite_AddRef(IOleInPlaceSite *iface) static ULONG WINAPI InPlaceSite_AddRef(IOleInPlaceSite *iface)
{ {
DocHost *This = INPLACESITE_THIS(iface); DocHost *This = INPLACESITE_THIS(iface);
return IOleClientSite_AddRef(CLIENTSITE(This)); return IOleClientSite_AddRef(&This->IOleClientSite_iface);
} }
static ULONG WINAPI InPlaceSite_Release(IOleInPlaceSite *iface) static ULONG WINAPI InPlaceSite_Release(IOleInPlaceSite *iface)
{ {
DocHost *This = INPLACESITE_THIS(iface); DocHost *This = INPLACESITE_THIS(iface);
return IOleClientSite_Release(CLIENTSITE(This)); return IOleClientSite_Release(&This->IOleClientSite_iface);
} }
static HRESULT WINAPI InPlaceSite_GetWindow(IOleInPlaceSite *iface, HWND *phwnd) static HRESULT WINAPI InPlaceSite_GetWindow(IOleInPlaceSite *iface, HWND *phwnd)
...@@ -282,8 +279,6 @@ static HRESULT WINAPI InPlaceSite_OnPosRectChange(IOleInPlaceSite *iface, ...@@ -282,8 +279,6 @@ static HRESULT WINAPI InPlaceSite_OnPosRectChange(IOleInPlaceSite *iface,
return E_NOTIMPL; return E_NOTIMPL;
} }
#undef INPLACESITE_THIS
static const IOleInPlaceSiteVtbl OleInPlaceSiteVtbl = { static const IOleInPlaceSiteVtbl OleInPlaceSiteVtbl = {
InPlaceSite_QueryInterface, InPlaceSite_QueryInterface,
InPlaceSite_AddRef, InPlaceSite_AddRef,
...@@ -308,19 +303,19 @@ static HRESULT WINAPI OleDocumentSite_QueryInterface(IOleDocumentSite *iface, ...@@ -308,19 +303,19 @@ static HRESULT WINAPI OleDocumentSite_QueryInterface(IOleDocumentSite *iface,
REFIID riid, void **ppv) REFIID riid, void **ppv)
{ {
DocHost *This = DOCSITE_THIS(iface); DocHost *This = DOCSITE_THIS(iface);
return IOleClientSite_QueryInterface(CLIENTSITE(This), riid, ppv); return IOleClientSite_QueryInterface(&This->IOleClientSite_iface, riid, ppv);
} }
static ULONG WINAPI OleDocumentSite_AddRef(IOleDocumentSite *iface) static ULONG WINAPI OleDocumentSite_AddRef(IOleDocumentSite *iface)
{ {
DocHost *This = DOCSITE_THIS(iface); DocHost *This = DOCSITE_THIS(iface);
return IOleClientSite_AddRef(CLIENTSITE(This)); return IOleClientSite_AddRef(&This->IOleClientSite_iface);
} }
static ULONG WINAPI OleDocumentSite_Release(IOleDocumentSite *iface) static ULONG WINAPI OleDocumentSite_Release(IOleDocumentSite *iface)
{ {
DocHost *This = DOCSITE_THIS(iface); DocHost *This = DOCSITE_THIS(iface);
return IOleClientSite_Release(CLIENTSITE(This)); return IOleClientSite_Release(&This->IOleClientSite_iface);
} }
static HRESULT WINAPI OleDocumentSite_ActivateMe(IOleDocumentSite *iface, static HRESULT WINAPI OleDocumentSite_ActivateMe(IOleDocumentSite *iface,
...@@ -348,8 +343,6 @@ static HRESULT WINAPI OleDocumentSite_ActivateMe(IOleDocumentSite *iface, ...@@ -348,8 +343,6 @@ static HRESULT WINAPI OleDocumentSite_ActivateMe(IOleDocumentSite *iface,
return hres; return hres;
} }
#undef DOCSITE_THIS
static const IOleDocumentSiteVtbl OleDocumentSiteVtbl = { static const IOleDocumentSiteVtbl OleDocumentSiteVtbl = {
OleDocumentSite_QueryInterface, OleDocumentSite_QueryInterface,
OleDocumentSite_AddRef, OleDocumentSite_AddRef,
...@@ -362,19 +355,19 @@ static const IOleDocumentSiteVtbl OleDocumentSiteVtbl = { ...@@ -362,19 +355,19 @@ static const IOleDocumentSiteVtbl OleDocumentSiteVtbl = {
static HRESULT WINAPI ClDispatch_QueryInterface(IDispatch *iface, REFIID riid, void **ppv) static HRESULT WINAPI ClDispatch_QueryInterface(IDispatch *iface, REFIID riid, void **ppv)
{ {
DocHost *This = DISP_THIS(iface); DocHost *This = DISP_THIS(iface);
return IOleClientSite_QueryInterface(CLIENTSITE(This), riid, ppv); return IOleClientSite_QueryInterface(&This->IOleClientSite_iface, riid, ppv);
} }
static ULONG WINAPI ClDispatch_AddRef(IDispatch *iface) static ULONG WINAPI ClDispatch_AddRef(IDispatch *iface)
{ {
DocHost *This = DISP_THIS(iface); DocHost *This = DISP_THIS(iface);
return IOleClientSite_AddRef(CLIENTSITE(This)); return IOleClientSite_AddRef(&This->IOleClientSite_iface);
} }
static ULONG WINAPI ClDispatch_Release(IDispatch *iface) static ULONG WINAPI ClDispatch_Release(IDispatch *iface)
{ {
DocHost *This = DISP_THIS(iface); DocHost *This = DISP_THIS(iface);
return IOleClientSite_Release(CLIENTSITE(This)); return IOleClientSite_Release(&This->IOleClientSite_iface);
} }
static HRESULT WINAPI ClDispatch_GetTypeInfoCount(IDispatch *iface, UINT *pctinfo) static HRESULT WINAPI ClDispatch_GetTypeInfoCount(IDispatch *iface, UINT *pctinfo)
...@@ -458,8 +451,6 @@ static HRESULT WINAPI ClDispatch_Invoke(IDispatch *iface, DISPID dispIdMember, R ...@@ -458,8 +451,6 @@ static HRESULT WINAPI ClDispatch_Invoke(IDispatch *iface, DISPID dispIdMember, R
return E_NOTIMPL; return E_NOTIMPL;
} }
#undef DISP_THIS
static const IDispatchVtbl DispatchVtbl = { static const IDispatchVtbl DispatchVtbl = {
ClDispatch_QueryInterface, ClDispatch_QueryInterface,
ClDispatch_AddRef, ClDispatch_AddRef,
...@@ -476,19 +467,19 @@ static HRESULT WINAPI ClServiceProvider_QueryInterface(IServiceProvider *iface, ...@@ -476,19 +467,19 @@ static HRESULT WINAPI ClServiceProvider_QueryInterface(IServiceProvider *iface,
void **ppv) void **ppv)
{ {
DocHost *This = SERVPROV_THIS(iface); DocHost *This = SERVPROV_THIS(iface);
return IOleClientSite_QueryInterface(CLIENTSITE(This), riid, ppv); return IOleClientSite_QueryInterface(&This->IOleClientSite_iface, riid, ppv);
} }
static ULONG WINAPI ClServiceProvider_AddRef(IServiceProvider *iface) static ULONG WINAPI ClServiceProvider_AddRef(IServiceProvider *iface)
{ {
DocHost *This = SERVPROV_THIS(iface); DocHost *This = SERVPROV_THIS(iface);
return IOleClientSite_AddRef(CLIENTSITE(This)); return IOleClientSite_AddRef(&This->IOleClientSite_iface);
} }
static ULONG WINAPI ClServiceProvider_Release(IServiceProvider *iface) static ULONG WINAPI ClServiceProvider_Release(IServiceProvider *iface)
{ {
DocHost *This = SERVPROV_THIS(iface); DocHost *This = SERVPROV_THIS(iface);
return IOleClientSite_Release(CLIENTSITE(This)); return IOleClientSite_Release(&This->IOleClientSite_iface);
} }
static HRESULT WINAPI ClServiceProvider_QueryService(IServiceProvider *iface, REFGUID guidService, static HRESULT WINAPI ClServiceProvider_QueryService(IServiceProvider *iface, REFGUID guidService,
...@@ -506,8 +497,6 @@ static HRESULT WINAPI ClServiceProvider_QueryService(IServiceProvider *iface, RE ...@@ -506,8 +497,6 @@ static HRESULT WINAPI ClServiceProvider_QueryService(IServiceProvider *iface, RE
return E_NOINTERFACE; return E_NOINTERFACE;
} }
#undef SERVPROV_THIS
static const IServiceProviderVtbl ServiceProviderVtbl = { static const IServiceProviderVtbl ServiceProviderVtbl = {
ClServiceProvider_QueryInterface, ClServiceProvider_QueryInterface,
ClServiceProvider_AddRef, ClServiceProvider_AddRef,
...@@ -517,7 +506,7 @@ static const IServiceProviderVtbl ServiceProviderVtbl = { ...@@ -517,7 +506,7 @@ static const IServiceProviderVtbl ServiceProviderVtbl = {
void DocHost_ClientSite_Init(DocHost *This) void DocHost_ClientSite_Init(DocHost *This)
{ {
This->lpOleClientSiteVtbl = &OleClientSiteVtbl; This->IOleClientSite_iface.lpVtbl = &OleClientSiteVtbl;
This->lpOleInPlaceSiteVtbl = &OleInPlaceSiteVtbl; This->lpOleInPlaceSiteVtbl = &OleInPlaceSiteVtbl;
This->lpOleDocumentSiteVtbl = &OleDocumentSiteVtbl; This->lpOleDocumentSiteVtbl = &OleDocumentSiteVtbl;
This->lpDispatchVtbl = &DispatchVtbl; This->lpDispatchVtbl = &DispatchVtbl;
......
...@@ -230,7 +230,7 @@ HRESULT dochost_object_available(DocHost *This, IUnknown *doc) ...@@ -230,7 +230,7 @@ HRESULT dochost_object_available(DocHost *This, IUnknown *doc)
TRACE("Got clsid %s\n", TRACE("Got clsid %s\n",
IsEqualGUID(&clsid, &CLSID_HTMLDocument) ? "CLSID_HTMLDocument" : debugstr_guid(&clsid)); IsEqualGUID(&clsid, &CLSID_HTMLDocument) ? "CLSID_HTMLDocument" : debugstr_guid(&clsid));
hres = IOleObject_SetClientSite(oleobj, CLIENTSITE(This)); hres = IOleObject_SetClientSite(oleobj, &This->IOleClientSite_iface);
if(FAILED(hres)) if(FAILED(hres))
FIXME("SetClientSite failed: %08x\n", hres); FIXME("SetClientSite failed: %08x\n", hres);
...@@ -367,7 +367,7 @@ void deactivate_document(DocHost *This) ...@@ -367,7 +367,7 @@ void deactivate_document(DocHost *This)
IOleObject_GetClientSite(oleobj, &client_site); IOleObject_GetClientSite(oleobj, &client_site);
if(client_site) { if(client_site) {
if(client_site == CLIENTSITE(This)) if(client_site == &This->IOleClientSite_iface)
IOleObject_SetClientSite(oleobj, NULL); IOleObject_SetClientSite(oleobj, NULL);
IOleClientSite_Release(client_site); IOleClientSite_Release(client_site);
} }
...@@ -408,19 +408,19 @@ static HRESULT WINAPI ClOleCommandTarget_QueryInterface(IOleCommandTarget *iface ...@@ -408,19 +408,19 @@ static HRESULT WINAPI ClOleCommandTarget_QueryInterface(IOleCommandTarget *iface
REFIID riid, void **ppv) REFIID riid, void **ppv)
{ {
DocHost *This = OLECMD_THIS(iface); DocHost *This = OLECMD_THIS(iface);
return IOleClientSite_QueryInterface(CLIENTSITE(This), riid, ppv); return IOleClientSite_QueryInterface(&This->IOleClientSite_iface, riid, ppv);
} }
static ULONG WINAPI ClOleCommandTarget_AddRef(IOleCommandTarget *iface) static ULONG WINAPI ClOleCommandTarget_AddRef(IOleCommandTarget *iface)
{ {
DocHost *This = OLECMD_THIS(iface); DocHost *This = OLECMD_THIS(iface);
return IOleClientSite_AddRef(CLIENTSITE(This)); return IOleClientSite_AddRef(&This->IOleClientSite_iface);
} }
static ULONG WINAPI ClOleCommandTarget_Release(IOleCommandTarget *iface) static ULONG WINAPI ClOleCommandTarget_Release(IOleCommandTarget *iface)
{ {
DocHost *This = OLECMD_THIS(iface); DocHost *This = OLECMD_THIS(iface);
return IOleClientSite_Release(CLIENTSITE(This)); return IOleClientSite_Release(&This->IOleClientSite_iface);
} }
static HRESULT WINAPI ClOleCommandTarget_QueryStatus(IOleCommandTarget *iface, static HRESULT WINAPI ClOleCommandTarget_QueryStatus(IOleCommandTarget *iface,
...@@ -495,19 +495,19 @@ static HRESULT WINAPI DocHostUIHandler_QueryInterface(IDocHostUIHandler2 *iface, ...@@ -495,19 +495,19 @@ static HRESULT WINAPI DocHostUIHandler_QueryInterface(IDocHostUIHandler2 *iface,
REFIID riid, void **ppv) REFIID riid, void **ppv)
{ {
DocHost *This = DOCHOSTUI_THIS(iface); DocHost *This = DOCHOSTUI_THIS(iface);
return IOleClientSite_QueryInterface(CLIENTSITE(This), riid, ppv); return IOleClientSite_QueryInterface(&This->IOleClientSite_iface, riid, ppv);
} }
static ULONG WINAPI DocHostUIHandler_AddRef(IDocHostUIHandler2 *iface) static ULONG WINAPI DocHostUIHandler_AddRef(IDocHostUIHandler2 *iface)
{ {
DocHost *This = DOCHOSTUI_THIS(iface); DocHost *This = DOCHOSTUI_THIS(iface);
return IOleClientSite_AddRef(CLIENTSITE(This)); return IOleClientSite_AddRef(&This->IOleClientSite_iface);
} }
static ULONG WINAPI DocHostUIHandler_Release(IDocHostUIHandler2 *iface) static ULONG WINAPI DocHostUIHandler_Release(IDocHostUIHandler2 *iface)
{ {
DocHost *This = DOCHOSTUI_THIS(iface); DocHost *This = DOCHOSTUI_THIS(iface);
return IOleClientSite_Release(CLIENTSITE(This)); return IOleClientSite_Release(&This->IOleClientSite_iface);
} }
static HRESULT WINAPI DocHostUIHandler_ShowContextMenu(IDocHostUIHandler2 *iface, static HRESULT WINAPI DocHostUIHandler_ShowContextMenu(IDocHostUIHandler2 *iface,
...@@ -728,19 +728,19 @@ static HRESULT WINAPI PropertyNotifySink_QueryInterface(IPropertyNotifySink *ifa ...@@ -728,19 +728,19 @@ static HRESULT WINAPI PropertyNotifySink_QueryInterface(IPropertyNotifySink *ifa
REFIID riid, void **ppv) REFIID riid, void **ppv)
{ {
DocHost *This = PROPNOTIF_THIS(iface); DocHost *This = PROPNOTIF_THIS(iface);
return IOleClientSite_QueryInterface(CLIENTSITE(This), riid, ppv); return IOleClientSite_QueryInterface(&This->IOleClientSite_iface, riid, ppv);
} }
static ULONG WINAPI PropertyNotifySink_AddRef(IPropertyNotifySink *iface) static ULONG WINAPI PropertyNotifySink_AddRef(IPropertyNotifySink *iface)
{ {
DocHost *This = PROPNOTIF_THIS(iface); DocHost *This = PROPNOTIF_THIS(iface);
return IOleClientSite_AddRef(CLIENTSITE(This)); return IOleClientSite_AddRef(&This->IOleClientSite_iface);
} }
static ULONG WINAPI PropertyNotifySink_Release(IPropertyNotifySink *iface) static ULONG WINAPI PropertyNotifySink_Release(IPropertyNotifySink *iface)
{ {
DocHost *This = PROPNOTIF_THIS(iface); DocHost *This = PROPNOTIF_THIS(iface);
return IOleClientSite_Release(CLIENTSITE(This)); return IOleClientSite_Release(&This->IOleClientSite_iface);
} }
static HRESULT WINAPI PropertyNotifySink_OnChanged(IPropertyNotifySink *iface, DISPID dispID) static HRESULT WINAPI PropertyNotifySink_OnChanged(IPropertyNotifySink *iface, DISPID dispID)
......
...@@ -56,13 +56,13 @@ static HRESULT WINAPI InPlaceFrame_QueryInterface(IOleInPlaceFrame *iface, ...@@ -56,13 +56,13 @@ static HRESULT WINAPI InPlaceFrame_QueryInterface(IOleInPlaceFrame *iface,
static ULONG WINAPI InPlaceFrame_AddRef(IOleInPlaceFrame *iface) static ULONG WINAPI InPlaceFrame_AddRef(IOleInPlaceFrame *iface)
{ {
DocHost *This = INPLACEFRAME_THIS(iface); DocHost *This = INPLACEFRAME_THIS(iface);
return IOleClientSite_AddRef(CLIENTSITE(This)); return IOleClientSite_AddRef(&This->IOleClientSite_iface);
} }
static ULONG WINAPI InPlaceFrame_Release(IOleInPlaceFrame *iface) static ULONG WINAPI InPlaceFrame_Release(IOleInPlaceFrame *iface)
{ {
DocHost *This = INPLACEFRAME_THIS(iface); DocHost *This = INPLACEFRAME_THIS(iface);
return IOleClientSite_Release(CLIENTSITE(This)); return IOleClientSite_Release(&This->IOleClientSite_iface);
} }
static HRESULT WINAPI InPlaceFrame_GetWindow(IOleInPlaceFrame *iface, HWND *phwnd) static HRESULT WINAPI InPlaceFrame_GetWindow(IOleInPlaceFrame *iface, HWND *phwnd)
......
...@@ -178,7 +178,7 @@ static ULONG WINAPI BindStatusCallback_Release(IBindStatusCallback *iface) ...@@ -178,7 +178,7 @@ static ULONG WINAPI BindStatusCallback_Release(IBindStatusCallback *iface)
if(!ref) { if(!ref) {
if(This->doc_host) if(This->doc_host)
IOleClientSite_Release(CLIENTSITE(This->doc_host)); IOleClientSite_Release(&This->doc_host->IOleClientSite_iface);
if(This->post_data) if(This->post_data)
GlobalFree(This->post_data); GlobalFree(This->post_data);
SysFreeString(This->headers); SysFreeString(This->headers);
...@@ -254,7 +254,7 @@ static HRESULT WINAPI BindStatusCallback_OnStopBinding(IBindStatusCallback *ifac ...@@ -254,7 +254,7 @@ static HRESULT WINAPI BindStatusCallback_OnStopBinding(IBindStatusCallback *ifac
set_status_text(This, emptyW); set_status_text(This, emptyW);
if(This->doc_host) { if(This->doc_host) {
IOleClientSite_Release(CLIENTSITE(This->doc_host)); IOleClientSite_Release(&This->doc_host->IOleClientSite_iface);
This->doc_host = NULL; This->doc_host = NULL;
} }
...@@ -390,7 +390,7 @@ static BindStatusCallback *create_callback(DocHost *doc_host, LPCWSTR url, PBYTE ...@@ -390,7 +390,7 @@ static BindStatusCallback *create_callback(DocHost *doc_host, LPCWSTR url, PBYTE
ret->headers = headers ? SysAllocString(headers) : NULL; ret->headers = headers ? SysAllocString(headers) : NULL;
ret->doc_host = doc_host; ret->doc_host = doc_host;
IOleClientSite_AddRef(CLIENTSITE(doc_host)); IOleClientSite_AddRef(&doc_host->IOleClientSite_iface);
if(post_data) { if(post_data) {
ret->post_data = GlobalAlloc(0, post_data_len); ret->post_data = GlobalAlloc(0, post_data_len);
...@@ -546,7 +546,7 @@ static HRESULT bind_to_object(DocHost *This, IMoniker *mon, LPCWSTR url, IBindCt ...@@ -546,7 +546,7 @@ static HRESULT bind_to_object(DocHost *This, IMoniker *mon, LPCWSTR url, IBindCt
return hres; return hres;
IBindCtx_RegisterObjectParam(bindctx, (LPOLESTR)SZ_HTML_CLIENTSITE_OBJECTPARAM, IBindCtx_RegisterObjectParam(bindctx, (LPOLESTR)SZ_HTML_CLIENTSITE_OBJECTPARAM,
(IUnknown*)CLIENTSITE(This)); (IUnknown*)&This->IOleClientSite_iface);
hres = IMoniker_BindToObject(mon, bindctx, NULL, &IID_IUnknown, (void**)&unk); hres = IMoniker_BindToObject(mon, bindctx, NULL, &IID_IUnknown, (void**)&unk);
if(SUCCEEDED(hres)) { if(SUCCEEDED(hres)) {
......
...@@ -93,7 +93,7 @@ typedef struct _IDocHostContainerVtbl ...@@ -93,7 +93,7 @@ typedef struct _IDocHostContainerVtbl
} IDocHostContainerVtbl; } IDocHostContainerVtbl;
struct DocHost { struct DocHost {
const IOleClientSiteVtbl *lpOleClientSiteVtbl; IOleClientSite IOleClientSite_iface;
const IOleInPlaceSiteVtbl *lpOleInPlaceSiteVtbl; const IOleInPlaceSiteVtbl *lpOleInPlaceSiteVtbl;
const IDocHostUIHandler2Vtbl *lpDocHostUIHandlerVtbl; const IDocHostUIHandler2Vtbl *lpDocHostUIHandlerVtbl;
const IOleDocumentSiteVtbl *lpOleDocumentSiteVtbl; const IOleDocumentSiteVtbl *lpOleDocumentSiteVtbl;
...@@ -197,7 +197,6 @@ struct InternetExplorer { ...@@ -197,7 +197,6 @@ struct InternetExplorer {
#define CONPTCONT(x) ((IConnectionPointContainer*) &(x)->lpConnectionPointContainerVtbl) #define CONPTCONT(x) ((IConnectionPointContainer*) &(x)->lpConnectionPointContainerVtbl)
#define OLECMD(x) ((IOleCommandTarget*) &(x)->lpOleCommandTargetVtbl) #define OLECMD(x) ((IOleCommandTarget*) &(x)->lpOleCommandTargetVtbl)
#define CLIENTSITE(x) ((IOleClientSite*) &(x)->lpOleClientSiteVtbl)
#define INPLACESITE(x) ((IOleInPlaceSite*) &(x)->lpOleInPlaceSiteVtbl) #define INPLACESITE(x) ((IOleInPlaceSite*) &(x)->lpOleInPlaceSiteVtbl)
#define DOCHOSTUI(x) ((IDocHostUIHandler*) &(x)->lpDocHostUIHandlerVtbl) #define DOCHOSTUI(x) ((IDocHostUIHandler*) &(x)->lpDocHostUIHandlerVtbl)
#define DOCHOSTUI2(x) ((IDocHostUIHandler2*) &(x)->lpDocHostUIHandlerVtbl) #define DOCHOSTUI2(x) ((IDocHostUIHandler2*) &(x)->lpDocHostUIHandlerVtbl)
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment