2014-08-04 07:12:15 -05:00
|
|
|
// vim: set ts=4 sw=4 tw=99 noet:
|
|
|
|
//
|
|
|
|
// AMX Mod X, based on AMX Mod by Aleksander Naszko ("OLO").
|
|
|
|
// Copyright (C) The AMX Mod X Development Team.
|
|
|
|
//
|
|
|
|
// This software is licensed under the GNU General Public License, version 3 or higher.
|
|
|
|
// Additional exceptions apply. For full license details, see LICENSE.txt or visit:
|
|
|
|
// https://alliedmods.net/amxmodx-license
|
2004-09-10 03:12:38 +00:00
|
|
|
|
2004-02-21 20:30:04 +00:00
|
|
|
#if defined _csstats_included
|
2015-02-24 22:51:36 +01:00
|
|
|
#endinput
|
2004-02-21 20:30:04 +00:00
|
|
|
#endif
|
|
|
|
#define _csstats_included
|
|
|
|
|
2018-08-25 20:52:48 +02:00
|
|
|
#include <csstats_const>
|
|
|
|
|
2015-02-18 16:24:04 +01:00
|
|
|
/**
|
|
|
|
* Retrieves the client's current weapon statistics.
|
|
|
|
*
|
|
|
|
* @note For a list of default CS weapon ids see the CSW_* constants in
|
|
|
|
* amxconst.inc, this function also works on custom weapons.
|
|
|
|
* @note For a list of possible body hitplaces see the HIT_* constants in
|
|
|
|
* amxconst.inc
|
2018-08-25 20:52:48 +02:00
|
|
|
* @note For a list of possible stat constants see the STATSX_* constants in
|
|
|
|
* amxconst.inc
|
2015-02-18 16:24:04 +01:00
|
|
|
* @note The fields in the statistics are:
|
|
|
|
* 0 - Kills
|
|
|
|
* 1 - Deaths
|
|
|
|
* 2 - Headshots
|
|
|
|
* 3 - Teamkills
|
|
|
|
* 4 - Shots
|
|
|
|
* 5 - Hits
|
|
|
|
* 6 - Damage
|
|
|
|
*
|
|
|
|
* @param index Client index
|
|
|
|
* @param wpnindex Weapon id, or 0 to retrieve total statistics across all
|
|
|
|
* weapons
|
|
|
|
* @param stats Buffer to copy statistics to
|
|
|
|
* @param bodyhits Buffer to copy body hits to
|
|
|
|
*
|
|
|
|
* @return 1 on success, 0 if no statistics are available for the weapon
|
|
|
|
* id
|
|
|
|
* @error If an invalid client index or weapon id is provided, an
|
|
|
|
* error will be thrown.
|
|
|
|
*/
|
2018-08-25 20:52:48 +02:00
|
|
|
native get_user_wstats(index, wpnindex, stats[STATSX_MAX_STATS], bodyhits[MAX_BODYHITS]);
|
2004-09-10 03:12:38 +00:00
|
|
|
|
2015-02-18 16:24:04 +01:00
|
|
|
/**
|
|
|
|
* Retrieves the client's weapon statistics from the current round.
|
|
|
|
*
|
|
|
|
* @note For a list of default CS weapon ids see the CSW_* constants in
|
|
|
|
* amxconst.inc, this function also works on custom weapons.
|
|
|
|
* @note For a list of possible body hitplaces see the HIT_* constants in
|
|
|
|
* amxconst.inc
|
2018-08-25 20:52:48 +02:00
|
|
|
* @note For a list of possible stat constants see the STATSX_* constants in
|
|
|
|
* amxconst.inc
|
2015-02-18 16:24:04 +01:00
|
|
|
* @note The fields in the statistics are:
|
|
|
|
* 0 - Kills
|
|
|
|
* 1 - Deaths
|
|
|
|
* 2 - Headshots
|
|
|
|
* 3 - Teamkills
|
|
|
|
* 4 - Shots
|
|
|
|
* 5 - Hits
|
|
|
|
* 6 - Damage
|
|
|
|
*
|
|
|
|
* @param index Client index
|
|
|
|
* @param wpnindex Weapon id, or 0 to retrieve total statistics across all
|
|
|
|
* weapons
|
|
|
|
* @param stats Buffer to copy statistics to
|
|
|
|
* @param bodyhits Buffer to copy body hits to
|
|
|
|
*
|
|
|
|
* @return 1 on success, 0 if no statistics are available for the
|
|
|
|
* weapon id
|
|
|
|
* @error If an invalid client index or weapon id is provided, an
|
|
|
|
* error will be thrown.
|
|
|
|
*/
|
2018-08-25 20:52:48 +02:00
|
|
|
native get_user_wrstats(index, wpnindex, stats[STATSX_MAX_STATS], bodyhits[MAX_BODYHITS]);
|
2004-01-31 20:56:22 +00:00
|
|
|
|
2015-02-18 16:24:04 +01:00
|
|
|
/**
|
|
|
|
* Retrieves the client's weapon statistics from the permanent storage on the
|
|
|
|
* server.
|
|
|
|
*
|
|
|
|
* @note The permanent storage is updated on every respawn or client disconnect.
|
2015-02-24 22:51:36 +01:00
|
|
|
* @note Player rank is determined by the customizable "get_score" function in
|
|
|
|
* "data/csstats.amxx". By default it uses the difference of kills to
|
|
|
|
* deaths/teamkills.
|
2015-02-18 16:24:04 +01:00
|
|
|
* @note For a list of possible body hitplaces see the HIT_* constants in
|
|
|
|
* amxconst.inc
|
2018-08-25 20:52:48 +02:00
|
|
|
* @note For a list of possible stat constants see the STATSX_* constants in
|
|
|
|
* amxconst.inc
|
2015-02-18 16:24:04 +01:00
|
|
|
* @note The fields in the statistics are:
|
|
|
|
* 0 - Kills
|
|
|
|
* 1 - Deaths
|
|
|
|
* 2 - Headshots
|
|
|
|
* 3 - Teamkills
|
|
|
|
* 4 - Shots
|
|
|
|
* 5 - Hits
|
|
|
|
* 6 - Damage
|
|
|
|
* 7 - Rank
|
|
|
|
*
|
|
|
|
* @param index Client index
|
|
|
|
* @param stats Buffer to copy statistics to
|
|
|
|
* @param bodyhits Buffer to copy body hits to
|
|
|
|
*
|
|
|
|
* @return Players rank > 0 on success, or 0 if player is not ranked
|
|
|
|
* and no statistics are available
|
|
|
|
* @error If an invalid client index is provided, an error will be
|
|
|
|
* thrown.
|
|
|
|
*/
|
2018-08-25 20:52:48 +02:00
|
|
|
native get_user_stats(index, stats[STATSX_MAX_STATS], bodyhits[MAX_BODYHITS]);
|
2004-01-31 20:56:22 +00:00
|
|
|
|
2015-02-18 16:24:04 +01:00
|
|
|
/**
|
|
|
|
* Retrieves the client's statistics from the current round.
|
|
|
|
*
|
|
|
|
* @note For a list of possible body hitplaces see the HIT_* constants in
|
|
|
|
* amxconst.inc
|
2018-08-25 20:52:48 +02:00
|
|
|
* @note For a list of possible stat constants see the STATSX_* constants in
|
|
|
|
* amxconst.inc
|
2015-02-18 16:24:04 +01:00
|
|
|
* @note The fields in the statistics are:
|
|
|
|
* 0 - Kills
|
|
|
|
* 1 - Deaths
|
|
|
|
* 2 - Headshots
|
|
|
|
* 3 - Teamkills
|
|
|
|
* 4 - Shots
|
|
|
|
* 5 - Hits
|
|
|
|
* 6 - Damage
|
|
|
|
*
|
|
|
|
* @param index Client index
|
|
|
|
* @param stats Buffer to copy statistics to
|
|
|
|
* @param bodyhits Buffer to copy body hits to
|
|
|
|
*
|
|
|
|
* @return 1 on success, 0 if no statistics are available
|
|
|
|
* @error If an invalid client index is provided, an error will be
|
|
|
|
* thrown.
|
|
|
|
*/
|
2018-08-25 20:52:48 +02:00
|
|
|
native get_user_rstats(index, stats[STATSX_MAX_STATS], bodyhits[MAX_BODYHITS]);
|
2004-01-31 20:56:22 +00:00
|
|
|
|
2015-02-18 16:24:04 +01:00
|
|
|
/**
|
|
|
|
* Retrieves the client's statistics inflicted upon another client from the
|
|
|
|
* current round.
|
|
|
|
*
|
|
|
|
* @note For a list of possible body hitplaces see the HIT_* constants in
|
|
|
|
* amxconst.inc
|
2018-08-25 20:52:48 +02:00
|
|
|
* @note For a list of possible stat constants see the STATSX_* constants in
|
|
|
|
* amxconst.inc
|
2015-02-18 16:24:04 +01:00
|
|
|
* @note The fields in the statistics are:
|
|
|
|
* 0 - Kills
|
|
|
|
* 1 - Deaths
|
|
|
|
* 2 - Headshots
|
|
|
|
* 3 - Teamkills
|
|
|
|
* 4 - Shots
|
|
|
|
* 5 - Hits
|
|
|
|
* 6 - Damage
|
|
|
|
*
|
|
|
|
* @param index Client index
|
|
|
|
* @param victim Victim client index, or 0 to retrieve the statistics against
|
|
|
|
* all victims
|
|
|
|
* @param stats Buffer to copy statistics to
|
|
|
|
* @param bodyhits Buffer to copy body hits to
|
|
|
|
* @param wpnname Optional buffer to copy last used weapon name to
|
|
|
|
* @param len Maximum buffer size
|
|
|
|
*
|
|
|
|
* @return 1 on success, 0 if no statistics are available against the
|
|
|
|
* specified victim
|
|
|
|
* @error If an invalid client index is provided, an error will be
|
|
|
|
* thrown.
|
|
|
|
*/
|
2018-08-25 20:52:48 +02:00
|
|
|
native get_user_vstats(index, victim, stats[STATSX_MAX_STATS], bodyhits[MAX_BODYHITS], wpnname[] = "", len = 0);
|
2004-01-31 20:56:22 +00:00
|
|
|
|
2015-02-18 16:24:04 +01:00
|
|
|
/**
|
|
|
|
* Retrieves the client's statistics received from another client from the
|
|
|
|
* current round.
|
|
|
|
*
|
|
|
|
* @note For a list of possible body hitplaces see the HIT_* constants in
|
|
|
|
* amxconst.inc
|
2018-08-25 20:52:48 +02:00
|
|
|
* @note For a list of possible stat constants see the STATSX_* constants in
|
|
|
|
* amxconst.inc
|
2015-02-18 16:24:04 +01:00
|
|
|
* @note The fields in the statistics are:
|
|
|
|
* 0 - Kills
|
|
|
|
* 1 - Deaths
|
|
|
|
* 2 - Headshots
|
|
|
|
* 3 - Teamkills
|
|
|
|
* 4 - Shots
|
|
|
|
* 5 - Hits
|
|
|
|
* 6 - Damage
|
|
|
|
*
|
|
|
|
* @param index Client index
|
|
|
|
* @param wpnindex Attacker client index, or 0 to retrieve the statistics from
|
|
|
|
* all attackers
|
|
|
|
* @param stats Buffer to copy statistics to
|
|
|
|
* @param bodyhits Buffer to copy body hits to
|
|
|
|
* @param wpnname Optional buffer to copy last used weapon name to
|
|
|
|
* @param len Maximum buffer size
|
|
|
|
*
|
|
|
|
* @return 1 on success, 0 if no statistics are available against the
|
|
|
|
* specified attacker
|
|
|
|
* @error If an invalid client index is provided, an error will be
|
|
|
|
* thrown.
|
|
|
|
*/
|
2018-08-25 20:52:48 +02:00
|
|
|
native get_user_astats(index, wpnindex, stats[STATSX_MAX_STATS], bodyhits[MAX_BODYHITS], wpnname[] = "", len = 0);
|
2004-01-31 20:56:22 +00:00
|
|
|
|
2015-02-18 16:24:04 +01:00
|
|
|
/**
|
|
|
|
* Resets the current round weapon, attacker and victim statistics.
|
|
|
|
*
|
|
|
|
* @param index Client index
|
|
|
|
*
|
|
|
|
* @noreturn
|
|
|
|
* @error If an invalid client index is provided, an error will be
|
|
|
|
* thrown.
|
|
|
|
*/
|
2004-01-31 20:56:22 +00:00
|
|
|
native reset_user_wstats(index);
|
|
|
|
|
2015-02-18 16:24:04 +01:00
|
|
|
/**
|
|
|
|
* Retrieves statistics from the permanent storage on the server via iterative,
|
|
|
|
* incremental access.
|
|
|
|
*
|
|
|
|
* @note The permanent storage is updated on every respawn or client disconnect.
|
2015-02-24 22:51:36 +01:00
|
|
|
* @note Player rank is determined by the customizable "get_score" function in
|
|
|
|
* "data/csstats.amxx". By default it uses the difference of kills to
|
|
|
|
* deaths/teamkills.
|
2015-02-18 16:24:04 +01:00
|
|
|
* @note For a list of possible body hitplaces see the HIT_* constants in
|
|
|
|
* amxconst.inc
|
2018-08-25 20:52:48 +02:00
|
|
|
* @note For a list of possible stat constants see the STATSX_* constants in
|
|
|
|
* amxconst.inc
|
2015-02-18 16:24:04 +01:00
|
|
|
* @note The fields in the statistics are:
|
|
|
|
* 0 - Kills
|
|
|
|
* 1 - Deaths
|
|
|
|
* 2 - Headshots
|
|
|
|
* 3 - Teamkills
|
|
|
|
* 4 - Shots
|
|
|
|
* 5 - Hits
|
|
|
|
* 6 - Damage
|
|
|
|
* 7 - Rank
|
|
|
|
*
|
|
|
|
* @param index Rank index
|
|
|
|
* @param stats Buffer to copy statistics to
|
|
|
|
* @param bodyhits Buffer to copy body hits to
|
|
|
|
* @param name Buffer to copy client name to
|
|
|
|
* @param len Maximum name buffer size
|
|
|
|
* @param authid Buffer to copy client auth id to
|
|
|
|
* @param authidlen Maximum authid buffer size
|
|
|
|
*
|
|
|
|
* @return Next rank index (> 0 and > index), or 0 if no more
|
|
|
|
* statistics exist
|
|
|
|
*/
|
2018-08-25 20:52:48 +02:00
|
|
|
native get_stats(index, stats[STATSX_MAX_STATS], bodyhits[MAX_BODYHITS], name[], len, authid[] = "", authidlen = 0);
|
2004-01-31 20:56:22 +00:00
|
|
|
|
2015-02-18 16:24:04 +01:00
|
|
|
/**
|
|
|
|
* Returns the number of all entries in the permanent statistics storage.
|
|
|
|
*
|
|
|
|
* @return Number of entries in statistics storage
|
|
|
|
*/
|
2004-09-10 03:12:38 +00:00
|
|
|
native get_statsnum();
|
|
|
|
|
2015-02-18 16:24:04 +01:00
|
|
|
/**
|
|
|
|
* Retrieves the client's objective statistics from the permanent storage.
|
|
|
|
*
|
|
|
|
* @note The permanent storage is updated on every respawn or client disconnect.
|
2018-08-25 20:52:48 +02:00
|
|
|
* @note For a list of possible stat constants see the STATSX_* constants in
|
|
|
|
* amxconst.inc
|
2015-02-18 16:24:04 +01:00
|
|
|
* @note The fields in the statistics are:
|
|
|
|
* 0 - total defusions
|
|
|
|
* 1 - bomb defused
|
|
|
|
* 2 - bomb plants
|
|
|
|
* 3 - bomb explosions
|
|
|
|
*
|
|
|
|
* @param index Client index
|
|
|
|
* @param stats Buffer to copy statistics to
|
|
|
|
*
|
|
|
|
* @return Players rank > 0 on success, or 0 if player is not ranked
|
|
|
|
* and no statistics are available
|
|
|
|
* @error If an invalid client index is provided, an error will be
|
|
|
|
* thrown.
|
|
|
|
*/
|
2018-08-25 20:52:48 +02:00
|
|
|
native get_user_stats2(index, stats[STATSX_MAX_OBJECTIVE]);
|
2015-02-18 16:24:04 +01:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Retrieves objective statistics from the permanent storage on the server via
|
|
|
|
* iterative, incremental access.
|
|
|
|
*
|
|
|
|
* @note The permanent storage is updated on every respawn or client disconnect.
|
2018-08-25 20:52:48 +02:00
|
|
|
* @note For a list of possible stat constants see the STATSX_* constants in
|
|
|
|
* amxconst.inc
|
2015-02-18 16:24:04 +01:00
|
|
|
* @note The fields in the statistics are:
|
|
|
|
* 0 - total defusions
|
|
|
|
* 1 - bomb defused
|
|
|
|
* 2 - bomb plants
|
|
|
|
* 3 - bomb explosions
|
|
|
|
*
|
|
|
|
* @param index Client index
|
|
|
|
* @param stats Buffer to copy statistics to
|
|
|
|
* @param authid Buffer to copy client auth id to
|
|
|
|
* @param authidlen Maximum authid buffer size
|
|
|
|
*
|
|
|
|
* @return Next rank index (> 0 and > index), or 0 if no more
|
|
|
|
* statistics exist
|
|
|
|
*/
|
2018-08-25 20:52:48 +02:00
|
|
|
native get_stats2(index, stats[STATSX_MAX_OBJECTIVE], authid[] = "", authidlen = 0);
|