2
0
mirror of https://github.com/rehlds/rehlds.git synced 2025-01-07 12:35:33 +03:00

Merge pull request #191 from Adidasman1/master

ReHLDS API: Add hook on SV_Spawn_f
This commit is contained in:
theAsmodai 2016-03-26 15:32:04 +03:00
commit 1c7d03e3c7
6 changed files with 25 additions and 4 deletions

View File

@ -846,7 +846,7 @@ qboolean Netchan_Process(netchan_t *chan)
{ {
// Make sure we actually could have ack'd this message // Make sure we actually could have ack'd this message
#ifdef REHLDS_FIXES #ifdef REHLDS_FIXES
if (sequence_ack >= chan->last_reliable_sequence) if (sequence_ack >= (unsigned)chan->last_reliable_sequence)
#else // REHLDS_FIXES #else // REHLDS_FIXES
if (chan->incoming_acknowledged + 1 >= chan->last_reliable_sequence) if (chan->incoming_acknowledged + 1 >= chan->last_reliable_sequence)
#endif // REHLDS_FIXES #endif // REHLDS_FIXES

View File

@ -644,6 +644,7 @@ void SV_SendUserReg(sizebuf_t *msg);
void SV_New_f(void); void SV_New_f(void);
void SV_SendRes_f(void); void SV_SendRes_f(void);
void SV_Spawn_f(void); void SV_Spawn_f(void);
void SV_Spawn_f_internal(void);
void SV_CheckUpdateRate(double *rate); void SV_CheckUpdateRate(double *rate);
void SV_RejectConnection(netadr_t *adr, char *fmt, ...); void SV_RejectConnection(netadr_t *adr, char *fmt, ...);
void SV_RejectConnectionForPassword(netadr_t *adr); void SV_RejectConnectionForPassword(netadr_t *adr);

View File

@ -1663,8 +1663,13 @@ void SV_SendRes_f(void)
} }
} }
/* <a8922> ../engine/sv_main.c:2096 */
void SV_Spawn_f(void) void SV_Spawn_f(void)
{
g_RehldsHookchains.m_SV_Spawn_f.callChain(SV_Spawn_f_internal);
}
/* <a8922> ../engine/sv_main.c:2096 */
void EXT_FUNC SV_Spawn_f_internal(void)
{ {
unsigned char data[NET_MAX_PAYLOAD]; unsigned char data[NET_MAX_PAYLOAD];
sizebuf_t msg; sizebuf_t msg;
@ -2118,7 +2123,7 @@ void SV_ReplaceSpecialCharactersInName(char *newname, const char *oldname)
break; break;
// http://unicode-table.com/blocks/halfwidth-and-fullwidth-forms/ // http://unicode-table.com/blocks/halfwidth-and-fullwidth-forms/
newname[n++] = 0xEF; newname[n++] = char(0xEF);
newname[n++] = 0xBC | (((*s - 0x20) & 0x40) >> 6); newname[n++] = 0xBC | (((*s - 0x20) & 0x40) >> 6);
newname[n++] = 0x80 + ((*s - 0x20) & 0x3F); newname[n++] = 0x80 + ((*s - 0x20) & 0x3F);

View File

@ -35,7 +35,7 @@
#include "model.h" #include "model.h"
#define REHLDS_API_VERSION_MAJOR 2 #define REHLDS_API_VERSION_MAJOR 2
#define REHLDS_API_VERSION_MINOR 10 #define REHLDS_API_VERSION_MINOR 11
//Steam_NotifyClientConnect hook //Steam_NotifyClientConnect hook
typedef IHookChain<qboolean, IGameClient*, const void*, unsigned int> IRehldsHook_Steam_NotifyClientConnect; typedef IHookChain<qboolean, IGameClient*, const void*, unsigned int> IRehldsHook_Steam_NotifyClientConnect;
@ -177,6 +177,10 @@ typedef IVoidHookChainRegistry<struct cvar_s *, const char *> IRehldsHookRegistr
typedef IVoidHookChain<IGameClient *, usercmd_t *, int, int, int> IRehldsHook_SV_EstablishTimeBase; typedef IVoidHookChain<IGameClient *, usercmd_t *, int, int, int> IRehldsHook_SV_EstablishTimeBase;
typedef IVoidHookChainRegistry<IGameClient *, usercmd_t *, int, int, int> IRehldsHookRegistry_SV_EstablishTimeBase; typedef IVoidHookChainRegistry<IGameClient *, usercmd_t *, int, int, int> IRehldsHookRegistry_SV_EstablishTimeBase;
//SV_Spawn_f hook
typedef IVoidHookChain<> IRehldsHook_SV_Spawn_f;
typedef IVoidHookChainRegistry<> IRehldsHookRegistry_SV_Spawn_f;
class IRehldsHookchains { class IRehldsHookchains {
public: public:
virtual ~IRehldsHookchains() { } virtual ~IRehldsHookchains() { }
@ -216,6 +220,7 @@ public:
virtual IRehldsHookRegistry_Steam_GSBUpdateUserData* Steam_GSBUpdateUserData() = 0; virtual IRehldsHookRegistry_Steam_GSBUpdateUserData* Steam_GSBUpdateUserData() = 0;
virtual IRehldsHookRegistry_Cvar_DirectSet* Cvar_DirectSet() = 0; virtual IRehldsHookRegistry_Cvar_DirectSet* Cvar_DirectSet() = 0;
virtual IRehldsHookRegistry_SV_EstablishTimeBase* SV_EstablishTimeBase() = 0; virtual IRehldsHookRegistry_SV_EstablishTimeBase* SV_EstablishTimeBase() = 0;
virtual IRehldsHookRegistry_SV_Spawn_f* SV_Spawn_f() = 0;
}; };
struct RehldsFuncs_t { struct RehldsFuncs_t {

View File

@ -368,6 +368,10 @@ IRehldsHookRegistry_SV_EstablishTimeBase* CRehldsHookchains::SV_EstablishTimeBas
return &m_SV_EstablishTimeBase; return &m_SV_EstablishTimeBase;
} }
IRehldsHookRegistry_SV_Spawn_f* CRehldsHookchains::SV_Spawn_f() {
return &m_SV_Spawn_f;
}
int EXT_FUNC CRehldsApi::GetMajorVersion() int EXT_FUNC CRehldsApi::GetMajorVersion()
{ {
return REHLDS_API_VERSION_MAJOR; return REHLDS_API_VERSION_MAJOR;

View File

@ -171,6 +171,10 @@ typedef IVoidHookChainRegistryImpl<struct cvar_s *, const char *> CRehldsHookReg
typedef IVoidHookChainImpl<IGameClient *, usercmd_t *, int, int, int> CRehldsHook_SV_EstablishTimeBase; typedef IVoidHookChainImpl<IGameClient *, usercmd_t *, int, int, int> CRehldsHook_SV_EstablishTimeBase;
typedef IVoidHookChainRegistryImpl<IGameClient *, usercmd_t *, int, int, int> CRehldsHookRegistry_SV_EstablishTimeBase; typedef IVoidHookChainRegistryImpl<IGameClient *, usercmd_t *, int, int, int> CRehldsHookRegistry_SV_EstablishTimeBase;
//SV_Spawn_f hook
typedef IVoidHookChainImpl<> CRehldsHook_SV_Spawn_f;
typedef IVoidHookChainRegistryImpl<> CRehldsHookRegistry_SV_Spawn_f;
class CRehldsHookchains : public IRehldsHookchains { class CRehldsHookchains : public IRehldsHookchains {
public: public:
CRehldsHookRegistry_Steam_NotifyClientConnect m_Steam_NotifyClientConnect; CRehldsHookRegistry_Steam_NotifyClientConnect m_Steam_NotifyClientConnect;
@ -208,6 +212,7 @@ public:
CRehldsHookRegistry_Steam_GSBUpdateUserData m_Steam_GSBUpdateUserData; CRehldsHookRegistry_Steam_GSBUpdateUserData m_Steam_GSBUpdateUserData;
CRehldsHookRegistry_Cvar_DirectSet m_Cvar_DirectSet; CRehldsHookRegistry_Cvar_DirectSet m_Cvar_DirectSet;
CRehldsHookRegistry_SV_EstablishTimeBase m_SV_EstablishTimeBase; CRehldsHookRegistry_SV_EstablishTimeBase m_SV_EstablishTimeBase;
CRehldsHookRegistry_SV_Spawn_f m_SV_Spawn_f;
public: public:
virtual IRehldsHookRegistry_Steam_NotifyClientConnect* Steam_NotifyClientConnect(); virtual IRehldsHookRegistry_Steam_NotifyClientConnect* Steam_NotifyClientConnect();
@ -245,6 +250,7 @@ public:
virtual IRehldsHookRegistry_Steam_GSBUpdateUserData* Steam_GSBUpdateUserData(); virtual IRehldsHookRegistry_Steam_GSBUpdateUserData* Steam_GSBUpdateUserData();
virtual IRehldsHookRegistry_Cvar_DirectSet* Cvar_DirectSet(); virtual IRehldsHookRegistry_Cvar_DirectSet* Cvar_DirectSet();
virtual IRehldsHookRegistry_SV_EstablishTimeBase* SV_EstablishTimeBase(); virtual IRehldsHookRegistry_SV_EstablishTimeBase* SV_EstablishTimeBase();
virtual IRehldsHookRegistry_SV_Spawn_f* SV_Spawn_f();
}; };
extern CRehldsHookchains g_RehldsHookchains; extern CRehldsHookchains g_RehldsHookchains;