Merge pull request #353 from Ni3znajomy/cstrike/cs_get_user_weapon

Add extra parameters to cs_get_user_weapon native
This commit is contained in:
Vincent Herbet 2016-02-17 21:21:34 +01:00
commit 721cc0ec5e
2 changed files with 22 additions and 2 deletions

View File

@ -1946,11 +1946,14 @@ static cell AMX_NATIVE_CALL cs_get_user_weapon_entity(AMX *amx, cell *params)
return (weaponEntIndex != -1) ? weaponEntIndex : 0; 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) static cell AMX_NATIVE_CALL cs_get_user_weapon(AMX *amx, cell *params)
{ {
GET_OFFSET("CBasePlayer", m_pActiveItem); GET_OFFSET("CBasePlayer", m_pActiveItem);
GET_OFFSET("CBasePlayer", m_rgAmmo);
GET_OFFSET("CBasePlayerItem", m_iId); GET_OFFSET("CBasePlayerItem", m_iId);
GET_OFFSET("CBasePlayerWeapon", m_iClip);
GET_OFFSET("CBasePlayerWeapon", m_iPrimaryAmmoType);
int playerIndex = params[1]; int playerIndex = params[1];
@ -1961,6 +1964,21 @@ static cell AMX_NATIVE_CALL cs_get_user_weapon(AMX *amx, cell *params)
if (!FNullEnt(pWeapon)) if (!FNullEnt(pWeapon))
{ {
cell *cpTemp = MF_GetAmxAddr(amx, params[2]);
*cpTemp = get_pdata<int>(pWeapon, m_iClip);
cpTemp = MF_GetAmxAddr(amx, params[3]);
int iAmmoType = get_pdata<int>(pWeapon, m_iPrimaryAmmoType);
if(iAmmoType <= 0)
{
*cpTemp = 0;
}
else
{
*cpTemp = get_pdata<int>(pPlayer, m_rgAmmo, iAmmoType);
}
return get_pdata<int>(pWeapon, m_iId); return get_pdata<int>(pWeapon, m_iId);
} }

View File

@ -1117,13 +1117,15 @@ native cs_get_user_weapon_entity(playerIndex);
* @note More reliable than get_user_weapon. * @note More reliable than get_user_weapon.
* *
* @param playerIndex Player index * @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 * @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 * @error If the client index is not within the range of 1 to
* maxClients, or the client is not connected, an error will be * maxClients, or the client is not connected, an error will be
* thrown. * 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. * Returns a weapon class id associated with a weapon id.