mirror of
https://github.com/alliedmodders/amxmodx.git
synced 2025-01-26 13:48:03 +03:00
callfunc_push_* params num checks
callfunc_push_byref & callfunc_push_str: more references to one variable fix
This commit is contained in:
parent
c8b722efe7
commit
cc277c1bf9
@ -2038,14 +2038,13 @@ struct CallFunc_ParamInfo
|
|||||||
cell size; // byref size
|
cell size; // byref size
|
||||||
};
|
};
|
||||||
|
|
||||||
// :TODO: Overflow possible
|
|
||||||
#define CALLFUNC_MAXPARAMS 64 /* Maximal params number */
|
#define CALLFUNC_MAXPARAMS 64 /* Maximal params number */
|
||||||
cell g_CallFunc_Params[CALLFUNC_MAXPARAMS] = {0}; // Params
|
cell g_CallFunc_Params[CALLFUNC_MAXPARAMS] = {0}; // Params
|
||||||
CallFunc_ParamInfo g_CallFunc_ParamInfo[CALLFUNC_MAXPARAMS] = {0}; // Flags
|
CallFunc_ParamInfo g_CallFunc_ParamInfo[CALLFUNC_MAXPARAMS] = {0}; // Flags
|
||||||
int g_CallFunc_CurParam = 0; // Current param id
|
int g_CallFunc_CurParam = 0; // Current param id
|
||||||
|
|
||||||
#define CALLFUNC_FLAG_BYREF 1 /* Byref flag so that mem is released */
|
#define CALLFUNC_FLAG_BYREF 1 /* Byref flag so that mem is released */
|
||||||
|
#define CALLFUNC_FLAG_BYREF_REUSED 2 /* Reused byref */
|
||||||
|
|
||||||
// native callfunc_begin(const func[], const plugin[]="");
|
// native callfunc_begin(const func[], const plugin[]="");
|
||||||
static cell AMX_NATIVE_CALL callfunc_begin(AMX *amx, cell *params)
|
static cell AMX_NATIVE_CALL callfunc_begin(AMX *amx, cell *params)
|
||||||
@ -2059,7 +2058,6 @@ static cell AMX_NATIVE_CALL callfunc_begin(AMX *amx, cell *params)
|
|||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
int numparams = *params / sizeof(cell);
|
|
||||||
int len;
|
int len;
|
||||||
char *pluginStr = get_amxstring(amx, params[2], 0, len);
|
char *pluginStr = get_amxstring(amx, params[2], 0, len);
|
||||||
char *funcStr = get_amxstring(amx, params[1], 1, len);
|
char *funcStr = get_amxstring(amx, params[1], 1, len);
|
||||||
@ -2125,7 +2123,7 @@ static cell AMX_NATIVE_CALL callfunc_end(AMX *amx, cell *params)
|
|||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
// process byref params
|
// process byref params (not byref_reused)
|
||||||
for (int i = 0; i < curParam; ++i)
|
for (int i = 0; i < curParam; ++i)
|
||||||
{
|
{
|
||||||
if (gparamInfo[i].flags & CALLFUNC_FLAG_BYREF)
|
if (gparamInfo[i].flags & CALLFUNC_FLAG_BYREF)
|
||||||
@ -2163,6 +2161,13 @@ static cell callfunc_push_byval(AMX *amx, cell *params)
|
|||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (g_CallFunc_CurParam == CALLFUNC_MAXPARAMS)
|
||||||
|
{
|
||||||
|
UTIL_Log("[AMXX] callfunc_push_xxx: maximal parameters num: %d", CALLFUNC_MAXPARAMS);
|
||||||
|
amx_RaiseError(amx, AMX_ERR_NATIVE);
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
g_CallFunc_ParamInfo[g_CallFunc_CurParam].flags = 0;
|
g_CallFunc_ParamInfo[g_CallFunc_CurParam].flags = 0;
|
||||||
g_CallFunc_Params[g_CallFunc_CurParam++] = params[1];
|
g_CallFunc_Params[g_CallFunc_CurParam++] = params[1];
|
||||||
|
|
||||||
@ -2182,6 +2187,30 @@ static cell callfunc_push_byref(AMX *amx, cell *params)
|
|||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (g_CallFunc_CurParam == CALLFUNC_MAXPARAMS)
|
||||||
|
{
|
||||||
|
UTIL_Log("[AMXX] callfunc_push_xxx: maximal parameters num: %d", CALLFUNC_MAXPARAMS);
|
||||||
|
amx_RaiseError(amx, AMX_ERR_NATIVE);
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
// search for the address; if it is found, dont create a new copy
|
||||||
|
for (int i = 0; i < g_CallFunc_CurParam; ++i)
|
||||||
|
{
|
||||||
|
if ((g_CallFunc_ParamInfo[i].flags & CALLFUNC_FLAG_BYREF) &&
|
||||||
|
(g_CallFunc_ParamInfo[i].byrefAddr == params[1]))
|
||||||
|
{
|
||||||
|
// the byrefAddr and size params should not be used; set them anyways...
|
||||||
|
g_CallFunc_ParamInfo[g_CallFunc_CurParam].flags = CALLFUNC_FLAG_BYREF_REUSED;
|
||||||
|
g_CallFunc_ParamInfo[g_CallFunc_CurParam].byrefAddr = params[1];
|
||||||
|
g_CallFunc_ParamInfo[g_CallFunc_CurParam].size = 1;
|
||||||
|
g_CallFunc_Params[g_CallFunc_CurParam++] = g_CallFunc_Params[i];
|
||||||
|
// we are done
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// not found; create an own copy
|
||||||
// allocate memory
|
// allocate memory
|
||||||
cell *phys_addr;
|
cell *phys_addr;
|
||||||
cell amx_addr;
|
cell amx_addr;
|
||||||
@ -2216,6 +2245,30 @@ static cell callfunc_push_str(AMX *amx, cell *params)
|
|||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (g_CallFunc_CurParam == CALLFUNC_MAXPARAMS)
|
||||||
|
{
|
||||||
|
UTIL_Log("[AMXX] callfunc_push_xxx: maximal parameters num: %d", CALLFUNC_MAXPARAMS);
|
||||||
|
amx_RaiseError(amx, AMX_ERR_NATIVE);
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
// search for the address; if it is found, dont create a new copy
|
||||||
|
for (int i = 0; i < g_CallFunc_CurParam; ++i)
|
||||||
|
{
|
||||||
|
if ((g_CallFunc_ParamInfo[i].flags & CALLFUNC_FLAG_BYREF) &&
|
||||||
|
(g_CallFunc_ParamInfo[i].byrefAddr == params[1]))
|
||||||
|
{
|
||||||
|
// the byrefAddr and size params should not be used; set them anyways...
|
||||||
|
g_CallFunc_ParamInfo[g_CallFunc_CurParam].flags = CALLFUNC_FLAG_BYREF_REUSED;
|
||||||
|
g_CallFunc_ParamInfo[g_CallFunc_CurParam].byrefAddr = params[1];
|
||||||
|
g_CallFunc_ParamInfo[g_CallFunc_CurParam].size = 1;
|
||||||
|
g_CallFunc_Params[g_CallFunc_CurParam++] = g_CallFunc_Params[i];
|
||||||
|
// we are done
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// not found; create an own copy
|
||||||
// get the string and its length
|
// get the string and its length
|
||||||
int len;
|
int len;
|
||||||
char *str = get_amxstring(amx, params[1], 0, len);
|
char *str = get_amxstring(amx, params[1], 0, len);
|
||||||
|
Loading…
x
Reference in New Issue
Block a user