=?UTF-8?Q?Rico=20Sch=C3=BCller=20?=: d3dx9/tests: Add effect parameter value GetMatrixArray() test.
Alexandre Julliard
julliard at winehq.org
Tue Dec 27 11:27:55 CST 2011
Module: wine
Branch: master
Commit: 9be82e317552907eda0ac2dc59d8c1c5aa975270
URL: http://source.winehq.org/git/wine.git/?a=commit;h=9be82e317552907eda0ac2dc59d8c1c5aa975270
Author: Rico Schüller <kgbricola at web.de>
Date: Mon Dec 26 11:51:34 2011 +0100
d3dx9/tests: Add effect parameter value GetMatrixArray() test.
---
dlls/d3dx9_36/tests/effect.c | 70 ++++++++++++++++++++++++++++++++++++++++++
1 files changed, 70 insertions(+), 0 deletions(-)
diff --git a/dlls/d3dx9_36/tests/effect.c b/dlls/d3dx9_36/tests/effect.c
index fcc336f..0aa4d05 100644
--- a/dlls/d3dx9_36/tests/effect.c
+++ b/dlls/d3dx9_36/tests/effect.c
@@ -968,6 +968,75 @@ static void test_effect_parameter_value_GetMatrix(const struct test_effect_param
}
}
+static void test_effect_parameter_value_GetMatrixArray(const struct test_effect_parameter_value_result *res,
+ ID3DXEffect *effect, const DWORD *res_value, D3DXHANDLE parameter, UINT i)
+{
+ const D3DXPARAMETER_DESC *res_desc = &res->desc;
+ LPCSTR res_full_name = res->full_name;
+ HRESULT hr;
+ DWORD cmp = 0xabababab;
+ FLOAT fvalue[EFFECT_PARAMETER_VALUE_ARRAY_SIZE];
+ UINT l, k, m;
+
+ memset(fvalue, 0xab, sizeof(fvalue));
+ hr = effect->lpVtbl->GetMatrixArray(effect, parameter, (D3DXMATRIX *)&fvalue, res_desc->Elements);
+ if (!res_desc->Elements)
+ {
+ ok(hr == D3D_OK, "%u - %s: GetMatrixArray failed, got %#x, expected %#x\n", i, res_full_name, hr, D3D_OK);
+
+ for (l = 0; l < EFFECT_PARAMETER_VALUE_ARRAY_SIZE; ++l)
+ {
+ ok(fvalue[l] == *(FLOAT *)&cmp, "%u - %s: GetMatrixArray fvalue[%u] failed, got %f, expected %f\n",
+ i, res_full_name, l, fvalue[l], *(FLOAT *)&cmp);
+ }
+ }
+ else if (res_desc->Elements && res_desc->Class == D3DXPC_MATRIX_ROWS)
+ {
+ ok(hr == D3D_OK, "%u - %s: GetMatrixArray failed, got %#x, expected %#x\n", i, res_full_name, hr, D3D_OK);
+
+ for (m = 0; m < res_desc->Elements; ++m)
+ {
+ for (k = 0; k < 4; ++k)
+ {
+ for (l = 0; l < 4; ++l)
+ {
+ if (k < res_desc->Columns && l < res_desc->Rows)
+ {
+ ok(compare_float(fvalue[m * 16 + l * 4 + k], get_float(res_desc->Type,
+ &res_value[m * res_desc->Columns * res_desc->Rows + l * res_desc->Columns + k]), 512),
+ "%u - %s: GetMatrixArray fvalue[%u] failed, got %f, expected %f\n",
+ i, res_full_name, m * 16 + l * 4 + k, fvalue[m * 16 + l * 4 + k],
+ get_float(res_desc->Type, &res_value[m * res_desc->Columns * res_desc->Rows
+ + l * res_desc->Columns + k]));
+ }
+ else
+ {
+ ok(fvalue[m * 16 + l * 4 + k] == 0.0f, "%u - %s: GetMatrixArray fvalue[%u] failed, got %f, expected %f\n",
+ i, res_full_name, m * 16 + l * 4 + k, fvalue[m * 16 + l * 4 + k], 0.0f);
+ }
+ }
+ }
+ }
+
+ for (l = res_desc->Elements * 16; l < EFFECT_PARAMETER_VALUE_ARRAY_SIZE; ++l)
+ {
+ ok(fvalue[l] == *(FLOAT *)&cmp, "%u - %s: GetMatrixArray fvalue[%u] failed, got %f, expected %f\n",
+ i, res_full_name, l, fvalue[l], *(FLOAT *)&cmp);
+ }
+ }
+ else
+ {
+ ok(hr == D3DERR_INVALIDCALL, "%u - %s: GetMatrixArray failed, got %#x, expected %#x\n",
+ i, res_full_name, hr, D3DERR_INVALIDCALL);
+
+ for (l = 0; l < EFFECT_PARAMETER_VALUE_ARRAY_SIZE; ++l)
+ {
+ ok(fvalue[l] == *(FLOAT *)&cmp, "%u - %s: GetMatrixArray fvalue[%u] failed, got %f, expected %f\n",
+ i, res_full_name, l, fvalue[l], *(FLOAT *)&cmp);
+ }
+ }
+}
+
static void test_effect_parameter_value(IDirect3DDevice9 *device)
{
UINT i;
@@ -1047,6 +1116,7 @@ static void test_effect_parameter_value(IDirect3DDevice9 *device)
test_effect_parameter_value_GetVector(&res[k], effect, &blob[res_value_offset], parameter, i);
test_effect_parameter_value_GetVectorArray(&res[k], effect, &blob[res_value_offset], parameter, i);
test_effect_parameter_value_GetMatrix(&res[k], effect, &blob[res_value_offset], parameter, i);
+ test_effect_parameter_value_GetMatrixArray(&res[k], effect, &blob[res_value_offset], parameter, i);
}
count = effect->lpVtbl->Release(effect);
More information about the wine-cvs
mailing list