From 5ac34ac3e023f55e46992ffca65af50276bf02be Mon Sep 17 00:00:00 2001 From: Alejo Date: Sat, 30 Mar 2024 13:38:42 -0300 Subject: [PATCH] Spawn protection --- .../scripting/include/reapi_gamedll.inc | 21 +++++++++- reapi/src/natives/natives_misc.cpp | 42 +++++++++++++++++++ 2 files changed, 62 insertions(+), 1 deletion(-) diff --git a/reapi/extra/amxmodx/scripting/include/reapi_gamedll.inc b/reapi/extra/amxmodx/scripting/include/reapi_gamedll.inc index 52dcd9c8..416e8be6 100644 --- a/reapi/extra/amxmodx/scripting/include/reapi_gamedll.inc +++ b/reapi/extra/amxmodx/scripting/include/reapi_gamedll.inc @@ -1213,4 +1213,23 @@ native rg_death_notice(const pVictim, const pKiller, const pevInflictor); * * @return Match player relationship, see GR_* constants in cssdk_const.inc */ -native rg_player_relationship(const player, const target); \ No newline at end of file +native rg_player_relationship(const player, const target); + +/* +* Removes spawn protection from a player +* +* @param player Player index +* +* @noreturn +*/ +native rg_remove_spawn_protection(const player); + +/* +* Sets spawn protection for a player with given time +* +* @param player Player index +* @param time Protection time +* +* @noreturn +*/ +native rg_set_spawn_protection(const player, const Float:time); \ No newline at end of file diff --git a/reapi/src/natives/natives_misc.cpp b/reapi/src/natives/natives_misc.cpp index 5bbe2848..17c3e55f 100644 --- a/reapi/src/natives/natives_misc.cpp +++ b/reapi/src/natives/natives_misc.cpp @@ -3316,6 +3316,46 @@ cell AMX_NATIVE_CALL rg_player_relationship(AMX *amx, cell *params) return CSGameRules()->PlayerRelationship(pPlayer, pTarget); } + +/* +* Removes spawn protection from a player +* +* @param player Player index +* +* @noreturn +*/ +cell AMX_NATIVE_CALL rg_remove_spawn_protection(AMX* amx, cell* params) { + enum args_e { arg_count, arg_player }; + + CHECK_ISPLAYER(arg_player); + + CBasePlayer* pPlayer = UTIL_PlayerByIndex(params[arg_player]); + CHECK_CONNECTED(pPlayer, arg_player); + + pPlayer->CSPlayer()->RemoveSpawnProtection(); + return TRUE; +} + +/* +* Sets spawn protection for a player with given time +* +* @param player Player index +* @param time Protection time +* +* @noreturn +*/ +cell AMX_NATIVE_CALL rg_set_spawn_protection(AMX* amx, cell* params) { + enum args_e { arg_count, arg_player, arg_time }; + + CHECK_ISPLAYER(arg_player); + + CBasePlayer* pPlayer = UTIL_PlayerByIndex(params[arg_player]); + CHECK_CONNECTED(pPlayer, arg_player); + + pPlayer->CSPlayer()->SetSpawnProtection(params[arg_time]); + return TRUE; +} + AMX_NATIVE_INFO Misc_Natives_RG[] = { { "rg_set_animation", rg_set_animation }, @@ -3429,6 +3469,8 @@ AMX_NATIVE_INFO Misc_Natives_RG[] = { "rg_set_observer_mode", rg_set_observer_mode }, { "rg_death_notice", rg_death_notice }, { "rg_player_relationship", rg_player_relationship }, + { "rg_remove_spawn_protection", rg_remove_spawn_protection }, + { "rg_set_spawn_protection", rg_set_spawn_protection }, { nullptr, nullptr } };