From a2e43a567f00db5a4088951bf714e4ba9d77e5f4 Mon Sep 17 00:00:00 2001 From: Alexander 'z33ky' Hirsch <1zeeky@gmail.com> Date: Tue, 12 Nov 2024 23:57:06 +0100 Subject: [PATCH] Fix (potential?) memory leaks from getVariant() (SquirrelVM) Free values before assignment. --- sp/src/public/vscript/ivscript.h | 1 + sp/src/vscript/vscript_squirrel.cpp | 7 +++++++ 2 files changed, 8 insertions(+) diff --git a/sp/src/public/vscript/ivscript.h b/sp/src/public/vscript/ivscript.h index 7e4c1d48..0c8f9007 100644 --- a/sp/src/public/vscript/ivscript.h +++ b/sp/src/public/vscript/ivscript.h @@ -497,6 +497,7 @@ struct ScriptVariant_t bool AssignTo( ScriptVariant_t *pDest ) { + pDest->Free(); pDest->m_type = m_type; if ( m_flags & SV_FREE ) { diff --git a/sp/src/vscript/vscript_squirrel.cpp b/sp/src/vscript/vscript_squirrel.cpp index c17f3c64..02d057aa 100644 --- a/sp/src/vscript/vscript_squirrel.cpp +++ b/sp/src/vscript/vscript_squirrel.cpp @@ -1205,6 +1205,7 @@ bool getVariant(HSQUIRRELVM vm, SQInteger idx, ScriptVariant_t& variant) { case OT_NULL: { + variant.Free(); variant.m_flags = 0; // TODO: Should this be (HSCRIPT)nullptr variant.m_type = FIELD_VOID; @@ -1217,6 +1218,7 @@ bool getVariant(HSQUIRRELVM vm, SQInteger idx, ScriptVariant_t& variant) { return false; } + variant.Free(); variant = (int)val; return true; } @@ -1227,6 +1229,7 @@ bool getVariant(HSQUIRRELVM vm, SQInteger idx, ScriptVariant_t& variant) { return false; } + variant.Free(); variant = (float)val; return true; } @@ -1237,6 +1240,7 @@ bool getVariant(HSQUIRRELVM vm, SQInteger idx, ScriptVariant_t& variant) { return false; } + variant.Free(); variant = val ? true : false; return true; } @@ -1248,6 +1252,7 @@ bool getVariant(HSQUIRRELVM vm, SQInteger idx, ScriptVariant_t& variant) { return false; } + variant.Free(); char* buffer = (char*)malloc(size + 1); V_memcpy(buffer, val, size); buffer[size] = 0; @@ -1263,6 +1268,7 @@ bool getVariant(HSQUIRRELVM vm, SQInteger idx, ScriptVariant_t& variant) tag == TYPETAG_VECTOR && SQ_SUCCEEDED(sq_getinstanceup(vm, idx, (SQUserPointer*)&v, TYPETAG_VECTOR))) { + variant.Free(); variant = (Vector*)malloc(sizeof(Vector)); variant.EmplaceAllocedVector(*v); variant.m_flags |= SV_FREE; @@ -1272,6 +1278,7 @@ bool getVariant(HSQUIRRELVM vm, SQInteger idx, ScriptVariant_t& variant) } default: { + variant.Free(); HSQOBJECT* obj = new HSQOBJECT; sq_resetobject(obj); sq_getstackobj(vm, idx, obj);