Michael Stefaniuc : d3drm: Make IDirect3DRMx_CreateFrame() more forgiving about the parent frame.
Module: wine Branch: master Commit: 9e183990f2d1c2b25e2fd132f4d63f81f6a7ff02 URL: http://source.winehq.org/git/wine.git/?a=commit;h=9e183990f2d1c2b25e2fd132f4... Author: Michael Stefaniuc <mstefani(a)redhat.de> Date: Sat Jun 30 01:13:56 2012 +0200 d3drm: Make IDirect3DRMx_CreateFrame() more forgiving about the parent frame. --- dlls/d3drm/frame.c | 21 +++++++++++---------- 1 files changed, 11 insertions(+), 10 deletions(-) diff --git a/dlls/d3drm/frame.c b/dlls/d3drm/frame.c index 10ddb72..025c955 100644 --- a/dlls/d3drm/frame.c +++ b/dlls/d3drm/frame.c @@ -2671,6 +2671,7 @@ static inline IDirect3DRMFrameImpl *unsafe_impl_from_IDirect3DRMFrame3(IDirect3D HRESULT Direct3DRMFrame_create(REFIID riid, IUnknown* parent, IUnknown** ret_iface) { IDirect3DRMFrameImpl* object; + HRESULT hr; TRACE("(%s, %p, %p)\n", wine_dbgstr_guid(riid), parent, ret_iface); @@ -2687,18 +2688,18 @@ HRESULT Direct3DRMFrame_create(REFIID riid, IUnknown* parent, IUnknown** ret_ifa memcpy(&object->transform[0][0], &identity[0][0], sizeof(D3DRMMATRIX4D)); - if (IsEqualGUID(riid, &IID_IDirect3DRMFrame3)) + if (parent) { - if (parent) - IDirect3DRMFrame3_AddChild((IDirect3DRMFrame3*)parent, &object->IDirect3DRMFrame3_iface); - *ret_iface = (IUnknown*)&object->IDirect3DRMFrame3_iface; - } - else - { - if (parent) - IDirect3DRMFrame2_AddChild((IDirect3DRMFrame2*)parent, (IDirect3DRMFrame*)&object->IDirect3DRMFrame2_iface); - *ret_iface = (IUnknown*)&object->IDirect3DRMFrame2_iface; + IDirect3DRMFrame3 *p; + + hr = IDirect3DRMFrame_QueryInterface(parent, &IID_IDirect3DRMFrame3, (void**)&p); + if (hr != S_OK) + return hr; + IDirect3DRMFrame_Release(parent); + IDirect3DRMFrame3_AddChild(p, &object->IDirect3DRMFrame3_iface); } + hr = IDirect3DRMFrame3_QueryInterface(&object->IDirect3DRMFrame3_iface, riid, (void**)ret_iface); + IDirect3DRMFrame3_Release(&object->IDirect3DRMFrame3_iface); return S_OK; }
participants (1)
-
Alexandre Julliard