2 * Copyright 2010 Christian Costa
4 * This library is free software; you can redistribute it and/or
5 * modify it under the terms of the GNU Lesser General Public
6 * License as published by the Free Software Foundation; either
7 * version 2.1 of the License, or (at your option) any later version.
9 * This library is distributed in the hope that it will be useful,
10 * but WITHOUT ANY WARRANTY; without even the implied warranty of
11 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
12 * Lesser General Public License for more details.
14 * You should have received a copy of the GNU Lesser General Public
15 * License along with this library; if not, write to the Free Software
16 * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301, USA
21 #include "wine/test.h"
23 static HMODULE d3drm_handle
= 0;
25 static HRESULT (WINAPI
* pDirect3DRMCreate
)(LPDIRECT3DRM
* ppDirect3DRM
);
27 #define D3DRM_GET_PROC(func) \
28 p ## func = (void*)GetProcAddress(d3drm_handle, #func); \
30 trace("GetProcAddress(%s) failed\n", #func); \
31 FreeLibrary(d3drm_handle); \
35 static BOOL
InitFunctionPtrs(void)
37 d3drm_handle
= LoadLibraryA("d3drm.dll");
41 skip("Could not load d3drm.dll\n");
45 D3DRM_GET_PROC(Direct3DRMCreate
)
50 static char data_bad_version
[] =
57 static char data_no_mesh
[] =
64 static char data_ok
[] =
83 static void MeshBuilderTest(void)
87 LPDIRECT3DRMMESHBUILDER pMeshBuilder
;
90 DWORD val1
, val2
, val3
;
92 hr
= pDirect3DRMCreate(&pD3DRM
);
93 ok(hr
== D3DRM_OK
, "Cannot get IDirect3DRM interface (hr = %x)\n", hr
);
95 hr
= IDirect3DRM_CreateMeshBuilder(pD3DRM
, &pMeshBuilder
);
96 ok(hr
== D3DRM_OK
, "Cannot get IDirect3DRMMeshBuilder interface (hr = %x)\n", hr
);
98 info
.lpMemory
= data_bad_version
;
99 info
.dSize
= strlen(data_bad_version
);
100 hr
= IDirect3DRMMeshBuilder_Load(pMeshBuilder
, &info
, NULL
, D3DRMLOAD_FROMMEMORY
, NULL
, NULL
);
101 ok(hr
== D3DRMERR_BADFILE
, "Sould have returned D3DRMERR_BADFILE (hr = %x)\n", hr
);
103 info
.lpMemory
= data_no_mesh
;
104 info
.dSize
= strlen(data_no_mesh
);
105 hr
= IDirect3DRMMeshBuilder_Load(pMeshBuilder
, &info
, NULL
, D3DRMLOAD_FROMMEMORY
, NULL
, NULL
);
106 ok(hr
== D3DRMERR_NOTFOUND
, "Sould have returned D3DRMERR_NOTFOUND (hr = %x)\n", hr
);
108 info
.lpMemory
= data_ok
;
109 info
.dSize
= strlen(data_ok
);
110 hr
= IDirect3DRMMeshBuilder_Load(pMeshBuilder
, &info
, NULL
, D3DRMLOAD_FROMMEMORY
, NULL
, NULL
);
111 ok(hr
== D3DRM_OK
, "Cannot load mesh data (hr = %x)\n", hr
);
113 val
= IDirect3DRMMeshBuilder_GetVertexCount(pMeshBuilder
);
114 ok(val
== 4, "Wrong number of vertices %d (must be 4)\n", val
);
116 val
= IDirect3DRMMeshBuilder_GetFaceCount(pMeshBuilder
);
117 ok(val
== 3, "Wrong number of faces %d (must be 3)\n", val
);
119 hr
= IDirect3DRMMeshBuilder_GetVertices(pMeshBuilder
, &val1
, NULL
, &val2
, NULL
, &val3
, NULL
);
120 ok(hr
== D3DRM_OK
, "Cannot get vertices information (hr = %x)\n", hr
);
121 ok(val1
== 4, "Wrong number of vertices %d (must be 4)\n", val1
);
122 todo_wine
ok(val2
== 4, "Wrong number of normals %d (must be 4)\n", val2
);
123 todo_wine
ok(val3
== 22, "Wrong number of face data bytes %d (must be 22)\n", val3
);
125 IDirect3DRMMeshBuilder_Release(pMeshBuilder
);
127 IDirect3DRM_Release(pD3DRM
);
132 if (!InitFunctionPtrs())
137 FreeLibrary(d3drm_handle
);