Commit bf235a66 authored by Henri Verbeet's avatar Henri Verbeet Committed by Alexandre Julliard

d3drm: Initialize the actual array in d3drm_frame_array_create() as well.

parent 71ecb556
...@@ -197,15 +197,31 @@ static const struct IDirect3DRMFrameArrayVtbl d3drm_frame_array_vtbl = ...@@ -197,15 +197,31 @@ static const struct IDirect3DRMFrameArrayVtbl d3drm_frame_array_vtbl =
d3drm_frame_array_GetElement, d3drm_frame_array_GetElement,
}; };
static struct d3drm_frame_array *d3drm_frame_array_create(void) static struct d3drm_frame_array *d3drm_frame_array_create(unsigned int frame_count, IDirect3DRMFrame3 **frames)
{ {
struct d3drm_frame_array *array; struct d3drm_frame_array *array;
unsigned int i;
if (!(array = HeapAlloc(GetProcessHeap(), HEAP_ZERO_MEMORY, sizeof(*array)))) if (!(array = HeapAlloc(GetProcessHeap(), HEAP_ZERO_MEMORY, sizeof(*array))))
return NULL; return NULL;
array->IDirect3DRMFrameArray_iface.lpVtbl = &d3drm_frame_array_vtbl; array->IDirect3DRMFrameArray_iface.lpVtbl = &d3drm_frame_array_vtbl;
array->ref = 1; array->ref = 1;
array->size = frame_count;
if (frame_count)
{
if (!(array->frames = HeapAlloc(GetProcessHeap(), 0, frame_count * sizeof(*array->frames))))
{
HeapFree(GetProcessHeap(), 0, array);
return NULL;
}
for (i = 0; i < frame_count; ++i)
{
IDirect3DRMFrame3_QueryInterface(frames[i], &IID_IDirect3DRMFrame, (void **)&array->frames[i]);
}
}
return array; return array;
} }
...@@ -1500,25 +1516,9 @@ static HRESULT WINAPI d3drm_frame3_GetChildren(IDirect3DRMFrame3 *iface, IDirect ...@@ -1500,25 +1516,9 @@ static HRESULT WINAPI d3drm_frame3_GetChildren(IDirect3DRMFrame3 *iface, IDirect
if (!children) if (!children)
return D3DRMERR_BADVALUE; return D3DRMERR_BADVALUE;
if (!(array = d3drm_frame_array_create())) if (!(array = d3drm_frame_array_create(frame->nb_children, frame->children)))
return E_OUTOFMEMORY; return E_OUTOFMEMORY;
array->size = frame->nb_children;
if (frame->nb_children)
{
ULONG i;
if (!(array->frames = HeapAlloc(GetProcessHeap(), 0, frame->nb_children * sizeof(*array->frames))))
{
HeapFree(GetProcessHeap(), 0, array);
return E_OUTOFMEMORY;
}
for (i = 0; i < frame->nb_children; ++i)
{
IDirect3DRMFrame3_QueryInterface(frame->children[i], &IID_IDirect3DRMFrame, (void **)&array->frames[i]);
}
}
*children = &array->IDirect3DRMFrameArray_iface; *children = &array->IDirect3DRMFrameArray_iface;
return D3DRM_OK; return D3DRM_OK;
......
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