From 8558f364e1415ba1070d05ddc9b83fa02471bb38 Mon Sep 17 00:00:00 2001 From: hrydgard Date: Mon, 11 Jan 2010 23:47:32 +0000 Subject: [PATCH] D3D vertex format wrapper: Fix a really small memory leak, add some sanity checks. git-svn-id: https://dolphin-emu.googlecode.com/svn/trunk@4809 8ced0084-cf51-0410-be5f-012b33b47a6e --- Source/Plugins/Plugin_VideoDX9/Src/NativeVertexFormat.cpp | 5 +++++ 1 file changed, 5 insertions(+) diff --git a/Source/Plugins/Plugin_VideoDX9/Src/NativeVertexFormat.cpp b/Source/Plugins/Plugin_VideoDX9/Src/NativeVertexFormat.cpp index 1717861db2..f3cea8e60a 100644 --- a/Source/Plugins/Plugin_VideoDX9/Src/NativeVertexFormat.cpp +++ b/Source/Plugins/Plugin_VideoDX9/Src/NativeVertexFormat.cpp @@ -59,6 +59,9 @@ D3DVertexFormat::~D3DVertexFormat() D3DDECLTYPE VarToD3D(VarType t, int size) { + if (t < 0 || t > 4) { + PanicAlert("VarToD3D: Invalid VarType %i", t); + } static const D3DDECLTYPE lookup1[5] = { D3DDECLTYPE_UNUSED, D3DDECLTYPE_UNUSED, D3DDECLTYPE_UNUSED, D3DDECLTYPE_UNUSED, D3DDECLTYPE_FLOAT1, }; @@ -78,6 +81,7 @@ D3DDECLTYPE VarToD3D(VarType t, int size) case 2: retval = lookup2[t]; break; case 3: retval = lookup3[t]; break; case 4: retval = lookup4[t]; break; + default: PanicAlert("VarToD3D: size wrong (%i)", size); break; } if (retval == D3DDECLTYPE_UNUSED) { PanicAlert("VarToD3D: Invalid type/size combo %i , %i", (int)t, size); @@ -157,6 +161,7 @@ void D3DVertexFormat::Initialize(const PortableVertexDeclaration &_vtx_decl) PanicAlert("Failed to create D3D vertex declaration!"); return; } + delete [] elems; } void D3DVertexFormat::SetupVertexPointers() const