d3drm: Move mesh builder data cleaning code into a separate function.
This commit is contained in:
parent
43d3ba36a1
commit
de690b8dae
|
@ -314,6 +314,25 @@ static inline IDirect3DRMMeshBuilderImpl *impl_from_IDirect3DRMMeshBuilder3(IDir
|
||||||
return CONTAINING_RECORD(iface, IDirect3DRMMeshBuilderImpl, IDirect3DRMMeshBuilder3_iface);
|
return CONTAINING_RECORD(iface, IDirect3DRMMeshBuilderImpl, IDirect3DRMMeshBuilder3_iface);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static void clean_mesh_builder_data(IDirect3DRMMeshBuilderImpl *mesh_builder)
|
||||||
|
{
|
||||||
|
HeapFree(GetProcessHeap(), 0, mesh_builder->name);
|
||||||
|
mesh_builder->name = NULL;
|
||||||
|
HeapFree(GetProcessHeap(), 0, mesh_builder->pVertices);
|
||||||
|
mesh_builder->pVertices = NULL;
|
||||||
|
mesh_builder->nb_vertices = 0;
|
||||||
|
HeapFree(GetProcessHeap(), 0, mesh_builder->pNormals);
|
||||||
|
mesh_builder->pNormals = NULL;
|
||||||
|
mesh_builder->nb_normals = 0;
|
||||||
|
HeapFree(GetProcessHeap(), 0, mesh_builder->pFaceData);
|
||||||
|
mesh_builder->pFaceData = NULL;
|
||||||
|
mesh_builder->face_data_size = 0;
|
||||||
|
mesh_builder->nb_faces = 0;
|
||||||
|
HeapFree(GetProcessHeap(), 0, mesh_builder->pCoords2d);
|
||||||
|
mesh_builder->pCoords2d = NULL;
|
||||||
|
mesh_builder->nb_coords2d = 0;
|
||||||
|
}
|
||||||
|
|
||||||
/*** IUnknown methods ***/
|
/*** IUnknown methods ***/
|
||||||
static HRESULT WINAPI IDirect3DRMMeshBuilder2Impl_QueryInterface(IDirect3DRMMeshBuilder2* iface,
|
static HRESULT WINAPI IDirect3DRMMeshBuilder2Impl_QueryInterface(IDirect3DRMMeshBuilder2* iface,
|
||||||
REFIID riid, void** ppvObject)
|
REFIID riid, void** ppvObject)
|
||||||
|
@ -363,15 +382,11 @@ static ULONG WINAPI IDirect3DRMMeshBuilder2Impl_Release(IDirect3DRMMeshBuilder2*
|
||||||
|
|
||||||
if (!ref)
|
if (!ref)
|
||||||
{
|
{
|
||||||
|
clean_mesh_builder_data(This);
|
||||||
if (This->material)
|
if (This->material)
|
||||||
IDirect3DRMMaterial2_Release(This->material);
|
IDirect3DRMMaterial2_Release(This->material);
|
||||||
if (This->texture)
|
if (This->texture)
|
||||||
IDirect3DRMTexture3_Release(This->texture);
|
IDirect3DRMTexture3_Release(This->texture);
|
||||||
HeapFree(GetProcessHeap(), 0, This->name);
|
|
||||||
HeapFree(GetProcessHeap(), 0, This->pVertices);
|
|
||||||
HeapFree(GetProcessHeap(), 0, This->pNormals);
|
|
||||||
HeapFree(GetProcessHeap(), 0, This->pFaceData);
|
|
||||||
HeapFree(GetProcessHeap(), 0, This->pCoords2d);
|
|
||||||
HeapFree(GetProcessHeap(), 0, This);
|
HeapFree(GetProcessHeap(), 0, This);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1114,9 +1129,6 @@ HRESULT load_mesh_data(IDirect3DRMMeshBuilder3* iface, LPDIRECTXFILEDATA pData)
|
||||||
|
|
||||||
TRACE("(%p)->(%p)\n", This, pData);
|
TRACE("(%p)->(%p)\n", This, pData);
|
||||||
|
|
||||||
/* Remove previous name */
|
|
||||||
HeapFree(GetProcessHeap(), 0, This->name);
|
|
||||||
This->name = NULL;
|
|
||||||
hr = IDirectXFileData_GetName(pData, NULL, &size);
|
hr = IDirectXFileData_GetName(pData, NULL, &size);
|
||||||
if (hr != DXFILE_OK)
|
if (hr != DXFILE_OK)
|
||||||
return hr;
|
return hr;
|
||||||
|
@ -1128,12 +1140,8 @@ HRESULT load_mesh_data(IDirect3DRMMeshBuilder3* iface, LPDIRECTXFILEDATA pData)
|
||||||
|
|
||||||
hr = IDirectXFileData_GetName(pData, This->name, &size);
|
hr = IDirectXFileData_GetName(pData, This->name, &size);
|
||||||
if (hr != DXFILE_OK)
|
if (hr != DXFILE_OK)
|
||||||
{
|
|
||||||
HeapFree(GetProcessHeap(), 0, This->name);
|
|
||||||
This->name = NULL;
|
|
||||||
return hr;
|
return hr;
|
||||||
}
|
}
|
||||||
}
|
|
||||||
|
|
||||||
TRACE("Mesh name is '%s'\n", This->name ? This->name : "");
|
TRACE("Mesh name is '%s'\n", This->name ? This->name : "");
|
||||||
|
|
||||||
|
@ -1518,15 +1526,7 @@ static HRESULT WINAPI IDirect3DRMMeshBuilder3Impl_Load(IDirect3DRMMeshBuilder3*
|
||||||
|
|
||||||
TRACE("(%p)->(%p,%p,%x,%p,%p)\n", This, filename, name, loadflags, cb, arg);
|
TRACE("(%p)->(%p,%p,%x,%p,%p)\n", This, filename, name, loadflags, cb, arg);
|
||||||
|
|
||||||
/* First free allocated buffers of previous mesh data */
|
clean_mesh_builder_data(This);
|
||||||
HeapFree(GetProcessHeap(), 0, This->pVertices);
|
|
||||||
This->pVertices = NULL;
|
|
||||||
HeapFree(GetProcessHeap(), 0, This->pNormals);
|
|
||||||
This->pNormals = NULL;
|
|
||||||
HeapFree(GetProcessHeap(), 0, This->pFaceData);
|
|
||||||
This->pFaceData = NULL;
|
|
||||||
HeapFree(GetProcessHeap(), 0, This->pCoords2d);
|
|
||||||
This->pCoords2d = NULL;
|
|
||||||
|
|
||||||
if (loadflags == D3DRMLOAD_FROMMEMORY)
|
if (loadflags == D3DRMLOAD_FROMMEMORY)
|
||||||
{
|
{
|
||||||
|
@ -1622,22 +1622,7 @@ end:
|
||||||
IDirectXFile_Release(pDXFile);
|
IDirectXFile_Release(pDXFile);
|
||||||
|
|
||||||
if (ret != D3DRM_OK)
|
if (ret != D3DRM_OK)
|
||||||
{
|
clean_mesh_builder_data(This);
|
||||||
/* Clean mesh data */
|
|
||||||
This->nb_vertices = 0;
|
|
||||||
This->nb_normals = 0;
|
|
||||||
This->nb_faces = 0;
|
|
||||||
This->face_data_size = 0;
|
|
||||||
This->nb_coords2d = 0;
|
|
||||||
HeapFree(GetProcessHeap(), 0, This->pVertices);
|
|
||||||
This->pVertices = NULL;
|
|
||||||
HeapFree(GetProcessHeap(), 0, This->pNormals);
|
|
||||||
This->pNormals = NULL;
|
|
||||||
HeapFree(GetProcessHeap(), 0, This->pFaceData);
|
|
||||||
This->pFaceData = NULL;
|
|
||||||
HeapFree(GetProcessHeap(), 0, This->pCoords2d);
|
|
||||||
This->pCoords2d = NULL;
|
|
||||||
}
|
|
||||||
|
|
||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue