From 78f577686a40630f49ad7a5c22a10b13de161651 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Valentin=20Gr=C3=BCnbacher?= Date: Tue, 17 Feb 2015 23:24:17 +0100 Subject: [PATCH] Fix ArrayDestroy/DestroyStack erroring on null handle --- amxmodx/datastructs.cpp | 32 +++++++++++++++++++------------- amxmodx/stackstructs.cpp | 6 ++++++ 2 files changed, 25 insertions(+), 13 deletions(-) diff --git a/amxmodx/datastructs.cpp b/amxmodx/datastructs.cpp index ff4ddba3..0dd59fb0 100644 --- a/amxmodx/datastructs.cpp +++ b/amxmodx/datastructs.cpp @@ -1,11 +1,11 @@ -// vim: set ts=4 sw=4 tw=99 noet: -// -// AMX Mod X, based on AMX Mod by Aleksander Naszko ("OLO"). -// Copyright (C) The AMX Mod X Development Team. -// -// This software is licensed under the GNU General Public License, version 3 or higher. -// Additional exceptions apply. For full license details, see LICENSE.txt or visit: -// https://alliedmods.net/amxmodx-license +// vim: set ts=4 sw=4 tw=99 noet: +// +// AMX Mod X, based on AMX Mod by Aleksander Naszko ("OLO"). +// Copyright (C) The AMX Mod X Development Team. +// +// This software is licensed under the GNU General Public License, version 3 or higher. +// Additional exceptions apply. For full license details, see LICENSE.txt or visit: +// https://alliedmods.net/amxmodx-license #include "amxmodx.h" #include "datastructs.h" @@ -661,6 +661,12 @@ static cell AMX_NATIVE_CALL ArrayDeleteItem(AMX* amx, cell* params) static cell AMX_NATIVE_CALL ArrayDestroy(AMX* amx, cell* params) { cell* handle = get_amxaddr(amx, params[1]); + + if (*handle == 0) + { + return 0; + } + CellArray* vec = HandleToVector(amx, *handle); if (vec == NULL) @@ -720,11 +726,11 @@ static cell AMX_NATIVE_CALL ArraySort(AMX* amx, cell* params) char* funcName = get_amxstring(amx, params[2], 0, len); // MySortFunc(Array:array, item1, item2, const data[], data_size) - int func = registerSPForwardByName(amx, funcName, FP_CELL, FP_CELL, FP_CELL, FP_CELL, FP_CELL, FP_DONE); - if (func < 0) - { - LogError(amx, AMX_ERR_NATIVE, "The public function \"%s\" was not found.", funcName); - return 0; + int func = registerSPForwardByName(amx, funcName, FP_CELL, FP_CELL, FP_CELL, FP_CELL, FP_CELL, FP_DONE); + if (func < 0) + { + LogError(amx, AMX_ERR_NATIVE, "The public function \"%s\" was not found.", funcName); + return 0; } size_t arraysize = vec->size(); diff --git a/amxmodx/stackstructs.cpp b/amxmodx/stackstructs.cpp index 7238c81e..e414817c 100644 --- a/amxmodx/stackstructs.cpp +++ b/amxmodx/stackstructs.cpp @@ -241,6 +241,12 @@ static cell AMX_NATIVE_CALL IsStackEmpty(AMX* amx, cell* params) static cell AMX_NATIVE_CALL DestroyStack(AMX* amx, cell* params) { cell *handle = get_amxaddr(amx, params[1]); + + if (*handle == 0) + { + return 0; + } + CellArray *vec = HandleToVector(amx, *handle); if (vec == NULL)