Jacek Caban : mshtml: Share nsimg reference with nsnode.
Module: wine Branch: master Commit: 8a9d3c845b76348e8c2fc038e48a22e7aa5c5271 URL: http://source.winehq.org/git/wine.git/?a=commit;h=8a9d3c845b76348e8c2fc038e4... Author: Jacek Caban <jacek(a)codeweavers.com> Date: Wed Jun 27 10:56:54 2012 +0200 mshtml: Share nsimg reference with nsnode. --- dlls/mshtml/htmlimg.c | 24 +++++++----------------- 1 files changed, 7 insertions(+), 17 deletions(-) diff --git a/dlls/mshtml/htmlimg.c b/dlls/mshtml/htmlimg.c index 5d1c665..be33a71 100644 --- a/dlls/mshtml/htmlimg.c +++ b/dlls/mshtml/htmlimg.c @@ -17,6 +17,7 @@ */ #include <stdarg.h> +#include <assert.h> #define COBJMACROS @@ -621,16 +622,6 @@ static HRESULT HTMLImgElement_QI(HTMLDOMNode *iface, REFIID riid, void **ppv) return S_OK; } -static void HTMLImgElement_destructor(HTMLDOMNode *iface) -{ - HTMLImgElement *This = impl_from_HTMLDOMNode(iface); - - if(This->nsimg) - nsIDOMHTMLImageElement_Release(This->nsimg); - - HTMLElement_destructor(&This->element.node); -} - static HRESULT HTMLImgElement_get_readystate(HTMLDOMNode *iface, BSTR *p) { HTMLImgElement *This = impl_from_HTMLDOMNode(iface); @@ -640,7 +631,7 @@ static HRESULT HTMLImgElement_get_readystate(HTMLDOMNode *iface, BSTR *p) static const NodeImplVtbl HTMLImgElementImplVtbl = { HTMLImgElement_QI, - HTMLImgElement_destructor, + HTMLElement_destructor, HTMLElement_clone, HTMLElement_get_attr_col, NULL, @@ -676,14 +667,13 @@ HRESULT HTMLImgElement_Create(HTMLDocumentNode *doc, nsIDOMHTMLElement *nselem, ret->IHTMLImgElement_iface.lpVtbl = &HTMLImgElementVtbl; ret->element.node.vtbl = &HTMLImgElementImplVtbl; + HTMLElement_Init(&ret->element, doc, nselem, &HTMLImgElement_dispex); + nsres = nsIDOMHTMLElement_QueryInterface(nselem, &IID_nsIDOMHTMLImageElement, (void**)&ret->nsimg); - if(NS_FAILED(nsres)) { - ERR("Could not get nsIDOMHTMLImageElement: %08x\n", nsres); - heap_free(ret); - return E_FAIL; - } - HTMLElement_Init(&ret->element, doc, nselem, &HTMLImgElement_dispex); + /* Share nsimg reference with nsnode */ + assert(nsres == NS_OK && (nsIDOMNode*)ret->nsimg == ret->element.node.nsnode); + nsIDOMNode_Release(ret->element.node.nsnode); *elem = &ret->element; return S_OK;
participants (1)
-
Alexandre Julliard