Commit 0858dee3 authored by Rico Schüller's avatar Rico Schüller Committed by Alexandre Julliard

d3dx9: Parse effect samplers.

parent 4e3be18e
......@@ -335,6 +335,14 @@ static void free_parameter(D3DXHANDLE handle, BOOL element, BOOL child)
if (*(IUnknown **)param->data) IUnknown_Release(*(IUnknown **)param->data);
break;
case D3DXPT_SAMPLER:
case D3DXPT_SAMPLER1D:
case D3DXPT_SAMPLER2D:
case D3DXPT_SAMPLER3D:
case D3DXPT_SAMPLERCUBE:
/* Todo: free sampler */
break;
default:
FIXME("Unhandled type %s\n", debug_d3dxparameter_type(param->type));
break;
......@@ -1210,27 +1218,53 @@ static HRESULT WINAPI ID3DXBaseEffectImpl_GetValue(ID3DXBaseEffect *iface, D3DXH
if (!param) param = get_parameter_by_name(This, NULL, parameter);
if (data && param && param->data && param->bytes <= bytes)
/* samplers don't touch data */
if (param->class == D3DXPC_OBJECT && (param->type == D3DXPT_SAMPLER
|| param->type == D3DXPT_SAMPLER1D || param->type == D3DXPT_SAMPLER2D
|| param->type == D3DXPT_SAMPLER3D || param->type == D3DXPT_SAMPLERCUBE))
{
TRACE("Sampler: returning E_FAIL\n");
return E_FAIL;
}
if (data && param && param->bytes <= bytes)
{
if (param->type == D3DXPT_VERTEXSHADER || param->type == D3DXPT_PIXELSHADER
|| param->type == D3DXPT_TEXTURE || param->type == D3DXPT_TEXTURE1D
|| param->type == D3DXPT_TEXTURE2D || param->type == D3DXPT_TEXTURE3D
|| param->type == D3DXPT_TEXTURECUBE)
TRACE("Type %s\n", debug_d3dxparameter_type(param->type));
switch (param->type)
{
UINT i;
case D3DXPT_VOID:
case D3DXPT_BOOL:
case D3DXPT_INT:
case D3DXPT_FLOAT:
case D3DXPT_STRING:
break;
for (i = 0; i < (param->element_count ? param->element_count : 1); ++i)
case D3DXPT_VERTEXSHADER:
case D3DXPT_PIXELSHADER:
case D3DXPT_TEXTURE:
case D3DXPT_TEXTURE1D:
case D3DXPT_TEXTURE2D:
case D3DXPT_TEXTURE3D:
case D3DXPT_TEXTURECUBE:
{
IUnknown *unk = ((IUnknown **)param->data)[i];
if (unk) IUnknown_AddRef(unk);
((IUnknown **)data)[i] = unk;
UINT i;
for (i = 0; i < (param->element_count ? param->element_count : 1); ++i)
{
IUnknown *unk = ((IUnknown **)param->data)[i];
if (unk) IUnknown_AddRef(unk);
}
break;
}
default:
FIXME("Unhandled type %s\n", debug_d3dxparameter_type(param->type));
break;
}
else
{
TRACE("Copy %u bytes\n", param->bytes);
memcpy(data, param->data, param->bytes);
}
TRACE("Copy %u bytes\n", param->bytes);
memcpy(data, param->data, param->bytes);
return D3D_OK;
}
......@@ -3336,7 +3370,7 @@ static HRESULT d3dx9_parse_value(struct d3dx_parameter *param, void *value, cons
{
struct d3dx_parameter *member = get_parameter_struct(param->member_handles[i]);
hr = d3dx9_parse_value(member, (char *)value + old_size, ptr);
hr = d3dx9_parse_value(member, value ? (char *)value + old_size : NULL, ptr);
if (hr != D3D_OK)
{
WARN("Failed to parse value\n");
......@@ -3393,6 +3427,25 @@ static HRESULT d3dx9_parse_value(struct d3dx_parameter *param, void *value, cons
param->data = value;
break;
case D3DXPT_SAMPLER:
case D3DXPT_SAMPLER1D:
case D3DXPT_SAMPLER2D:
case D3DXPT_SAMPLER3D:
case D3DXPT_SAMPLERCUBE:
{
UINT state_count;
read_dword(ptr, &state_count);
TRACE("Count: %u\n", state_count);
for (i = 0; i < state_count; ++i)
{
/* Todo: parse states */
skip_dword_unknown(ptr, 4);
}
break;
}
default:
FIXME("Unhandled type %s\n", debug_d3dxparameter_type(param->type));
break;
......@@ -3415,15 +3468,18 @@ static HRESULT d3dx9_parse_init_value(struct d3dx_parameter *param, const char *
TRACE("param size: %u\n", size);
value = HeapAlloc(GetProcessHeap(), 0, size);
if (!value)
if (size)
{
ERR("Failed to allocate data memory.\n");
return E_OUTOFMEMORY;
}
value = HeapAlloc(GetProcessHeap(), 0, size);
if (!value)
{
ERR("Failed to allocate data memory.\n");
return E_OUTOFMEMORY;
}
TRACE("Data: %s.\n", debugstr_an(ptr, size));
memcpy(value, ptr, size);
TRACE("Data: %s.\n", debugstr_an(ptr, size));
memcpy(value, ptr, size);
}
hr = d3dx9_parse_value(param, value, &ptr);
if (hr != D3D_OK)
......@@ -3614,6 +3670,14 @@ static HRESULT d3dx9_parse_effect_typedef(struct d3dx_parameter *param, const ch
param->bytes = sizeof(LPDIRECT3DBASETEXTURE9);
break;
case D3DXPT_SAMPLER:
case D3DXPT_SAMPLER1D:
case D3DXPT_SAMPLER2D:
case D3DXPT_SAMPLER3D:
case D3DXPT_SAMPLERCUBE:
param->bytes = 0;
break;
default:
FIXME("Unhandled type %s\n", debug_d3dxparameter_type(param->type));
break;
......
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