// 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

//
// CSX Functions
//

#if defined _csx_included
	#endinput
#endif
#define _csx_included

#include <csstats>

#pragma reqclass xstats
#if !defined AMXMODX_NOAUTOLOAD
	#pragma defclasslib xstats csx
#endif

/**
 * Map objective flags returned by get_map_objectives().
 */
enum MapObjective
{
	MapObjective_Bomb    = (1<<0),
	MapObjective_Hostage = (1<<1),
	MapObjective_Vip     = (1<<2),
	MapObjective_Escape  = (1<<3),
};

/**
 * Called after a client attacks another client.
 *
 * @note For a list of possible weapon ids see the CSW_* constants in
 *       amxconst.inc
 * @note For a list of possible body hitplaces see the HIT_* constants in
 *       amxconst.inc
 *
 * @param attacker  Attacker client index
 * @param victim    Victim client index
 * @param damage    Damage dealt to victim
 * @param wpnindex  Weapon id
 * @param hitplace  Body hitplace
 * @param ta        If nonzero the attack was a team attack
 *
 * @noreturn
 */
forward client_damage(attacker, victim, damage, wpnindex, hitplace, TA);

/**
 * Called after a client death.
 *
 * @note For a list of possible weapon ids see the CSW_* constants in
 *       amxconst.inc
 * @note For a list of possible body hitplaces see the HIT_* constants in
 *       amxconst.inc
 *
 * @param attacker  Attacker client index
 * @param victim    Victim client index
 * @param wpnindex  Weapon id
 * @param hitplace  Body hitplace
 * @param tk        If nonzero the death was a teamkill
 *
 * @noreturn
 */
forward client_death(killer, victim, wpnindex, hitplace, TK);

/**
 * Called after a grenade was thrown.
 *
 * @note Weapon id is one of CSW_HEGRENADE, CSW_SMOKEGRENADE or CSW_FLASHBANG.
 *
 * @param index     Client index
 * @param greindex  Grenade entity index
 * @param wId       Weapon id
 *
 * @noreturn
 */
forward grenade_throw(index, greindex, wId);

/**
 * Called after a bomb plant attempt has started.
 *
 * @param planter   Planter client index
 *
 * @noreturn
 */
forward bomb_planting(planter);

/**
 * Called after a bomb plant has finished.
 *
 * @param planter   Planter client index
 *
 * @noreturn
 */
forward bomb_planted(planter);

/**
 * Called when the bomb exploded.
 *
 * @param planter   Planter client index
 * @param defuser   Defuser client index, if applicable
 *
 * @noreturn
 */
forward bomb_explode(planter, defuser);

/**
 * Called after a bomb defuse attempt has started.
 *
 * @param defuser   Defuser client index
 *
 * @noreturn
 */
forward bomb_defusing(defuser);

/**
 * Called after a bomb defuse has finished.
 *
 * @param defuser   Defuser client index
 *
 * @noreturn
 */
forward bomb_defused(defuser);

/**
 * @section Shared natives
 */

/**
 * Adds a custom weapon to the stats system.
 *
 * @note The weapon name should be the full display name of the gun such as
 *       "Desert Eagle" while the logname should be "weapon_deagle".
 *
 * @param wpnname   Full weapon name
 * @param melee     If nonzero the weapon will be considered a melee weapon
 * @param logname   Weapon short name
 *
 * @return          Cusom weapon id (>0) on success, 0 if no more custom weapons
 *                  can be added
 */
native custom_weapon_add(const wpnname[], melee = 0, const logname[] = "");

/**
 * Triggers a damage event on a custom weapon, adding it to the internal stats.
 *
 * @note This will also call the client_damage() and client_kill() forwards if
 *       applicable.
 * @note For a list of possible body hitplaces see the HIT_* constants in
 *       amxconst.inc
 *
 * @param weapon    Custom weapon id
 * @param att       Attacker client index
 * @param vic       Victim client index
 * @param damage    Damage dealt
 * @param hitplace  Optional body hitplace
 *
 * @noreturn
 * @error           If the weapon id is not a custom weapon, an invalid client
 *                  index, damage value or hitplace is provided, an error will
 *                  be thrown.
 */
native custom_weapon_dmg(weapon, att, vic, damage, hitplace = 0);

/**
 * Adds a shot event on a custom weapon to the internal stats.
 *
 * @param weapon    Custom weapon id
 * @param index     Client index
 *
 * @noreturn
 * @error           If the weapon id is not a custom weapon or an invalid client
 *                  index is provided, an error will be thrown.
 */
native custom_weapon_shot(weapon, index);

/**
 * Returns if the weapon is considered a melee weapon.
 *
 * @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 the default CS weapons this obviously returns true only for
 *       CSW_KNIFE.
 *
 * @param wpnindex  Weapon id
 *
 * @return          1 if weapon is a melee weapon, 0
 * @error           If an invalid weapon id is provided an error will be thrown.
 */
native xmod_is_melee_wpn(wpnindex);

/**
 * Retrieves the full weapon name of a weapon id.
 *
 * @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 the default CS weapons this obviously returns true only for
 *       CSW_KNIFE.
 *
 * @param wpnindex  Weapon id
 * @param name      Buffer to copy weapon name to
 * @param len       Maximmum buffer size
 *
 * @return          Number of cells written to buffer
 * @error           If an invalid weapon id is provided an error will be thrown.
 */
native xmod_get_wpnname(wpnindex, name[], len);

/**
 * Retrieves the weapon log name of a weapon id.
 *
 * @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 the default CS weapons this obviously returns true only for
 *       CSW_KNIFE.
 *
 * @param wpnindex  Weapon id
 * @param name      Buffer to copy weapon log name to
 * @param len       Maximmum buffer size
 *
 * @return          Number of cells written to buffer
 * @error           If an invalid weapon id is provided an error will be thrown.
 */
native xmod_get_wpnlogname(wpnindex, name[], len);

/**
 * Returns the maximum amount of weapons that the stats system supports.
 *
 * @return      Maximum number of weapons supported
 */
native xmod_get_maxweapons();

/**
 * Returns the number of stats tracked by the stats system.
 *
 * @return      Number of stats tracked
 */
native xmod_get_stats_size();

/**
 * @endsection Shared natives
 */

/**
 * Returns the current map's objectives as a bitflag value.
 *
 * @note For a list of possible map objective flags see the MapObjective enum.
 *
 * @return      Bitflag value of map objectives
 */
native MapObjective:get_map_objectives();