2
0
mirror of https://github.com/rehlds/reapi.git synced 2025-01-04 02:55:29 +03:00

Rework native rg_get_weapon_info

This commit is contained in:
s1lentq 2016-05-11 19:52:49 +06:00
parent 136efa87ab
commit 86aead4b02
6 changed files with 56 additions and 20 deletions

View File

@ -61,7 +61,7 @@ void setupToolchain(NativeBinarySpec b) {
'_snprintf': 'snprintf' '_snprintf': 'snprintf'
]) ])
cfg.compilerOptions.args '-Qoption,cpp,--treat_func_as_string_literal_cpp', '-msse2', '-fp-model fast=2', '-fomit-frame-pointer', '-inline-forceinline', '-fvisibility=default', '-fvisibility-inlines-hidden', '-fno-rtti', '-g0', '-s' cfg.compilerOptions.args '-Qoption,cpp,--treat_func_as_string_literal_cpp', '-msse2', '-fomit-frame-pointer', '-inline-forceinline', '-fvisibility=default', '-fvisibility-inlines-hidden', '-fno-rtti', '-g0', '-s'
} }
ToolchainConfigUtils.apply(project, cfg, b) ToolchainConfigUtils.apply(project, cfg, b)

View File

@ -236,14 +236,15 @@ native rg_find_ent_by_owner(&start_index, const classname[], owner);
/** /**
* Returns some information about a weapon. * Returns some information about a weapon.
* *
* @param weapon_id Weapon id, see WEAPON_* constants * @param weapon name or id Weapon id, see WEAPON_* constants WeaponIdType or weapon_* name
* @param type Info type, see WPINFO_* constants * @param WpnInfo:type Info type, see WI_* constants
* *
* @return Weapon information value * @return Weapon information value
* @error If weapon_id and type are out of bound, an error will be thrown. * @error If weapon_id and type are out of bound, an error will be thrown.
* *
* native rg_get_weapon_info(any:...);
*/ */
native rg_get_weapon_info(const {WeaponIdType,_}:weapon_id, WpnInfo:type, any:...); native rg_get_weapon_info(any:...);
/** /**
* Sets specific values of weapons info. * Sets specific values of weapons info.

View File

@ -54,6 +54,7 @@ enum WeaponIdType
// Weapon info types for use with rg_get_weapon_info() // Weapon info types for use with rg_get_weapon_info()
enum WpnInfo enum WpnInfo
{ {
WI_ID,
WI_COST, WI_COST,
WI_CLIP_COST, WI_CLIP_COST,
WI_BUY_CLIP_SIZE, WI_BUY_CLIP_SIZE,

View File

@ -504,30 +504,48 @@ cell AMX_NATIVE_CALL rg_find_ent_by_owner(AMX *amx, cell *params)
/** /**
* Returns some information about a weapon. * Returns some information about a weapon.
* *
* @param weapon_id Weapon id, see WEAPON_* constants * @param weapon name or id Weapon id, see WEAPON_* constants or weapon_* name
* @param type Info type, see WI_* constants * @param WpnInfo:type Info type, see WI_* constants
* *
* @return Weapon information value * @return Weapon information value
* @error If weapon_id and type are out of bound, an error will be thrown. * @error If weapon_id and type are out of bound, an error will be thrown.
* *
* native rg_get_weapon_info(const {WeaponIdType,_}:weapon_id, WpnInfo:type, any:...); * native rg_get_weapon_info(any:...);
*/ */
cell AMX_NATIVE_CALL rg_get_weapon_info(AMX *amx, cell *params) cell AMX_NATIVE_CALL rg_get_weapon_info(AMX *amx, cell *params)
{ {
enum args_e { arg_count, arg_weapon_id, arg_type, arg_3, arg_4 }; enum args_e { arg_count, arg_weapon_id, arg_type, arg_3, arg_4 };
int weapon_id = params[arg_weapon_id]; WeaponIdType weaponID = static_cast<WeaponIdType>(params[arg_weapon_id]);
if (weapon_id <= WEAPON_NONE || weapon_id == WEAPON_C4 || weapon_id == WEAPON_KNIFE || weapon_id > WEAPON_P90) WpnInfo info_type = static_cast<WpnInfo>(*getAmxAddr(amx, params[arg_type]));
if (!GetWeaponInfoRange(weaponID) && info_type != WI_ID)
{ {
MF_LogError(amx, AMX_ERR_NATIVE, "%s: invalid weapon id %i", __FUNCTION__, weapon_id); MF_LogError(amx, AMX_ERR_NATIVE, "%s: invalid weapon id %i", __FUNCTION__, weaponID);
return 0; return 0;
} }
WeaponInfoStruct *info = g_ReGameApi->GetGameData()->GetWeaponInfo(weapon_id); WeaponInfoStruct* info = g_ReGameApi->GetGameData()->GetWeaponInfo(weaponID);
WpnInfo info_type = static_cast<WpnInfo>(params[arg_type]); char* szWeaponName = getAmxString(amx, params[arg_weapon_id]);
switch (info_type) switch (info_type)
{ {
case WI_ID:
if (szWeaponName == nullptr) {
return WEAPON_NONE;
}
_strlwr(szWeaponName);
for (int i = 0; i < MAX_WEAPONS; ++i) {
info = g_ReGameApi->GetGameData()->GetWeaponInfo(i);
if (info == nullptr || info->id == WEAPON_NONE)
continue;
if (strcmp(info->entityName, szWeaponName) == 0) {
return info->id;
}
}
return WEAPON_NONE;
case WI_COST: case WI_COST:
return info->cost; return info->cost;
case WI_CLIP_COST: case WI_CLIP_COST:
@ -579,15 +597,15 @@ cell AMX_NATIVE_CALL rg_set_weapon_info(AMX *amx, cell *params)
{ {
enum args_e { arg_count, arg_weapon_id, arg_type, arg_value }; enum args_e { arg_count, arg_weapon_id, arg_type, arg_value };
int weapon_id = params[arg_weapon_id]; WeaponIdType weaponID = static_cast<WeaponIdType>(params[arg_weapon_id]);
if (weapon_id <= WEAPON_NONE || weapon_id == WEAPON_C4 || weapon_id == WEAPON_KNIFE || weapon_id > WEAPON_P90) if (!GetWeaponInfoRange(weaponID))
{ {
MF_LogError(amx, AMX_ERR_NATIVE, "%s: invalid weapon id %i", __FUNCTION__, weapon_id); MF_LogError(amx, AMX_ERR_NATIVE, "%s: invalid weapon id %i", __FUNCTION__, weaponID);
return 0; return 0;
} }
cell* value = getAmxAddr(amx, params[arg_value]); cell* value = getAmxAddr(amx, params[arg_value]);
WeaponInfoStruct *info = g_ReGameApi->GetGameData()->GetWeaponInfo(weapon_id); WeaponInfoStruct *info = g_ReGameApi->GetGameData()->GetWeaponInfo(weaponID);
WpnInfo info_type = static_cast<WpnInfo>(params[arg_type]); WpnInfo info_type = static_cast<WpnInfo>(params[arg_type]);
switch (info_type) switch (info_type)

View File

@ -2,6 +2,7 @@
enum WpnInfo enum WpnInfo
{ {
WI_ID,
WI_COST, WI_COST,
WI_CLIP_COST, WI_CLIP_COST,
WI_BUY_CLIP_SIZE, WI_BUY_CLIP_SIZE,

View File

@ -7,6 +7,10 @@ char(&ArraySizeHelper(T(&array)[N]))[N];
#define INDEXENT edictByIndex #define INDEXENT edictByIndex
#define ENTINDEX indexOfEdict #define ENTINDEX indexOfEdict
#ifndef _WIN32
#define _strlwr(p) for (int i = 0; p[i] != 0; i++) p[i] = tolower(p[i]);
#endif
extern enginefuncs_t* g_pengfuncsTable; extern enginefuncs_t* g_pengfuncsTable;
inline size_t indexOfEdict(edict_t* ed) inline size_t indexOfEdict(edict_t* ed)
@ -86,6 +90,17 @@ inline T get_member_direct(edict_t *pEntity, int offset, int element = 0, int si
return get_member_direct<T>(pEntity->pvPrivateData, offset, element, size); return get_member_direct<T>(pEntity->pvPrivateData, offset, element, size);
} }
inline bool GetWeaponInfoRange(WeaponIdType wpnid)
{
if (wpnid == WEAPON_SHIELDGUN)
return true;
if (wpnid > WEAPON_NONE && wpnid != WEAPON_C4 && wpnid != WEAPON_KNIFE && wpnid <= WEAPON_P90)
return true;
return false;
}
void Broadcast(const char *sentence); void Broadcast(const char *sentence);
void UpdateTeamScores(); void UpdateTeamScores();