[PATCH 1/2] d3drm: Fix QueryInterface for IDirect3DRMTexture*.

Aaryaman Vasishta jem456.vasishta at gmail.com
Mon Jan 18 12:57:22 CST 2016


Signed-off-by: Aaryaman Vasishta <jem456.vasishta at gmail.com>
---
 dlls/d3drm/texture.c | 11 ++++++++---
 1 file changed, 8 insertions(+), 3 deletions(-)

diff --git a/dlls/d3drm/texture.c b/dlls/d3drm/texture.c
index 46d968a..7d26ef4 100644
--- a/dlls/d3drm/texture.c
+++ b/dlls/d3drm/texture.c
@@ -679,10 +679,15 @@ static HRESULT WINAPI d3drm_texture3_QueryInterface(IDirect3DRMTexture3 *iface,
 
     TRACE("iface %p, riid %s, out %p.\n", iface, debugstr_guid(riid), out);
 
-    if (IsEqualGUID(riid, &IID_IDirect3DRMTexture2)
-            || IsEqualGUID(riid, &IID_IDirect3DRMTexture)
+    if (IsEqualGUID(riid, &IID_IDirect3DRMTexture)
+            || IsEqualGUID(riid, &IID_IDirect3DRMVisual)
+            || IsEqualGUID(riid, &IID_IDirect3DRMObject)
             || IsEqualGUID(riid, &IID_IUnknown))
     {
+        *out = &texture->IDirect3DRMTexture_iface;
+    }
+    else if (IsEqualGUID(riid, &IID_IDirect3DRMTexture2))
+    {
         *out = &texture->IDirect3DRMTexture2_iface;
     }
     else if (IsEqualGUID(riid, &IID_IDirect3DRMTexture3))
@@ -693,7 +698,7 @@ static HRESULT WINAPI d3drm_texture3_QueryInterface(IDirect3DRMTexture3 *iface,
     {
         *out = NULL;
         WARN("%s not implemented, returning E_NOINTERFACE.\n", debugstr_guid(riid));
-        return E_NOINTERFACE;
+        return CLASS_E_CLASSNOTAVAILABLE;
     }
 
     IUnknown_AddRef((IUnknown *)*out);
-- 
2.3.2 (Apple Git-55)




More information about the wine-patches mailing list