diff --git a/dlls/mshtml/htmldoc.c b/dlls/mshtml/htmldoc.c index 05eb664cc6e..a0ab79d7d57 100644 --- a/dlls/mshtml/htmldoc.c +++ b/dlls/mshtml/htmldoc.c @@ -2428,6 +2428,8 @@ HRESULT HTMLDocument_Create(IUnknown *pUnkOuter, REFIID riid, void** ppvObject) doc->usermode = UNKNOWN_USERMODE; + init_binding_ui(doc); + hres = create_nscontainer(doc, &doc->nscontainer); if(FAILED(hres)) { ERR("Failed to init Gecko, returning CLASS_E_CLASSNOTAVAILABLE\n"); diff --git a/dlls/mshtml/mshtml_private.h b/dlls/mshtml/mshtml_private.h index 7eaaa572a0e..3eb81b900ff 100644 --- a/dlls/mshtml/mshtml_private.h +++ b/dlls/mshtml/mshtml_private.h @@ -453,6 +453,8 @@ struct HTMLDocumentObj { ICustomDoc ICustomDoc_iface; ITargetContainer ITargetContainer_iface; + IWindowForBindingUI IWindowForBindingUI_iface; + LONG ref; NSContainer *nscontainer; @@ -657,6 +659,7 @@ void HTMLDocument_Service_Init(HTMLDocument*) DECLSPEC_HIDDEN; void HTMLDocument_Hlink_Init(HTMLDocument*) DECLSPEC_HIDDEN; void TargetContainer_Init(HTMLDocumentObj*) DECLSPEC_HIDDEN; +void init_binding_ui(HTMLDocumentObj*) DECLSPEC_HIDDEN; void HTMLDocumentNode_SecMgr_Init(HTMLDocumentNode*) DECLSPEC_HIDDEN; diff --git a/dlls/mshtml/service.c b/dlls/mshtml/service.c index 9cafbf05093..56744e6d440 100644 --- a/dlls/mshtml/service.c +++ b/dlls/mshtml/service.c @@ -254,6 +254,11 @@ static HRESULT WINAPI ServiceProvider_QueryService(IServiceProvider *iface, REFG return IHTMLDocument2_QueryInterface(&This->IHTMLDocument2_iface, riid, ppv); } + if(IsEqualGUID(&IID_IWindowForBindingUI, guidService)) { + TRACE("IID_IWindowForBindingUI\n"); + return IWindowForBindingUI_QueryInterface(&This->doc_obj->IWindowForBindingUI_iface, riid, ppv); + } + TRACE("(%p)->(%s %s %p)\n", This, debugstr_guid(guidService), debugstr_guid(riid), ppv); if(This->doc_obj->client) { diff --git a/dlls/mshtml/view.c b/dlls/mshtml/view.c index 3852046cdb3..67019871eb2 100644 --- a/dlls/mshtml/view.c +++ b/dlls/mshtml/view.c @@ -912,3 +912,59 @@ void HTMLDocument_View_Init(HTMLDocument *This) This->IOleDocumentView_iface.lpVtbl = &OleDocumentViewVtbl; This->IViewObjectEx_iface.lpVtbl = &ViewObjectVtbl; } + +static inline HTMLDocumentObj *impl_from_IWindowForBindingUI(IWindowForBindingUI *iface) +{ + return CONTAINING_RECORD(iface, HTMLDocumentObj, IWindowForBindingUI_iface); +} + +static HRESULT WINAPI WindowForBindingUI_QueryInterface(IWindowForBindingUI *iface, REFIID riid, void **ppv) +{ + HTMLDocumentObj *This = impl_from_IWindowForBindingUI(iface); + + if(IsEqualGUID(&IID_IUnknown, riid)) { + TRACE("(%p)->(IID_IUnknown %p)\n", This, ppv); + *ppv = &This->IWindowForBindingUI_iface; + }else if(IsEqualGUID(&IID_IWindowForBindingUI, riid)) { + TRACE("(%p)->(IID_IWindowForBindingUI %p)\n", This, ppv); + *ppv = &This->IWindowForBindingUI_iface; + }else { + WARN("(%p)->(%s %p)\n", This, debugstr_guid(riid), ppv); + *ppv = NULL; + return E_NOINTERFACE; + } + + IUnknown_AddRef((IUnknown*)*ppv); + return S_OK; +} + +static ULONG WINAPI WindowForBindingUI_AddRef(IWindowForBindingUI *iface) +{ + HTMLDocumentObj *This = impl_from_IWindowForBindingUI(iface); + return htmldoc_addref(&This->basedoc); +} + +static ULONG WINAPI WindowForBindingUI_Release(IWindowForBindingUI *iface) +{ + HTMLDocumentObj *This = impl_from_IWindowForBindingUI(iface); + return htmldoc_release(&This->basedoc); +} + +static HRESULT WINAPI WindowForBindingUI_GetWindow(IWindowForBindingUI *iface, REFGUID rguidReason, HWND *phwnd) +{ + HTMLDocumentObj *This = impl_from_IWindowForBindingUI(iface); + FIXME("(%p)->(%s %p)\n", This, debugstr_guid(rguidReason), phwnd); + return E_NOTIMPL; +} + +static const IWindowForBindingUIVtbl WindowForBindingUIVtbl = { + WindowForBindingUI_QueryInterface, + WindowForBindingUI_AddRef, + WindowForBindingUI_Release, + WindowForBindingUI_GetWindow +}; + +void init_binding_ui(HTMLDocumentObj *doc) +{ + doc->IWindowForBindingUI_iface.lpVtbl = &WindowForBindingUIVtbl; +}