From cb87fa12e1bbd1859dfa48d745aa3f34d7365f7f Mon Sep 17 00:00:00 2001 From: Karol Szuster Date: Wed, 17 Feb 2016 20:46:42 +0100 Subject: [PATCH] Add extra parameters to cs_get_user_weapon native Add clip & ammo as optional as get_user_weapon native has --- modules/cstrike/cstrike/CstrikeNatives.cpp | 20 +++++++++++++++++++- plugins/include/cstrike.inc | 4 +++- 2 files changed, 22 insertions(+), 2 deletions(-) diff --git a/modules/cstrike/cstrike/CstrikeNatives.cpp b/modules/cstrike/cstrike/CstrikeNatives.cpp index f61b2e8c..79c8267f 100644 --- a/modules/cstrike/cstrike/CstrikeNatives.cpp +++ b/modules/cstrike/cstrike/CstrikeNatives.cpp @@ -1946,11 +1946,14 @@ static cell AMX_NATIVE_CALL cs_get_user_weapon_entity(AMX *amx, cell *params) return (weaponEntIndex != -1) ? weaponEntIndex : 0; } -// native cs_get_user_weapon(playerIndex); +// native cs_get_user_weapon(playerIndex, &clip = 0, &ammo = 0); static cell AMX_NATIVE_CALL cs_get_user_weapon(AMX *amx, cell *params) { GET_OFFSET("CBasePlayer", m_pActiveItem); + GET_OFFSET("CBasePlayer", m_rgAmmo); GET_OFFSET("CBasePlayerItem", m_iId); + GET_OFFSET("CBasePlayerWeapon", m_iClip); + GET_OFFSET("CBasePlayerWeapon", m_iPrimaryAmmoType); int playerIndex = params[1]; @@ -1961,6 +1964,21 @@ static cell AMX_NATIVE_CALL cs_get_user_weapon(AMX *amx, cell *params) if (!FNullEnt(pWeapon)) { + cell *cpTemp = MF_GetAmxAddr(amx, params[2]); + *cpTemp = get_pdata(pWeapon, m_iClip); + + cpTemp = MF_GetAmxAddr(amx, params[3]); + int iAmmoType = get_pdata(pWeapon, m_iPrimaryAmmoType); + + if(iAmmoType <= 0) + { + *cpTemp = 0; + } + else + { + *cpTemp = get_pdata(pPlayer, m_rgAmmo, iAmmoType); + } + return get_pdata(pWeapon, m_iId); } diff --git a/plugins/include/cstrike.inc b/plugins/include/cstrike.inc index 4976e191..e86e7909 100755 --- a/plugins/include/cstrike.inc +++ b/plugins/include/cstrike.inc @@ -1117,13 +1117,15 @@ native cs_get_user_weapon_entity(playerIndex); * @note More reliable than get_user_weapon. * * @param playerIndex Player index + * @param clip Optional variable to store clip ammo to + * @param ammo Optional variable to store backpack ammo to * * @return Weapon index on success or 0 if there is no active weapon * @error If the client index is not within the range of 1 to * maxClients, or the client is not connected, an error will be * thrown. */ -native cs_get_user_weapon(playerIndex); +native cs_get_user_weapon(playerIndex, &clip = 0, &ammo = 0); /** * Returns a weapon class id associated with a weapon id.