Commit b73ed197 authored by Nikolay Sivov's avatar Nikolay Sivov Committed by Alexandre Julliard

d3d10/effect: Store string annotation values.

parent eb2946ad
...@@ -1330,12 +1330,28 @@ static HRESULT parse_fx10_variable_head(const char *data, size_t data_size, ...@@ -1330,12 +1330,28 @@ static HRESULT parse_fx10_variable_head(const char *data, size_t data_size,
static HRESULT parse_fx10_annotation(const char *data, size_t data_size, static HRESULT parse_fx10_annotation(const char *data, size_t data_size,
const char **ptr, struct d3d10_effect_variable *a) const char **ptr, struct d3d10_effect_variable *a)
{ {
DWORD offset;
HRESULT hr; HRESULT hr;
if (FAILED(hr = parse_fx10_variable_head(data, data_size, ptr, a))) if (FAILED(hr = parse_fx10_variable_head(data, data_size, ptr, a)))
return hr; return hr;
skip_dword_unknown("annotation", ptr, 1); read_dword(ptr, &offset);
TRACE("Annotation value is at offset %#x.\n", offset);
switch (a->type->basetype)
{
case D3D10_SVT_STRING:
if (!fx10_copy_string(data, data_size, offset, (char **)&a->u.buffer.local_buffer))
{
ERR("Failed to copy name.\n");
return E_OUTOFMEMORY;
}
break;
default:
FIXME("Unhandled object type %#x.\n", a->type->basetype);
}
/* mark the variable as annotation */ /* mark the variable as annotation */
a->flag = D3D10_EFFECT_VARIABLE_ANNOTATION; a->flag = D3D10_EFFECT_VARIABLE_ANNOTATION;
...@@ -2826,6 +2842,10 @@ static void d3d10_effect_variable_destroy(struct d3d10_effect_variable *v) ...@@ -2826,6 +2842,10 @@ static void d3d10_effect_variable_destroy(struct d3d10_effect_variable *v)
heap_free(v->u.resource.srv); heap_free(v->u.resource.srv);
break; break;
case D3D10_SVT_STRING:
heap_free(v->u.buffer.local_buffer);
break;
default: default:
break; 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