Commit 58b87b0f authored by Michael Stefaniuc's avatar Michael Stefaniuc Committed by Alexandre Julliard

d3dx9: Move parameter_count out of struct d3dx9_base_effect.

parent 3899e79f
...@@ -152,7 +152,6 @@ struct d3dx9_base_effect ...@@ -152,7 +152,6 @@ struct d3dx9_base_effect
{ {
struct d3dx_effect *effect; struct d3dx_effect *effect;
UINT parameter_count;
UINT technique_count; UINT technique_count;
UINT object_count; UINT object_count;
...@@ -176,6 +175,7 @@ struct d3dx_effect ...@@ -176,6 +175,7 @@ struct d3dx_effect
LONG ref; LONG ref;
struct d3dx9_base_effect base_effect; struct d3dx9_base_effect base_effect;
unsigned int parameter_count;
struct ID3DXEffectStateManager *manager; struct ID3DXEffectStateManager *manager;
struct IDirect3DDevice9 *device; struct IDirect3DDevice9 *device;
...@@ -691,7 +691,7 @@ static void d3dx9_base_effect_cleanup(struct d3dx9_base_effect *base) ...@@ -691,7 +691,7 @@ static void d3dx9_base_effect_cleanup(struct d3dx9_base_effect *base)
if (base->parameters) if (base->parameters)
{ {
for (i = 0; i < base->parameter_count; ++i) for (i = 0; i < base->effect->parameter_count; ++i)
free_top_level_parameter(&base->parameters[i]); free_top_level_parameter(&base->parameters[i]);
HeapFree(GetProcessHeap(), 0, base->parameters); HeapFree(GetProcessHeap(), 0, base->parameters);
base->parameters = NULL; base->parameters = NULL;
...@@ -3277,7 +3277,7 @@ static HRESULT WINAPI d3dx_effect_GetDesc(ID3DXEffect *iface, D3DXEFFECT_DESC *d ...@@ -3277,7 +3277,7 @@ static HRESULT WINAPI d3dx_effect_GetDesc(ID3DXEffect *iface, D3DXEFFECT_DESC *d
/* TODO: add creator and function count. */ /* TODO: add creator and function count. */
desc->Creator = NULL; desc->Creator = NULL;
desc->Functions = 0; desc->Functions = 0;
desc->Parameters = effect->base_effect.parameter_count; desc->Parameters = effect->parameter_count;
desc->Techniques = effect->base_effect.technique_count; desc->Techniques = effect->base_effect.technique_count;
return D3D_OK; return D3D_OK;
...@@ -3329,7 +3329,7 @@ static D3DXHANDLE WINAPI d3dx_effect_GetParameter(ID3DXEffect *iface, D3DXHANDLE ...@@ -3329,7 +3329,7 @@ static D3DXHANDLE WINAPI d3dx_effect_GetParameter(ID3DXEffect *iface, D3DXHANDLE
if (!parameter) if (!parameter)
{ {
if (index < effect->base_effect.parameter_count) if (index < effect->parameter_count)
{ {
TRACE("Returning parameter %p.\n", &effect->base_effect.parameters[index]); TRACE("Returning parameter %p.\n", &effect->base_effect.parameters[index]);
return get_parameter_handle(&effect->base_effect.parameters[index].param); return get_parameter_handle(&effect->base_effect.parameters[index].param);
...@@ -3383,7 +3383,7 @@ static D3DXHANDLE WINAPI d3dx_effect_GetParameterBySemantic(ID3DXEffect *iface, ...@@ -3383,7 +3383,7 @@ static D3DXHANDLE WINAPI d3dx_effect_GetParameterBySemantic(ID3DXEffect *iface,
if (!parameter) if (!parameter)
{ {
for (i = 0; i < effect->base_effect.parameter_count; ++i) for (i = 0; i < effect->parameter_count; ++i)
{ {
temp_param = &effect->base_effect.parameters[i].param; temp_param = &effect->base_effect.parameters[i].param;
...@@ -3442,7 +3442,7 @@ static D3DXHANDLE WINAPI d3dx_effect_GetParameterElement(ID3DXEffect *iface, D3D ...@@ -3442,7 +3442,7 @@ static D3DXHANDLE WINAPI d3dx_effect_GetParameterElement(ID3DXEffect *iface, D3D
if (!param) if (!param)
{ {
if (index < effect->base_effect.parameter_count) if (index < effect->parameter_count)
{ {
TRACE("Returning parameter %p.\n", &effect->base_effect.parameters[index]); TRACE("Returning parameter %p.\n", &effect->base_effect.parameters[index]);
return get_parameter_handle(&effect->base_effect.parameters[index].param); return get_parameter_handle(&effect->base_effect.parameters[index].param);
...@@ -4363,7 +4363,7 @@ static HRESULT WINAPI d3dx_effect_OnLostDevice(ID3DXEffect *iface) ...@@ -4363,7 +4363,7 @@ static HRESULT WINAPI d3dx_effect_OnLostDevice(ID3DXEffect *iface)
TRACE("iface %p.\n", iface); TRACE("iface %p.\n", iface);
for (i = 0; i < base->parameter_count; ++i) for (i = 0; i < effect->parameter_count; ++i)
walk_parameter_tree(&base->parameters[i].param, param_on_lost_device, NULL); walk_parameter_tree(&base->parameters[i].param, param_on_lost_device, NULL);
return D3D_OK; return D3D_OK;
...@@ -6143,9 +6143,9 @@ static HRESULT d3dx_parse_resource(struct d3dx_effect *effect, const char *data, ...@@ -6143,9 +6143,9 @@ static HRESULT d3dx_parse_resource(struct d3dx_effect *effect, const char *data,
struct d3dx_parameter *parameter; struct d3dx_parameter *parameter;
struct d3dx_sampler *sampler; struct d3dx_sampler *sampler;
if (index >= base->parameter_count) if (index >= effect->parameter_count)
{ {
FIXME("Index out of bounds: index %u >= parameter_count %u\n", index, base->parameter_count); FIXME("Index out of bounds: index %u >= parameter_count %u\n", index, effect->parameter_count);
return E_FAIL; return E_FAIL;
} }
...@@ -6308,8 +6308,8 @@ static HRESULT d3dx_parse_effect(struct d3dx_effect *effect, const char *data, U ...@@ -6308,8 +6308,8 @@ static HRESULT d3dx_parse_effect(struct d3dx_effect *effect, const char *data, U
HRESULT hr; HRESULT hr;
UINT i; UINT i;
read_dword(&ptr, &base->parameter_count); read_dword(&ptr, &effect->parameter_count);
TRACE("Parameter count: %u.\n", base->parameter_count); TRACE("Parameter count: %u.\n", effect->parameter_count);
read_dword(&ptr, &base->technique_count); read_dword(&ptr, &base->technique_count);
TRACE("Technique count: %u.\n", base->technique_count); TRACE("Technique count: %u.\n", base->technique_count);
...@@ -6328,10 +6328,10 @@ static HRESULT d3dx_parse_effect(struct d3dx_effect *effect, const char *data, U ...@@ -6328,10 +6328,10 @@ static HRESULT d3dx_parse_effect(struct d3dx_effect *effect, const char *data, U
} }
wine_rb_init(&base->param_tree, param_rb_compare); wine_rb_init(&base->param_tree, param_rb_compare);
if (base->parameter_count) if (effect->parameter_count)
{ {
base->parameters = HeapAlloc(GetProcessHeap(), HEAP_ZERO_MEMORY, base->parameters = HeapAlloc(GetProcessHeap(), HEAP_ZERO_MEMORY,
sizeof(*base->parameters) * base->parameter_count); sizeof(*base->parameters) * effect->parameter_count);
if (!base->parameters) if (!base->parameters)
{ {
ERR("Out of memory.\n"); ERR("Out of memory.\n");
...@@ -6339,7 +6339,7 @@ static HRESULT d3dx_parse_effect(struct d3dx_effect *effect, const char *data, U ...@@ -6339,7 +6339,7 @@ static HRESULT d3dx_parse_effect(struct d3dx_effect *effect, const char *data, U
goto err_out; goto err_out;
} }
for (i = 0; i < base->parameter_count; ++i) for (i = 0; i < effect->parameter_count; ++i)
{ {
param_set_magic_number(&base->parameters[i].param); param_set_magic_number(&base->parameters[i].param);
hr = d3dx_parse_effect_parameter(effect, &base->parameters[i], data, &ptr, base->objects); hr = d3dx_parse_effect_parameter(effect, &base->parameters[i], data, &ptr, base->objects);
...@@ -6412,7 +6412,7 @@ static HRESULT d3dx_parse_effect(struct d3dx_effect *effect, const char *data, U ...@@ -6412,7 +6412,7 @@ static HRESULT d3dx_parse_effect(struct d3dx_effect *effect, const char *data, U
} }
} }
for (i = 0; i < base->parameter_count; ++i) for (i = 0; i < effect->parameter_count; ++i)
{ {
if (FAILED(hr = d3dx_pool_sync_shared_parameter(base->pool, &base->parameters[i]))) if (FAILED(hr = d3dx_pool_sync_shared_parameter(base->pool, &base->parameters[i])))
goto err_out; goto err_out;
...@@ -6435,7 +6435,7 @@ err_out: ...@@ -6435,7 +6435,7 @@ err_out:
if (base->parameters) if (base->parameters)
{ {
for (i = 0; i < base->parameter_count; ++i) for (i = 0; i < effect->parameter_count; ++i)
{ {
free_top_level_parameter(&base->parameters[i]); free_top_level_parameter(&base->parameters[i]);
} }
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment