From 2d0ac93f6371e4109b189da79c8660a17c6eb9fe Mon Sep 17 00:00:00 2001 From: fl0werD Date: Wed, 8 Nov 2023 18:18:01 +0400 Subject: [PATCH] Implement PlayerDeathThink hook (#885) --- regamedll/dlls/API/CAPI_Impl.cpp | 2 ++ regamedll/dlls/API/CAPI_Impl.h | 8 ++++++++ regamedll/dlls/player.cpp | 4 +++- regamedll/dlls/player.h | 1 + regamedll/public/regamedll/regamedll_api.h | 8 +++++++- regamedll/version/version.h | 2 +- 6 files changed, 22 insertions(+), 3 deletions(-) diff --git a/regamedll/dlls/API/CAPI_Impl.cpp b/regamedll/dlls/API/CAPI_Impl.cpp index 3075c841..55a56e31 100644 --- a/regamedll/dlls/API/CAPI_Impl.cpp +++ b/regamedll/dlls/API/CAPI_Impl.cpp @@ -333,6 +333,8 @@ GAMEHOOK_REGISTRY(CBasePlayerWeapon_KickBack); GAMEHOOK_REGISTRY(CBasePlayerWeapon_SendWeaponAnim); GAMEHOOK_REGISTRY(CSGameRules_SendDeathMessage); +GAMEHOOK_REGISTRY(CBasePlayer_PlayerDeathThink); + int CReGameApi::GetMajorVersion() { return REGAMEDLL_API_VERSION_MAJOR; } diff --git a/regamedll/dlls/API/CAPI_Impl.h b/regamedll/dlls/API/CAPI_Impl.h index f3de48d8..b64f6d81 100644 --- a/regamedll/dlls/API/CAPI_Impl.h +++ b/regamedll/dlls/API/CAPI_Impl.h @@ -737,6 +737,10 @@ typedef IHookChainRegistryClassImpl CReGameHook_CBasePlayerWeapon_SendWeaponAnim; typedef IHookChainRegistryClassImpl CReGameHookRegistry_CBasePlayerWeapon_SendWeaponAnim; +// CBasePlayer::PlayerDeathThink hook +typedef IHookChainClassImpl CReGameHook_CBasePlayer_PlayerDeathThink; +typedef IHookChainRegistryClassImpl CReGameHookRegistry_CBasePlayer_PlayerDeathThink; + class CReGameHookchains: public IReGameHookchains { public: // CBasePlayer virtual @@ -895,6 +899,8 @@ public: CReGameHookRegistry_CBasePlayerWeapon_SendWeaponAnim m_CBasePlayerWeapon_SendWeaponAnim; CReGameHookRegistry_CSGameRules_SendDeathMessage m_CSGameRules_SendDeathMessage; + CReGameHookRegistry_CBasePlayer_PlayerDeathThink m_CBasePlayer_PlayerDeathThink; + public: virtual IReGameHookRegistry_CBasePlayer_Spawn *CBasePlayer_Spawn(); virtual IReGameHookRegistry_CBasePlayer_Precache *CBasePlayer_Precache(); @@ -1050,6 +1056,8 @@ public: virtual IReGameHookRegistry_CBasePlayerWeapon_KickBack *CBasePlayerWeapon_KickBack(); virtual IReGameHookRegistry_CBasePlayerWeapon_SendWeaponAnim *CBasePlayerWeapon_SendWeaponAnim(); virtual IReGameHookRegistry_CSGameRules_SendDeathMessage *CSGameRules_SendDeathMessage(); + + virtual IReGameHookRegistry_CBasePlayer_PlayerDeathThink *CBasePlayer_PlayerDeathThink(); }; extern CReGameHookchains g_ReGameHookchains; diff --git a/regamedll/dlls/player.cpp b/regamedll/dlls/player.cpp index d3b1391c..5e7eed2f 100644 --- a/regamedll/dlls/player.cpp +++ b/regamedll/dlls/player.cpp @@ -3784,7 +3784,9 @@ void EXT_FUNC CBasePlayer::__API_HOOK(Disappear)() pev->angles.z = 0; } -void CBasePlayer::PlayerDeathThink() +LINK_HOOK_CLASS_VOID_CHAIN2(CBasePlayer, PlayerDeathThink) + +void EXT_FUNC CBasePlayer::__API_HOOK(PlayerDeathThink)() { if (m_iJoiningState != JOINED) return; diff --git a/regamedll/dlls/player.h b/regamedll/dlls/player.h index b0e5c42b..d3b8e623 100644 --- a/regamedll/dlls/player.h +++ b/regamedll/dlls/player.h @@ -446,6 +446,7 @@ public: void JoiningThink_OrigFunc(); void CheckTimeBasedDamage_OrigFunc(); edict_t *EntSelectSpawnPoint_OrigFunc(); + void PlayerDeathThink_OrigFunc(); CCSPlayer *CSPlayer() const; #endif // REGAMEDLL_API diff --git a/regamedll/public/regamedll/regamedll_api.h b/regamedll/public/regamedll/regamedll_api.h index d82b2c84..e1191494 100644 --- a/regamedll/public/regamedll/regamedll_api.h +++ b/regamedll/public/regamedll/regamedll_api.h @@ -38,7 +38,7 @@ #include #define REGAMEDLL_API_VERSION_MAJOR 5 -#define REGAMEDLL_API_VERSION_MINOR 25 +#define REGAMEDLL_API_VERSION_MINOR 26 // CBasePlayer::Spawn hook typedef IHookChainClass IReGameHook_CBasePlayer_Spawn; @@ -616,6 +616,10 @@ typedef IHookChainRegistryClass IReGameHook_CBasePlayerWeapon_SendWeaponAnim; typedef IHookChainRegistryClass IReGameHookRegistry_CBasePlayerWeapon_SendWeaponAnim; +// CBasePlayer::PlayerDeathThink hook +typedef IHookChainClass IReGameHook_CBasePlayer_PlayerDeathThink; +typedef IHookChainRegistryClass IReGameHookRegistry_CBasePlayer_PlayerDeathThink; + class IReGameHookchains { public: virtual ~IReGameHookchains() {} @@ -774,6 +778,8 @@ public: virtual IReGameHookRegistry_CBasePlayerWeapon_KickBack *CBasePlayerWeapon_KickBack() = 0; virtual IReGameHookRegistry_CBasePlayerWeapon_SendWeaponAnim *CBasePlayerWeapon_SendWeaponAnim() = 0; virtual IReGameHookRegistry_CSGameRules_SendDeathMessage *CSGameRules_SendDeathMessage() = 0; + + virtual IReGameHookRegistry_CBasePlayer_PlayerDeathThink *CBasePlayer_PlayerDeathThink() = 0; }; struct ReGameFuncs_t { diff --git a/regamedll/version/version.h b/regamedll/version/version.h index cca231b8..0f32ed96 100644 --- a/regamedll/version/version.h +++ b/regamedll/version/version.h @@ -6,5 +6,5 @@ #pragma once #define VERSION_MAJOR 5 -#define VERSION_MINOR 25 +#define VERSION_MINOR 26 #define VERSION_MAINTENANCE 0