>From 61cf497ac8be76e0faca3d039ab2dc3aca56dcb1 Mon Sep 17 00:00:00 2001 From: Alistair Leslie-Hughes Date: Mon, 31 Aug 2009 15:18:00 +1000 Subject: [PATCH] Add IDispatchEx support to IXMLDOMElement To: wine-patches --- dlls/msxml3/element.c | 18 +++++++++++++++++- dlls/msxml3/tests/domdoc.c | 2 ++ 2 files changed, 19 insertions(+), 1 deletions(-) diff --git a/dlls/msxml3/element.c b/dlls/msxml3/element.c index 6590e5b..531d43e 100644 --- a/dlls/msxml3/element.c +++ b/dlls/msxml3/element.c @@ -74,6 +74,10 @@ static HRESULT WINAPI domelem_QueryInterface( { *ppvObject = IXMLDOMNode_from_impl(This->node); } + else if(dispex_query_interface(&This->node->dispex, riid, ppvObject)) + { + return *ppvObject ? S_OK : E_NOINTERFACE; + } else { FIXME("interface %s not implemented\n", debugstr_guid(riid)); @@ -751,6 +755,18 @@ static const struct IXMLDOMElementVtbl domelem_vtbl = domelem_normalize, }; +static const tid_t domelem_iface_tids[] = { + IXMLDOMElement_tid, + 0 +}; + +static dispex_static_data_t domelem_dispex = { + NULL, + IXMLDOMElement_tid, + NULL, + domelem_iface_tids +}; + IUnknown* create_element( xmlNodePtr element ) { domelem *This; @@ -762,7 +778,7 @@ IUnknown* create_element( xmlNodePtr element ) This->lpVtbl = &domelem_vtbl; This->ref = 1; - This->node = create_basic_node( element, (IUnknown*)&This->lpVtbl, NULL ); + This->node = create_basic_node( element, (IUnknown*)&This->lpVtbl, &domelem_dispex ); if(!This->node) { HeapFree(GetProcessHeap(), 0, This); diff --git a/dlls/msxml3/tests/domdoc.c b/dlls/msxml3/tests/domdoc.c index 91e34f5..2de9843 100644 --- a/dlls/msxml3/tests/domdoc.c +++ b/dlls/msxml3/tests/domdoc.c @@ -596,6 +596,8 @@ static void test_domdoc( void ) ok( r == S_OK, "should be a document element\n"); if( element ) { + test_disp((IUnknown*)element); + IObjectIdentity *ident; BSTR tag = NULL; -- 1.6.2.5