Nikolay Sivov : d3drm: Fix IDirect3DRMMeshBuilder:: QueryInterface to support IDirect3DRMObject and IDirect3DRMVisual.
Alexandre Julliard
julliard at winehq.org
Mon Jun 5 16:56:31 CDT 2017
Module: wine
Branch: master
Commit: 99e0442acc123a32139cb0a2a3c365a87b33b577
URL: http://source.winehq.org/git/wine.git/?a=commit;h=99e0442acc123a32139cb0a2a3c365a87b33b577
Author: Nikolay Sivov <nsivov at codeweavers.com>
Date: Mon Jun 5 02:07:32 2017 +0300
d3drm: Fix IDirect3DRMMeshBuilder::QueryInterface to support IDirect3DRMObject and IDirect3DRMVisual.
Signed-off-by: Nikolay Sivov <nsivov at codeweavers.com>
Signed-off-by: Henri Verbeet <hverbeet at codeweavers.com>
Signed-off-by: Alexandre Julliard <julliard at winehq.org>
---
dlls/d3drm/meshbuilder.c | 2 ++
dlls/d3drm/tests/d3drm.c | 27 +++++++++++++++++++++++++++
2 files changed, 29 insertions(+)
diff --git a/dlls/d3drm/meshbuilder.c b/dlls/d3drm/meshbuilder.c
index 82f809e..e53457d 100644
--- a/dlls/d3drm/meshbuilder.c
+++ b/dlls/d3drm/meshbuilder.c
@@ -361,6 +361,8 @@ static HRESULT WINAPI d3drm_mesh_builder2_QueryInterface(IDirect3DRMMeshBuilder2
if (IsEqualGUID(riid, &IID_IDirect3DRMMeshBuilder2)
|| IsEqualGUID(riid, &IID_IDirect3DRMMeshBuilder)
+ || IsEqualGUID(riid, &IID_IDirect3DRMVisual)
+ || IsEqualGUID(riid, &IID_IDirect3DRMObject)
|| IsEqualGUID(riid, &IID_IUnknown))
{
*out = &mesh_builder->IDirect3DRMMeshBuilder2_iface;
diff --git a/dlls/d3drm/tests/d3drm.c b/dlls/d3drm/tests/d3drm.c
index 9985d03..e1091be 100644
--- a/dlls/d3drm/tests/d3drm.c
+++ b/dlls/d3drm/tests/d3drm.c
@@ -203,6 +203,7 @@ static void test_MeshBuilder(void)
HRESULT hr;
IDirect3DRM *d3drm;
IDirect3DRMMeshBuilder *pMeshBuilder;
+ IDirect3DRMMeshBuilder3 *meshbuilder3;
IDirect3DRMMesh *mesh;
D3DRMLOADMEMORY info;
int val;
@@ -215,6 +216,7 @@ static void test_MeshBuilder(void)
DWORD size;
D3DCOLOR color;
CHAR cname[64] = {0};
+ IUnknown *unk;
hr = Direct3DRMCreate(&d3drm);
ok(hr == D3DRM_OK, "Cannot get IDirect3DRM interface (hr = %x)\n", hr);
@@ -222,6 +224,31 @@ static void test_MeshBuilder(void)
hr = IDirect3DRM_CreateMeshBuilder(d3drm, &pMeshBuilder);
ok(hr == D3DRM_OK, "Cannot get IDirect3DRMMeshBuilder interface (hr = %x)\n", hr);
+ hr = IDirect3DRMMeshBuilder_QueryInterface(pMeshBuilder, &IID_IDirect3DRMObject, (void **)&unk);
+ ok(SUCCEEDED(hr), "Failed to get IDirect3DRMObject, %#x.\n", hr);
+ ok(unk == (IUnknown *)pMeshBuilder, "Unexpected interface pointer.\n");
+ IUnknown_Release(unk);
+
+ hr = IDirect3DRMMeshBuilder_QueryInterface(pMeshBuilder, &IID_IDirect3DRMVisual, (void **)&unk);
+ ok(SUCCEEDED(hr), "Failed to get IDirect3DRMVisual, %#x.\n", hr);
+ ok(unk == (IUnknown *)pMeshBuilder, "Unexpected interface pointer.\n");
+ IUnknown_Release(unk);
+
+ hr = IDirect3DRMMeshBuilder_QueryInterface(pMeshBuilder, &IID_IDirect3DRMMeshBuilder3, (void **)&meshbuilder3);
+ ok(SUCCEEDED(hr), "Failed to get IDirect3DRMMeshBuilder3, %#x.\n", hr);
+
+ hr = IDirect3DRMMeshBuilder3_QueryInterface(meshbuilder3, &IID_IDirect3DRMObject, (void **)&unk);
+ ok(SUCCEEDED(hr), "Failed to get IDirect3DRMObject, %#x.\n", hr);
+ ok(unk == (IUnknown *)pMeshBuilder, "Unexpected interface pointer.\n");
+ IUnknown_Release(unk);
+
+ hr = IDirect3DRMMeshBuilder3_QueryInterface(meshbuilder3, &IID_IDirect3DRMVisual, (void **)&unk);
+ ok(SUCCEEDED(hr), "Failed to get IDirect3DRMVisual, %#x.\n", hr);
+ ok(unk == (IUnknown *)pMeshBuilder, "Unexpected interface pointer.\n");
+ IUnknown_Release(unk);
+
+ IDirect3DRMMeshBuilder3_Release(meshbuilder3);
+
hr = IDirect3DRMMeshBuilder_GetClassName(pMeshBuilder, NULL, cname);
ok(hr == E_INVALIDARG, "GetClassName failed with %x\n", hr);
hr = IDirect3DRMMeshBuilder_GetClassName(pMeshBuilder, NULL, NULL);
More information about the wine-cvs
mailing list