Jacek Caban : mshtml: Forward HTMLStyle IUnknown calls to IHTMLCSSStyleDeclaration implementation.
Alexandre Julliard
julliard at winehq.org
Mon Mar 25 16:54:57 CDT 2019
Module: wine
Branch: master
Commit: 0097dd1c6de8965d294c4d2d538aea189a9a3192
URL: https://source.winehq.org/git/wine.git/?a=commit;h=0097dd1c6de8965d294c4d2d538aea189a9a3192
Author: Jacek Caban <jacek at 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 at codeweavers.com>
Signed-off-by: Alexandre Julliard <julliard at 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,
More information about the wine-cvs
mailing list