Module: wine Branch: master Commit: 0097dd1c6de8965d294c4d2d538aea189a9a3192 URL: https://source.winehq.org/git/wine.git/?a=commit;h=0097dd1c6de8965d294c4d2d5...
Author: Jacek Caban jacek@codeweavers.com Date: Mon Mar 25 15:13:30 2019 +0100
mshtml: Forward HTMLStyle IUnknown calls to IHTMLCSSStyleDeclaration implementation.
Signed-off-by: Jacek Caban jacek@codeweavers.com Signed-off-by: Alexandre Julliard julliard@winehq.org
---
dlls/mshtml/htmlstyle.c | 103 ++++++++++++++++++++++++------------------------ 1 file changed, 51 insertions(+), 52 deletions(-)
diff --git a/dlls/mshtml/htmlstyle.c b/dlls/mshtml/htmlstyle.c index 2637145..b5e918b 100644 --- a/dlls/mshtml/htmlstyle.c +++ b/dlls/mshtml/htmlstyle.c @@ -1280,65 +1280,19 @@ static inline HTMLStyle *impl_from_IHTMLStyle(IHTMLStyle *iface) static HRESULT WINAPI HTMLStyle_QueryInterface(IHTMLStyle *iface, REFIID riid, void **ppv) { HTMLStyle *This = impl_from_IHTMLStyle(iface); - - TRACE("(%p)->(%s %p)\n", This, debugstr_mshtml_guid(riid), ppv); - - if(IsEqualGUID(&IID_IUnknown, riid)) { - *ppv = &This->IHTMLStyle_iface; - }else if(IsEqualGUID(&IID_IHTMLCSSStyleDeclaration, riid)) { - *ppv = &This->IHTMLCSSStyleDeclaration_iface; - }else if(IsEqualGUID(&IID_IHTMLCSSStyleDeclaration2, riid)) { - *ppv = &This->IHTMLCSSStyleDeclaration2_iface; - }else if(IsEqualGUID(&IID_IHTMLStyle, riid)) { - *ppv = &This->IHTMLStyle_iface; - }else if(IsEqualGUID(&IID_IHTMLStyle2, riid)) { - *ppv = &This->IHTMLStyle2_iface; - }else if(IsEqualGUID(&IID_IHTMLStyle3, riid)) { - *ppv = &This->IHTMLStyle3_iface; - }else if(IsEqualGUID(&IID_IHTMLStyle4, riid)) { - *ppv = &This->IHTMLStyle4_iface; - }else if(IsEqualGUID(&IID_IHTMLStyle5, riid)) { - *ppv = &This->IHTMLStyle5_iface; - }else if(IsEqualGUID(&IID_IHTMLStyle6, riid)) { - *ppv = &This->IHTMLStyle6_iface; - }else if(dispex_query_interface(&This->css_style.dispex, riid, ppv)) { - return *ppv ? S_OK : E_NOINTERFACE; - }else { - *ppv = NULL; - WARN("unsupported iface %s\n", debugstr_mshtml_guid(riid)); - return E_NOINTERFACE; - } - - IUnknown_AddRef((IUnknown*)*ppv); - return S_OK; + return IHTMLCSSStyleDeclaration_QueryInterface(&This->IHTMLCSSStyleDeclaration_iface, riid, ppv); }
static ULONG WINAPI HTMLStyle_AddRef(IHTMLStyle *iface) { HTMLStyle *This = impl_from_IHTMLStyle(iface); - LONG ref = InterlockedIncrement(&This->ref); - - TRACE("(%p) ref=%d\n", This, ref); - - return ref; + return IHTMLCSSStyleDeclaration_AddRef(&This->IHTMLCSSStyleDeclaration_iface); }
static ULONG WINAPI HTMLStyle_Release(IHTMLStyle *iface) { HTMLStyle *This = impl_from_IHTMLStyle(iface); - LONG ref = InterlockedDecrement(&This->ref); - - TRACE("(%p) ref=%d\n", This, ref); - - if(!ref) { - assert(!This->elem); - if(This->css_style.nsstyle) - nsIDOMCSSStyleDeclaration_Release(This->css_style.nsstyle); - release_dispex(&This->css_style.dispex); - heap_free(This); - } - - return ref; + return IHTMLCSSStyleDeclaration_Release(&This->IHTMLCSSStyleDeclaration_iface); }
static HRESULT WINAPI HTMLStyle_GetTypeInfoCount(IHTMLStyle *iface, UINT *pctinfo) @@ -5098,19 +5052,64 @@ static HRESULT WINAPI HTMLCSSStyleDeclaration_QueryInterface(IHTMLCSSStyleDeclar REFIID riid, void **ppv) { HTMLStyle *This = impl_from_IHTMLCSSStyleDeclaration(iface); - return IHTMLStyle_QueryInterface(&This->IHTMLStyle_iface, riid, ppv); + + TRACE("(%p)->(%s %p)\n", This, debugstr_mshtml_guid(riid), ppv); + + if(IsEqualGUID(&IID_IUnknown, riid)) { + *ppv = &This->IHTMLStyle_iface; + }else if(IsEqualGUID(&IID_IHTMLCSSStyleDeclaration, riid)) { + *ppv = &This->IHTMLCSSStyleDeclaration_iface; + }else if(IsEqualGUID(&IID_IHTMLCSSStyleDeclaration2, riid)) { + *ppv = &This->IHTMLCSSStyleDeclaration2_iface; + }else if(IsEqualGUID(&IID_IHTMLStyle, riid)) { + *ppv = &This->IHTMLStyle_iface; + }else if(IsEqualGUID(&IID_IHTMLStyle2, riid)) { + *ppv = &This->IHTMLStyle2_iface; + }else if(IsEqualGUID(&IID_IHTMLStyle3, riid)) { + *ppv = &This->IHTMLStyle3_iface; + }else if(IsEqualGUID(&IID_IHTMLStyle4, riid)) { + *ppv = &This->IHTMLStyle4_iface; + }else if(IsEqualGUID(&IID_IHTMLStyle5, riid)) { + *ppv = &This->IHTMLStyle5_iface; + }else if(IsEqualGUID(&IID_IHTMLStyle6, riid)) { + *ppv = &This->IHTMLStyle6_iface; + }else if(dispex_query_interface(&This->css_style.dispex, riid, ppv)) { + return *ppv ? S_OK : E_NOINTERFACE; + }else { + *ppv = NULL; + WARN("unsupported iface %s\n", debugstr_mshtml_guid(riid)); + return E_NOINTERFACE; + } + + IUnknown_AddRef((IUnknown*)*ppv); + return S_OK; }
static ULONG WINAPI HTMLCSSStyleDeclaration_AddRef(IHTMLCSSStyleDeclaration *iface) { HTMLStyle *This = impl_from_IHTMLCSSStyleDeclaration(iface); - return IHTMLStyle_AddRef(&This->IHTMLStyle_iface); + LONG ref = InterlockedIncrement(&This->ref); + + TRACE("(%p) ref=%d\n", This, ref); + + return ref; }
static ULONG WINAPI HTMLCSSStyleDeclaration_Release(IHTMLCSSStyleDeclaration *iface) { HTMLStyle *This = impl_from_IHTMLCSSStyleDeclaration(iface); - return IHTMLStyle_Release(&This->IHTMLStyle_iface); + LONG ref = InterlockedDecrement(&This->ref); + + TRACE("(%p) ref=%d\n", This, ref); + + if(!ref) { + if(This->css_style.nsstyle) + nsIDOMCSSStyleDeclaration_Release(This->css_style.nsstyle); + release_dispex(&This->css_style.dispex); + heap_free(This); + } + + return ref; }
static HRESULT WINAPI HTMLCSSStyleDeclaration_GetTypeInfoCount(IHTMLCSSStyleDeclaration *iface,