Fixed debugging stuff
This commit is contained in:
		| @@ -2454,7 +2454,7 @@ PFN_GET_AMXSTRINGLEN		g_fn_GetAmxStringLen; | ||||
| PFN_FORMAT_AMXSTRING		g_fn_FormatAmxString; | ||||
| PFN_COPY_AMXMEMORY			g_fn_CopyAmxMemory; | ||||
| PFN_LOG						g_fn_Log; | ||||
| PFN_LOG_ERROR				g_fn_LogError; | ||||
| PFN_LOG_ERROR				g_fn_LogErrorFunc; | ||||
| PFN_RAISE_AMXERROR			g_fn_RaiseAmxError; | ||||
| PFN_REGISTER_FORWARD		g_fn_RegisterForward; | ||||
| PFN_EXECUTE_FORWARD			g_fn_ExecuteForward; | ||||
| @@ -2544,7 +2544,7 @@ C_DLLEXPORT int AMXX_Attach(PFN_REQ_FNPTR reqFnptrFunc) | ||||
| 	REQFUNC("PrintSrvConsole", g_fn_PrintSrvConsole, PFN_PRINT_SRVCONSOLE); | ||||
| 	REQFUNC("GetModname", g_fn_GetModname, PFN_GET_MODNAME); | ||||
| 	REQFUNC("Log", g_fn_Log, PFN_LOG); | ||||
| 	REQFUNC("LogError", g_fn_LogError, PFN_LOG_ERROR); | ||||
| 	REQFUNC("LogError", g_fn_LogErrorFunc, PFN_LOG_ERROR); | ||||
| 	REQFUNC("MergeDefinitionFile", g_fn_MergeDefinition_File, PFN_MERGEDEFINITION_FILE); | ||||
| 	REQFUNC("Format", g_fn_Format, PFN_FORMAT); | ||||
|  | ||||
| @@ -2651,6 +2651,18 @@ void MF_Log(const char *fmt, ...) | ||||
| 	g_fn_Log("[%s] %s", MODULE_NAME, msg); | ||||
| } | ||||
|  | ||||
| void MF_LogError(AMX *amx, int err, const char *fmt, ...) | ||||
| { | ||||
| 	// :TODO: Overflow possible here | ||||
| 	char msg[3072]; | ||||
| 	va_list arglst; | ||||
| 	va_start(arglst, fmt); | ||||
| 	vsprintf(msg, fmt, arglst); | ||||
| 	va_end(arglst); | ||||
|  | ||||
| 	g_fn_LogErrorFunc(amx, err, "[%s] %s", MODULE_NAME, msg); | ||||
| } | ||||
|  | ||||
|  | ||||
| #ifdef _DEBUG | ||||
| // validate macros | ||||
|   | ||||
| @@ -1990,7 +1990,7 @@ extern PFN_GET_AMXSTRINGLEN			g_fn_GetAmxStringLen; | ||||
| extern PFN_FORMAT_AMXSTRING			g_fn_FormatAmxString; | ||||
| extern PFN_COPY_AMXMEMORY			g_fn_CopyAmxMemory; | ||||
| extern PFN_LOG						g_fn_Log; | ||||
| extern PFN_LOG_ERROR				g_fn_LogError; | ||||
| extern PFN_LOG_ERROR				g_fn_LogErrorFunc; | ||||
| extern PFN_RAISE_AMXERROR			g_fn_RaiseAmxError; | ||||
| extern PFN_REGISTER_FORWARD			g_fn_RegisterForward; | ||||
| extern PFN_EXECUTE_FORWARD			g_fn_ExecuteForward; | ||||
| @@ -2106,7 +2106,7 @@ const char *	MF_Format					(const char *fmt, ...) { } | ||||
| #define MF_GetAmxStringLen g_fn_GetAmxStringLen | ||||
| #define MF_CopyAmxMemory g_fn_CopyAmxMemory | ||||
| void MF_Log(const char *fmt, ...); | ||||
| #define	MF_LogError g_fn_LogError | ||||
| void MF_LogError(AMX *amx, int err, const char *fmt, ...); | ||||
| #define MF_RaiseAmxError g_fn_RaiseAmxError | ||||
| #define MF_RegisterForward g_fn_RegisterForward | ||||
| #define MF_ExecuteForward g_fn_ExecuteForward | ||||
|   | ||||
| @@ -217,14 +217,17 @@ bool g_noknives = false; | ||||
| #define CHECK_ENTITY(x) \ | ||||
| 	if (x < 0 || x > gpGlobals->maxEntities) { \ | ||||
| 		MF_LogError(amx, AMX_ERR_NATIVE, "Entity out of range (%d)", x); \ | ||||
| 		return 0; \ | ||||
| 	} else { \ | ||||
| 		if (x <= gpGlobals->maxClients) { \ | ||||
| 			if (!MF_IsPlayerIngame(x)) { \ | ||||
| 				MF_LogError(amx, AMX_ERR_NATIVE, "Invalid player %d (not in-game)", x); \ | ||||
| 				return 0; \ | ||||
| 			} \ | ||||
| 		} else { \ | ||||
| 			if (x != 0 && FNullEnt(INDEXENT(x))) { \ | ||||
| 				MF_LogError(amx, AMX_ERR_NATIVE, "Invalid entity %d", x); \ | ||||
| 				return 0; \ | ||||
| 			} \ | ||||
| 		} \ | ||||
| 	} | ||||
| @@ -232,18 +235,22 @@ bool g_noknives = false; | ||||
| #define CHECK_PLAYER(x) \ | ||||
| 	if (x < 1 || x > gpGlobals->maxClients) { \ | ||||
| 		MF_LogError(amx, AMX_ERR_NATIVE, "Player out of range (%d)", x); \ | ||||
| 		return 0; \ | ||||
| 	} else { \ | ||||
| 		if (!MF_IsPlayerIngame(x) || FNullEnt(MF_GetPlayerEdict(x))) { \ | ||||
| 			MF_LogError(amx, AMX_ERR_NATIVE, "Invalid player %d", x); \ | ||||
| 			return 0; \ | ||||
| 		} \ | ||||
| 	} | ||||
|  | ||||
| #define CHECK_NONPLAYER(x) \ | ||||
| 	if (x < 1 || x <= gpGlobals->maxClients || x > gpGlobals->maxEntities) { \ | ||||
| 		MF_LogError(amx, AMX_ERR_NATIVE, "Non-player entity %d out of range", x); \ | ||||
| 		return 0; \ | ||||
| 	} else { \ | ||||
| 		if (FNullEnt(INDEXENT(x))) { \ | ||||
| 			MF_LogError(amx, AMX_ERR_NATIVE, "Invalid non-player entity %d", x); \ | ||||
| 			return 0; \ | ||||
| 		} \ | ||||
| 	} | ||||
|  | ||||
|   | ||||
| @@ -32,8 +32,6 @@ | ||||
| *  Description: AMX Mod X Module Interface Functions | ||||
| */ | ||||
|  | ||||
|  | ||||
|  | ||||
| #include <string.h> | ||||
| #include <new> | ||||
| #include <stdarg.h> | ||||
| @@ -53,6 +51,9 @@ DLL_FUNCTIONS *g_pFunctionTable; | ||||
| DLL_FUNCTIONS *g_pFunctionTable_Post; | ||||
| enginefuncs_t *g_pengfuncsTable; | ||||
| enginefuncs_t *g_pengfuncsTable_Post; | ||||
| NEW_DLL_FUNCTIONS *g_pNewFunctionsTable; | ||||
| NEW_DLL_FUNCTIONS *g_pNewFunctionsTable_Post; | ||||
|  | ||||
|  | ||||
| // GetEntityAPI2 functions | ||||
| static DLL_FUNCTIONS g_EntityAPI_Table =  | ||||
| @@ -2207,6 +2208,7 @@ C_DLLEXPORT int GetNewDLLFunctions(NEW_DLL_FUNCTIONS *pNewFunctionTable, | ||||
| 		return(FALSE); | ||||
| 	} | ||||
| 	memcpy(pNewFunctionTable, &g_NewFuncs_Table, sizeof(NEW_DLL_FUNCTIONS)); | ||||
| 	g_pNewFunctionsTable=pNewFunctionTable; | ||||
| 	return TRUE; | ||||
| } | ||||
|  | ||||
| @@ -2224,6 +2226,7 @@ C_DLLEXPORT int GetNewDLLFunctions_Post( NEW_DLL_FUNCTIONS *pNewFunctionTable, i | ||||
| 		return(FALSE); | ||||
| 	} | ||||
| 	memcpy(pNewFunctionTable, &g_NewFuncs_Post_Table, sizeof(NEW_DLL_FUNCTIONS)); | ||||
| 	g_pNewFunctionsTable_Post=pNewFunctionTable; | ||||
| 	return TRUE; | ||||
| } | ||||
|  | ||||
| @@ -2451,12 +2454,14 @@ PFN_GET_AMXSTRINGLEN		g_fn_GetAmxStringLen; | ||||
| PFN_FORMAT_AMXSTRING		g_fn_FormatAmxString; | ||||
| PFN_COPY_AMXMEMORY			g_fn_CopyAmxMemory; | ||||
| PFN_LOG						g_fn_Log; | ||||
| PFN_LOG_ERROR				g_fn_LogError; | ||||
| PFN_LOG_ERROR				g_fn_LogErrorFunc; | ||||
| PFN_RAISE_AMXERROR			g_fn_RaiseAmxError; | ||||
| PFN_REGISTER_FORWARD		g_fn_RegisterForward; | ||||
| PFN_EXECUTE_FORWARD			g_fn_ExecuteForward; | ||||
| PFN_PREPARE_CELLARRAY		g_fn_PrepareCellArray; | ||||
| PFN_PREPARE_CHARARRAY		g_fn_PrepareCharArray; | ||||
| PFN_PREPARE_CELLARRAY_A		g_fn_PrepareCellArrayA; | ||||
| PFN_PREPARE_CHARARRAY_A		g_fn_PrepareCharArrayA; | ||||
| PFN_IS_PLAYER_VALID			g_fn_IsPlayerValid; | ||||
| PFN_GET_PLAYER_NAME			g_fn_GetPlayerName; | ||||
| PFN_GET_PLAYER_IP			g_fn_GetPlayerIP; | ||||
| @@ -2466,6 +2471,7 @@ PFN_IS_PLAYER_AUTHORIZED	g_fn_IsPlayerAuthorized; | ||||
| PFN_GET_PLAYER_TIME			g_fn_GetPlayerTime; | ||||
| PFN_GET_PLAYER_PLAYTIME		g_fn_GetPlayerPlayTime; | ||||
| PFN_GET_PLAYER_CURWEAPON	g_fn_GetPlayerCurweapon; | ||||
| PFN_GET_PLAYER_TEAM			g_fn_GetPlayerTeam; | ||||
| PFN_GET_PLAYER_TEAMID		g_fn_GetPlayerTeamID; | ||||
| PFN_GET_PLAYER_DEATHS		g_fn_GetPlayerDeaths; | ||||
| PFN_GET_PLAYER_MENU			g_fn_GetPlayerMenu; | ||||
| @@ -2490,6 +2496,11 @@ PFN_CELL_TO_REAL			g_fn_CellToReal; | ||||
| PFN_REGISTER_SPFORWARD		g_fn_RegisterSPForward; | ||||
| PFN_REGISTER_SPFORWARD_BYNAME	g_fn_RegisterSPForwardByName; | ||||
| PFN_UNREGISTER_SPFORWARD	g_fn_UnregisterSPForward; | ||||
| PFN_MERGEDEFINITION_FILE	g_fn_MergeDefinition_File; | ||||
| PFN_AMX_FINDNATIVE			g_fn_AmxFindNative; | ||||
| PFN_GETPLAYERFLAGS			g_fn_GetPlayerFlags; | ||||
| PFN_GET_PLAYER_EDICT		g_fn_GetPlayerEdict; | ||||
| PFN_FORMAT					g_fn_Format; | ||||
|  | ||||
| // *** Exports *** | ||||
| C_DLLEXPORT int AMXX_Query(int *interfaceVersion, amxx_module_info_s *moduleInfo) | ||||
| @@ -2533,7 +2544,9 @@ C_DLLEXPORT int AMXX_Attach(PFN_REQ_FNPTR reqFnptrFunc) | ||||
| 	REQFUNC("PrintSrvConsole", g_fn_PrintSrvConsole, PFN_PRINT_SRVCONSOLE); | ||||
| 	REQFUNC("GetModname", g_fn_GetModname, PFN_GET_MODNAME); | ||||
| 	REQFUNC("Log", g_fn_Log, PFN_LOG); | ||||
| 	REQFUNC("LogError", g_fn_LogError, PFN_LOG_ERROR); | ||||
| 	REQFUNC("LogError", g_fn_LogErrorFunc, PFN_LOG_ERROR); | ||||
| 	REQFUNC("MergeDefinitionFile", g_fn_MergeDefinition_File, PFN_MERGEDEFINITION_FILE); | ||||
| 	REQFUNC("Format", g_fn_Format, PFN_FORMAT); | ||||
|  | ||||
| 	// Amx scripts | ||||
| 	REQFUNC("GetAmxScript", g_fn_GetAmxScript, PFN_GET_AMXSCRIPT); | ||||
| @@ -2555,6 +2568,7 @@ C_DLLEXPORT int AMXX_Attach(PFN_REQ_FNPTR reqFnptrFunc) | ||||
| 	REQFUNC("amx_Execv", g_fn_AmxExecv, PFN_AMX_EXECV); | ||||
| 	REQFUNC("amx_FindPublic", g_fn_AmxFindPublic, PFN_AMX_FINDPUBLIC); | ||||
| 	REQFUNC("amx_Allot", g_fn_AmxAllot, PFN_AMX_ALLOT); | ||||
| 	REQFUNC("amx_FindNative", g_fn_AmxFindNative, PFN_AMX_FINDNATIVE); | ||||
|  | ||||
| 	// Natives / Forwards | ||||
| 	REQFUNC("AddNatives", g_fn_AddNatives, PFN_ADD_NATIVES); | ||||
| @@ -2566,7 +2580,8 @@ C_DLLEXPORT int AMXX_Attach(PFN_REQ_FNPTR reqFnptrFunc) | ||||
| 	REQFUNC("ExecuteForward", g_fn_ExecuteForward, PFN_EXECUTE_FORWARD); | ||||
| 	REQFUNC("PrepareCellArray", g_fn_PrepareCellArray, PFN_PREPARE_CELLARRAY); | ||||
| 	REQFUNC("PrepareCharArray", g_fn_PrepareCharArray, PFN_PREPARE_CHARARRAY); | ||||
|  | ||||
| 	REQFUNC("PrepareCellArrayA", g_fn_PrepareCellArrayA, PFN_PREPARE_CELLARRAY_A); | ||||
| 	REQFUNC("PrepareCharArrayA", g_fn_PrepareCharArrayA, PFN_PREPARE_CHARARRAY_A); | ||||
| 	// Player | ||||
| 	REQFUNC("IsPlayerValid", g_fn_IsPlayerValid, PFN_IS_PLAYER_VALID); | ||||
| 	REQFUNC("GetPlayerName", g_fn_GetPlayerName, PFN_GET_PLAYER_NAME); | ||||
| @@ -2578,6 +2593,7 @@ C_DLLEXPORT int AMXX_Attach(PFN_REQ_FNPTR reqFnptrFunc) | ||||
| 	REQFUNC("GetPlayerPlayTime", g_fn_GetPlayerPlayTime, PFN_GET_PLAYER_PLAYTIME); | ||||
| 	REQFUNC("GetPlayerCurweapon", g_fn_GetPlayerCurweapon, PFN_GET_PLAYER_CURWEAPON); | ||||
| 	REQFUNC("GetPlayerTeamID", g_fn_GetPlayerTeamID, PFN_GET_PLAYER_TEAMID); | ||||
| 	REQFUNC("GetPlayerTeam",g_fn_GetPlayerTeam, PFN_GET_PLAYER_TEAM); | ||||
| 	REQFUNC("GetPlayerDeaths", g_fn_GetPlayerDeaths, PFN_GET_PLAYER_DEATHS); | ||||
| 	REQFUNC("GetPlayerMenu", g_fn_GetPlayerMenu, PFN_GET_PLAYER_MENU); | ||||
| 	REQFUNC("GetPlayerKeys", g_fn_GetPlayerKeys, PFN_GET_PLAYER_KEYS); | ||||
| @@ -2587,6 +2603,8 @@ C_DLLEXPORT int AMXX_Attach(PFN_REQ_FNPTR reqFnptrFunc) | ||||
| 	REQFUNC("IsPlayerHLTV", g_fn_IsPlayerHLTV, PFN_IS_PLAYER_HLTV); | ||||
| 	REQFUNC("GetPlayerArmor", g_fn_GetPlayerArmor, PFN_GET_PLAYER_ARMOR); | ||||
| 	REQFUNC("GetPlayerHealth", g_fn_GetPlayerHealth, PFN_GET_PLAYER_HEALTH); | ||||
| 	REQFUNC("GetPlayerFlags", g_fn_GetPlayerFlags, PFN_GETPLAYERFLAGS); | ||||
| 	REQFUNC("GetPlayerEdict", g_fn_GetPlayerEdict, PFN_GET_PLAYER_EDICT); | ||||
|  | ||||
| 	// Memory | ||||
| 	REQFUNC_OPT("Allocator", g_fn_Allocator, PFN_ALLOCATOR); | ||||
| @@ -2633,6 +2651,18 @@ void MF_Log(const char *fmt, ...) | ||||
| 	g_fn_Log("[%s] %s", MODULE_NAME, msg); | ||||
| } | ||||
|  | ||||
| void MF_LogError(AMX *amx, int err, const char *fmt, ...) | ||||
| { | ||||
| 	// :TODO: Overflow possible here | ||||
| 	char msg[3072]; | ||||
| 	va_list arglst; | ||||
| 	va_start(arglst, fmt); | ||||
| 	vsprintf(msg, fmt, arglst); | ||||
| 	va_end(arglst); | ||||
|  | ||||
| 	g_fn_LogErrorFunc(amx, err, "[%s] %s", MODULE_NAME, msg); | ||||
| } | ||||
|  | ||||
|  | ||||
| #ifdef _DEBUG | ||||
| // validate macros | ||||
| @@ -2659,6 +2689,8 @@ void ValidateMacros_DontCallThis_Smiley() | ||||
| 	MF_ExecuteForward(0, 0, 0); | ||||
| 	MF_PrepareCellArray(NULL, 0); | ||||
| 	MF_PrepareCharArray(NULL, 0); | ||||
| 	MF_PrepareCellArrayA(NULL, 0, true); | ||||
| 	MF_PrepareCharArrayA(NULL, 0, true); | ||||
| 	MF_IsPlayerValid(0); | ||||
| 	MF_GetPlayerName(0); | ||||
| 	MF_GetPlayerIP(0); | ||||
| @@ -2669,6 +2701,7 @@ void ValidateMacros_DontCallThis_Smiley() | ||||
| 	MF_GetPlayerPlayTime(0); | ||||
| 	MF_GetPlayerCurweapon(0); | ||||
| 	MF_GetPlayerTeamID(0); | ||||
| 	MF_GetPlayerTeam(0); | ||||
| 	MF_GetPlayerDeaths(0); | ||||
| 	MF_GetPlayerMenu(0); | ||||
| 	MF_GetPlayerKeys(0); | ||||
| @@ -2682,11 +2715,14 @@ void ValidateMacros_DontCallThis_Smiley() | ||||
| 	MF_AmxExecv(0, 0, 0, 0, 0); | ||||
| 	MF_AmxFindPublic(0, 0, 0); | ||||
| 	MF_AmxAllot(0, 0, 0, 0); | ||||
| 	MF_LoadAmxScript(0, 0, 0, 0); | ||||
| 	MF_LoadAmxScript(0, 0, 0, 0, 0); | ||||
| 	MF_UnloadAmxScript(0, 0); | ||||
| 	MF_RegisterSPForward(0, 0, 0, 0, 0, 0); | ||||
| 	MF_RegisterSPForwardByName(0, 0, 0, 0, 0, 0); | ||||
| 	MF_UnregisterSPForward(0); | ||||
| 	MF_GetPlayerFrags(0); | ||||
| 	MF_GetPlayerEdict(0); | ||||
| 	MF_Format("", 4, "str"); | ||||
| } | ||||
| #endif | ||||
|  | ||||
|   | ||||
| @@ -55,7 +55,7 @@ struct amxx_module_info_s | ||||
| // The next section is copied from the amx.h file | ||||
| // Copyright (c) ITB CompuPhase, 1997-2004 | ||||
|  | ||||
| #if defined __LCC__ || defined __DMC__ || defined __linux__ | ||||
| #if defined __LCC__ || defined __DMC__ || defined __linux__ || defined __GNUC__ | ||||
|   #include <stdint.h> | ||||
| #elif !defined __STDC_VERSION__ || __STDC_VERSION__ < 199901L | ||||
|   /* The ISO C99 defines the int16_t and int_32t types. If the compiler got | ||||
| @@ -929,7 +929,7 @@ void FN_EngineFprintf(FILE *pfile, char *szFmt, ...); | ||||
| #endif // FN_EngineFprintf | ||||
|  | ||||
| #ifdef FN_PvAllocEntPrivateData | ||||
| void *FN_PvAllocEntPrivateData(edict_t *pEdict, long cb); | ||||
| void *FN_PvAllocEntPrivateData(edict_t *pEdict, int32 cb); | ||||
| #endif // FN_PvAllocEntPrivateData | ||||
|  | ||||
| #ifdef FN_PvEntPrivateData | ||||
| @@ -1925,6 +1925,8 @@ typedef int				(*PFN_REGISTER_FORWARD)			(const char * /*funcname*/, ForwardExec | ||||
| typedef int				(*PFN_EXECUTE_FORWARD)			(int /*id*/, ... /*params*/); | ||||
| typedef cell			(*PFN_PREPARE_CELLARRAY)		(cell * /*ptr*/, unsigned int /*size*/); | ||||
| typedef cell			(*PFN_PREPARE_CHARARRAY)		(char * /*ptr*/, unsigned int /*size*/); | ||||
| typedef cell			(*PFN_PREPARE_CELLARRAY_A)		(cell * /*ptr*/, unsigned int /*size*/, bool /*copyBack*/); | ||||
| typedef cell			(*PFN_PREPARE_CHARARRAY_A)		(char * /*ptr*/, unsigned int /*size*/, bool /*copyBack*/); | ||||
| typedef int				(*PFN_IS_PLAYER_VALID)			(int /*id*/); | ||||
| typedef const char *	(*PFN_GET_PLAYER_NAME)			(int /*id*/); | ||||
| typedef const char *	(*PFN_GET_PLAYER_IP)			(int /*id*/); | ||||
| @@ -1935,6 +1937,7 @@ typedef float			(*PFN_GET_PLAYER_TIME)			(int /*id*/); | ||||
| typedef float			(*PFN_GET_PLAYER_PLAYTIME)		(int /*id*/); | ||||
| typedef int				(*PFN_GETPLAYERFLAGS) 			(int /* id*/); | ||||
| typedef int				(*PFN_GET_PLAYER_CURWEAPON)		(int /*id*/); | ||||
| typedef const char *    (*PFN_GET_PLAYER_TEAM)			(int /*id*/); | ||||
| typedef int				(*PFN_GET_PLAYER_TEAMID)		(int /*id*/); | ||||
| typedef int				(*PFN_GET_PLAYER_DEATHS)		(int /*id*/); | ||||
| typedef int				(*PFN_GET_PLAYER_MENU)			(int /*id*/); | ||||
| @@ -1945,6 +1948,12 @@ typedef int				(*PFN_IS_PLAYER_CONNECTING)		(int /*id*/); | ||||
| typedef int				(*PFN_IS_PLAYER_HLTV)			(int /*id*/); | ||||
| typedef int				(*PFN_GET_PLAYER_ARMOR)			(int /*id*/); | ||||
| typedef int				(*PFN_GET_PLAYER_HEALTH)		(int /*id*/); | ||||
| #ifdef USE_METAMOD | ||||
| typedef edict_t *		(*PFN_GET_PLAYER_EDICT)			(int /*id*/); | ||||
| #else | ||||
| typedef void *			(*PFN_GET_PLAYER_EDICT)			(int /*id*/); | ||||
| #endif | ||||
|  | ||||
| typedef void *			(*PFN_ALLOCATOR)				(const char* /*filename*/, const unsigned int /*line*/, const char* /*func*/, | ||||
| 														 const unsigned int /*type*/, const size_t /*size*/); | ||||
| typedef void *			(*PFN_REALLOCATOR)				(const char* /*filename*/, const unsigned int /*line*/, const char* /*func*/, | ||||
| @@ -1956,7 +1965,7 @@ typedef int				(*PFN_AMX_EXECV)				(AMX* /*amx*/, cell* /*return val*/, int /*in | ||||
| typedef int				(*PFN_AMX_ALLOT)				(AMX* /*amx*/, int /*length*/, cell* /*amx_addr*/, cell** /*phys_addr*/); | ||||
| typedef int				(*PFN_AMX_FINDPUBLIC)			(AMX* /*amx*/, char* /*func name*/, int* /*index*/); | ||||
| typedef int				(*PFN_AMX_FINDNATIVE)			(AMX* /*amx*/, char* /*func name*/, int* /*index*/); | ||||
| typedef int				(*PFN_LOAD_AMXSCRIPT)			(AMX* /*amx*/, void** /*code*/, const char* /*path*/, char[64] /*error info*/); | ||||
| typedef int				(*PFN_LOAD_AMXSCRIPT)			(AMX* /*amx*/, void** /*code*/, const char* /*path*/, char[64] /*error info*/, int /* debug */); | ||||
| typedef int				(*PFN_UNLOAD_AMXSCRIPT)			(AMX* /*amx*/,void** /*code*/); | ||||
| typedef cell			(*PFN_REAL_TO_CELL)				(REAL /*x*/); | ||||
| typedef REAL			(*PFN_CELL_TO_REAL)				(cell /*x*/); | ||||
| @@ -1964,6 +1973,7 @@ typedef int				(*PFN_REGISTER_SPFORWARD)		(AMX * /*amx*/, int /*func*/, ... /*pa | ||||
| typedef int				(*PFN_REGISTER_SPFORWARD_BYNAME)	(AMX * /*amx*/, const char * /*funcName*/, ... /*params*/); | ||||
| typedef void			(*PFN_UNREGISTER_SPFORWARD)		(int /*id*/); | ||||
| typedef	void			(*PFN_MERGEDEFINITION_FILE)		(const char * /*filename*/); | ||||
| typedef const char *	(*PFN_FORMAT)					(const char * /*fmt*/, ... /*params*/); | ||||
|  | ||||
| extern PFN_ADD_NATIVES				g_fn_AddNatives; | ||||
| extern PFN_BUILD_PATHNAME			g_fn_BuildPathname; | ||||
| @@ -1980,12 +1990,14 @@ extern PFN_GET_AMXSTRINGLEN			g_fn_GetAmxStringLen; | ||||
| extern PFN_FORMAT_AMXSTRING			g_fn_FormatAmxString; | ||||
| extern PFN_COPY_AMXMEMORY			g_fn_CopyAmxMemory; | ||||
| extern PFN_LOG						g_fn_Log; | ||||
| extern PFN_LOG_ERROR				g_fn_LogError; | ||||
| extern PFN_LOG_ERROR				g_fn_LogErrorFunc; | ||||
| extern PFN_RAISE_AMXERROR			g_fn_RaiseAmxError; | ||||
| extern PFN_REGISTER_FORWARD			g_fn_RegisterForward; | ||||
| extern PFN_EXECUTE_FORWARD			g_fn_ExecuteForward; | ||||
| extern PFN_PREPARE_CELLARRAY		g_fn_PrepareCellArray; | ||||
| extern PFN_PREPARE_CHARARRAY		g_fn_PrepareCharArray; | ||||
| extern PFN_PREPARE_CELLARRAY_A		g_fn_PrepareCellArrayA; | ||||
| extern PFN_PREPARE_CHARARRAY_A		g_fn_PrepareCharArrayA; | ||||
| extern PFN_IS_PLAYER_VALID			g_fn_IsPlayerValid; | ||||
| extern PFN_GET_PLAYER_NAME			g_fn_GetPlayerName; | ||||
| extern PFN_GET_PLAYER_IP			g_fn_GetPlayerIP; | ||||
| @@ -2019,6 +2031,9 @@ extern PFN_UNREGISTER_SPFORWARD		g_fn_UnregisterSPForward; | ||||
| extern PFN_MERGEDEFINITION_FILE		g_fn_MergeDefinition_File; | ||||
| extern PFN_AMX_FINDNATIVE			g_fn_AmxFindNative; | ||||
| extern PFN_GETPLAYERFLAGS		g_fn_GetPlayerFlags; | ||||
| extern PFN_GET_PLAYER_EDICT			g_fn_GetPlayerEdict; | ||||
| extern PFN_FORMAT					g_fn_Format; | ||||
| extern PFN_GET_PLAYER_TEAM			g_fn_GetPlayerTeam; | ||||
|  | ||||
| #ifdef MAY_NEVER_BE_DEFINED | ||||
| // Function prototypes for intellisense and similar systems | ||||
| @@ -2044,6 +2059,8 @@ int				MF_RegisterForward			(const char * funcname, ForwardExecType exectype, .. | ||||
| int				MF_ExecuteForward			(int id, ...) { } | ||||
| cell			MF_PrepareCellArray			(cell * ptr, unsigned int size) { } | ||||
| cell			MF_PrepareCharArray			(char * ptr, unsigned int size) { } | ||||
| cell			MF_PrepareCellArrayA			(cell * ptr, unsigned int size, bool copyBack) { } | ||||
| cell			MF_PrepareCharArrayA			(char * ptr, unsigned int size, bool copyBack) { } | ||||
| int				MF_IsPlayerValid			(int id) { } | ||||
| const char *	MF_GetPlayerName			(int id) { } | ||||
| const char *	MF_GetPlayerIP				(int id) { } | ||||
| @@ -2053,6 +2070,7 @@ int				MF_IsPlayerAuthorized		(int id) { } | ||||
| float			MF_GetPlayerTime			(int id) { } | ||||
| float			MF_GetPlayerPlayTime		(int id) { } | ||||
| int				MF_GetPlayerCurweapon		(int id) { } | ||||
| const char *	MF_GetPlayerTeam			(int id) { } | ||||
| int				MF_GetPlayerTeamID			(int id) { } | ||||
| int				MF_GetPlayerDeaths			(int id) { } | ||||
| int				MF_GetPlayerMenu			(int id) { } | ||||
| @@ -2069,6 +2087,8 @@ int				MF_RegisterSPForwardByName	(AMX * amx, const char *str, ...) { } | ||||
| int				MF_RegisterSPForward		(AMX * amx, int func, ...) { } | ||||
| void			MF_UnregisterSPForward		(int id) { } | ||||
| int				MF_GetPlayerFlags			(int id) { } | ||||
| edict_t*		MF_GetPlayerEdict			(int id) { } | ||||
| const char *	MF_Format					(const char *fmt, ...) { } | ||||
| #endif	// MAY_NEVER_BE_DEFINED | ||||
|  | ||||
| #define MF_AddNatives g_fn_AddNatives | ||||
| @@ -2086,12 +2106,14 @@ int				MF_GetPlayerFlags			(int id) { } | ||||
| #define MF_GetAmxStringLen g_fn_GetAmxStringLen | ||||
| #define MF_CopyAmxMemory g_fn_CopyAmxMemory | ||||
| void MF_Log(const char *fmt, ...); | ||||
| #define	MF_LogError g_fn_LogError | ||||
| void MF_LogError(AMX *amx, int err, const char *fmt, ...); | ||||
| #define MF_RaiseAmxError g_fn_RaiseAmxError | ||||
| #define MF_RegisterForward g_fn_RegisterForward | ||||
| #define MF_ExecuteForward g_fn_ExecuteForward | ||||
| #define MF_PrepareCellArray g_fn_PrepareCellArray | ||||
| #define MF_PrepareCharArray g_fn_PrepareCharArray | ||||
| #define MF_PrepareCellArrayA g_fn_PrepareCellArrayA | ||||
| #define MF_PrepareCharArrayA g_fn_PrepareCharArrayA | ||||
| #define MF_IsPlayerValid g_fn_IsPlayerValid | ||||
| #define MF_GetPlayerName g_fn_GetPlayerName | ||||
| #define MF_GetPlayerIP g_fn_GetPlayerIP | ||||
| @@ -2101,6 +2123,7 @@ void MF_Log(const char *fmt, ...); | ||||
| #define MF_GetPlayerTime g_fn_GetPlayerTime | ||||
| #define MF_GetPlayerPlayTime g_fn_GetPlayerPlayTime | ||||
| #define MF_GetPlayerCurweapon g_fn_GetPlayerCurweapon | ||||
| #define MF_GetPlayerTeam g_fn_GetPlayerTeam | ||||
| #define MF_GetPlayerTeamID g_fn_GetPlayerTeamID | ||||
| #define MF_GetPlayerDeaths g_fn_GetPlayerDeaths | ||||
| #define MF_GetPlayerMenu g_fn_GetPlayerMenu | ||||
| @@ -2125,6 +2148,8 @@ void MF_Log(const char *fmt, ...); | ||||
| #define MF_RegisterSPForward g_fn_RegisterSPForward | ||||
| #define MF_UnregisterSPForward g_fn_UnregisterSPForward | ||||
| #define MF_GetPlayerFlags g_fn_GetPlayerFlags | ||||
| #define MF_GetPlayerEdict g_fn_GetPlayerEdict | ||||
| #define MF_Format g_fn_Format | ||||
|  | ||||
| /*** Memory ***/ | ||||
| void	*operator new(size_t reportedSize); | ||||
|   | ||||
| @@ -183,14 +183,17 @@ void Think(edict_t *pent); | ||||
| #define CHECK_ENTITY(x) \ | ||||
| 	if (x < 0 || x > gpGlobals->maxEntities) { \ | ||||
| 		MF_LogError(amx, AMX_ERR_NATIVE, "Entity out of range (%d)", x); \ | ||||
| 		return 0; \ | ||||
| 	} else { \ | ||||
| 		if (x <= gpGlobals->maxClients) { \ | ||||
| 			if (!MF_IsPlayerIngame(x)) { \ | ||||
| 				MF_LogError(amx, AMX_ERR_NATIVE, "Invalid player %d (not in-game)", x); \ | ||||
| 				return 0; \ | ||||
| 			} \ | ||||
| 		} else { \ | ||||
| 			if (x != 0 && FNullEnt(INDEXENT(x))) { \ | ||||
| 				MF_LogError(amx, AMX_ERR_NATIVE, "Invalid entity %d", x); \ | ||||
| 				return 0; \ | ||||
| 			} \ | ||||
| 		} \ | ||||
| 	} | ||||
|   | ||||
| @@ -2454,7 +2454,7 @@ PFN_GET_AMXSTRINGLEN		g_fn_GetAmxStringLen; | ||||
| PFN_FORMAT_AMXSTRING		g_fn_FormatAmxString; | ||||
| PFN_COPY_AMXMEMORY			g_fn_CopyAmxMemory; | ||||
| PFN_LOG						g_fn_Log; | ||||
| PFN_LOG_ERROR				g_fn_LogError; | ||||
| PFN_LOG_ERROR				g_fn_LogErrorFunc; | ||||
| PFN_RAISE_AMXERROR			g_fn_RaiseAmxError; | ||||
| PFN_REGISTER_FORWARD		g_fn_RegisterForward; | ||||
| PFN_EXECUTE_FORWARD			g_fn_ExecuteForward; | ||||
| @@ -2544,7 +2544,7 @@ C_DLLEXPORT int AMXX_Attach(PFN_REQ_FNPTR reqFnptrFunc) | ||||
| 	REQFUNC("PrintSrvConsole", g_fn_PrintSrvConsole, PFN_PRINT_SRVCONSOLE); | ||||
| 	REQFUNC("GetModname", g_fn_GetModname, PFN_GET_MODNAME); | ||||
| 	REQFUNC("Log", g_fn_Log, PFN_LOG); | ||||
| 	REQFUNC("LogError", g_fn_LogError, PFN_LOG_ERROR); | ||||
| 	REQFUNC("LogError", g_fn_LogErrorFunc, PFN_LOG_ERROR); | ||||
| 	REQFUNC("MergeDefinitionFile", g_fn_MergeDefinition_File, PFN_MERGEDEFINITION_FILE); | ||||
| 	REQFUNC("Format", g_fn_Format, PFN_FORMAT); | ||||
|  | ||||
| @@ -2651,6 +2651,18 @@ void MF_Log(const char *fmt, ...) | ||||
| 	g_fn_Log("[%s] %s", MODULE_NAME, msg); | ||||
| } | ||||
|  | ||||
| void MF_LogError(AMX *amx, int err, const char *fmt, ...) | ||||
| { | ||||
| 	// :TODO: Overflow possible here | ||||
| 	char msg[3072]; | ||||
| 	va_list arglst; | ||||
| 	va_start(arglst, fmt); | ||||
| 	vsprintf(msg, fmt, arglst); | ||||
| 	va_end(arglst); | ||||
|  | ||||
| 	g_fn_LogErrorFunc(amx, err, "[%s] %s", MODULE_NAME, msg); | ||||
| } | ||||
|  | ||||
|  | ||||
| #ifdef _DEBUG | ||||
| // validate macros | ||||
|   | ||||
| @@ -1990,7 +1990,7 @@ extern PFN_GET_AMXSTRINGLEN			g_fn_GetAmxStringLen; | ||||
| extern PFN_FORMAT_AMXSTRING			g_fn_FormatAmxString; | ||||
| extern PFN_COPY_AMXMEMORY			g_fn_CopyAmxMemory; | ||||
| extern PFN_LOG						g_fn_Log; | ||||
| extern PFN_LOG_ERROR				g_fn_LogError; | ||||
| extern PFN_LOG_ERROR				g_fn_LogErrorFunc; | ||||
| extern PFN_RAISE_AMXERROR			g_fn_RaiseAmxError; | ||||
| extern PFN_REGISTER_FORWARD			g_fn_RegisterForward; | ||||
| extern PFN_EXECUTE_FORWARD			g_fn_ExecuteForward; | ||||
| @@ -2106,7 +2106,7 @@ const char *	MF_Format					(const char *fmt, ...) { } | ||||
| #define MF_GetAmxStringLen g_fn_GetAmxStringLen | ||||
| #define MF_CopyAmxMemory g_fn_CopyAmxMemory | ||||
| void MF_Log(const char *fmt, ...); | ||||
| #define	MF_LogError g_fn_LogError | ||||
| void MF_LogError(AMX *amx, int err, const char *fmt, ...); | ||||
| #define MF_RaiseAmxError g_fn_RaiseAmxError | ||||
| #define MF_RegisterForward g_fn_RegisterForward | ||||
| #define MF_ExecuteForward g_fn_ExecuteForward | ||||
|   | ||||
| @@ -64,14 +64,17 @@ edict_t* g_edict; | ||||
| #define CHECK_ENTITY(x) \ | ||||
| 	if (x < 0 || x > gpGlobals->maxEntities) { \ | ||||
| 		MF_LogError(amx, AMX_ERR_NATIVE, "Entity out of range (%d)", x); \ | ||||
| 		return 0; \ | ||||
| 	} else { \ | ||||
| 		if (x <= gpGlobals->maxClients) { \ | ||||
| 			if (!MF_IsPlayerIngame(x)) { \ | ||||
| 				MF_LogError(amx, AMX_ERR_NATIVE, "Invalid player %d (not in-game)", x); \ | ||||
| 				return 0; \ | ||||
| 			} \ | ||||
| 		} else { \ | ||||
| 			if (x != 0 && FNullEnt(INDEXENT(x))) { \ | ||||
| 				MF_LogError(amx, AMX_ERR_NATIVE, "Invalid entity %d", x); \ | ||||
| 				return 0; \ | ||||
| 			} \ | ||||
| 		} \ | ||||
| 	} | ||||
| @@ -79,9 +82,11 @@ edict_t* g_edict; | ||||
| #define CHECK_PLAYER(x) \ | ||||
| 	if (x < 1 || x > gpGlobals->maxClients) { \ | ||||
| 		MF_LogError(amx, AMX_ERR_NATIVE, "Player out of range (%d)", x); \ | ||||
| 		return 0; \ | ||||
| 	} else { \ | ||||
| 		if (!MF_IsPlayerIngame(x) || FNullEnt(MF_GetPlayerEdict(x))) { \ | ||||
| 			MF_LogError(amx, AMX_ERR_NATIVE, "Invalid player %d", x); \ | ||||
| 			return 0; \ | ||||
| 		} \ | ||||
| 	} | ||||
|  | ||||
|   | ||||
		Reference in New Issue
	
	Block a user