Jacek Caban : mshtml: Share nsrow reference with nsnode.
Module: wine Branch: master Commit: b1ed6b2dd61811f97de9b095eb151cf4e6c50aa5 URL: http://source.winehq.org/git/wine.git/?a=commit;h=b1ed6b2dd61811f97de9b095eb... Author: Jacek Caban <jacek(a)codeweavers.com> Date: Thu Jun 28 11:19:41 2012 +0200 mshtml: Share nsrow reference with nsnode. --- dlls/mshtml/htmltablerow.c | 24 +++++++----------------- 1 files changed, 7 insertions(+), 17 deletions(-) diff --git a/dlls/mshtml/htmltablerow.c b/dlls/mshtml/htmltablerow.c index db5c7f2..66cf711 100644 --- a/dlls/mshtml/htmltablerow.c +++ b/dlls/mshtml/htmltablerow.c @@ -17,6 +17,7 @@ */ #include <stdarg.h> +#include <assert.h> #define COBJMACROS @@ -287,19 +288,9 @@ static HRESULT HTMLTableRow_QI(HTMLDOMNode *iface, REFIID riid, void **ppv) return HTMLElement_QI(&This->element.node, riid, ppv); } -static void HTMLTableRow_destructor(HTMLDOMNode *iface) -{ - HTMLTableRow *This = impl_from_HTMLDOMNode(iface); - - if(This->nsrow) - nsIDOMHTMLTableRowElement_Release(This->nsrow); - - HTMLElement_destructor(&This->element.node); -} - static const NodeImplVtbl HTMLTableRowImplVtbl = { HTMLTableRow_QI, - HTMLTableRow_destructor, + HTMLElement_destructor, HTMLElement_clone, HTMLElement_get_attr_col }; @@ -329,14 +320,13 @@ HRESULT HTMLTableRow_Create(HTMLDocumentNode *doc, nsIDOMHTMLElement *nselem, HT ret->IHTMLTableRow_iface.lpVtbl = &HTMLTableRowVtbl; ret->element.node.vtbl = &HTMLTableRowImplVtbl; + HTMLElement_Init(&ret->element, doc, nselem, &HTMLTableRow_dispex); + nsres = nsIDOMHTMLElement_QueryInterface(nselem, &IID_nsIDOMHTMLTableRowElement, (void**)&ret->nsrow); - if(NS_FAILED(nsres)) { - ERR("Could not get nsIDOMHTMLTableRowElement iface: %08x\n", nsres); - heap_free(ret); - return E_OUTOFMEMORY; - } - HTMLElement_Init(&ret->element, doc, nselem, &HTMLTableRow_dispex); + /* Share nsrow reference with nsnode */ + assert(nsres == NS_OK && (nsIDOMNode*)ret->nsrow == ret->element.node.nsnode); + nsIDOMNode_Release(ret->element.node.nsnode); *elem = &ret->element; return S_OK;
participants (1)
-
Alexandre Julliard