1
0
mirror of https://github.com/alliedmodders/metamod-source.git synced 2025-01-19 08:52:34 +01:00

Iterate on ConCommands, ClientCommands, and the split S1/S2 compat

This commit is contained in:
Nick Hastings 2023-05-21 12:13:17 -04:00
parent 956861f27a
commit 817b5f940e
11 changed files with 66 additions and 65 deletions

View File

@ -53,6 +53,14 @@ class ConCommandBase;
#define MMIFACE_SH_HOOKMANAUTOGEN "IHookManagerAutoGen" /**< SourceHook::IHookManagerAutoGen Pointer */
#define IFACE_MAXNUM 999 /**< Maximum interface version */
#if defined META_IS_SOURCE2
typedef CPlayerSlot MMSPlayer_t;
static const MMSPlayer_t MMSPlayer_INVALID = CPlayerSlot(-1);
#else
typedef edict_t* MMSPlayer_t;
static const MMSPlayer_t MMSPlayer_INVALID = nullptr;
#endif
typedef void* (*CreateInterfaceFn)(const char *pName, int *pReturnCode);
class IServerPluginCallbacks;
@ -255,7 +263,7 @@ namespace SourceMM
* @param client Client edict pointer.
* @param fmt Formatted string to print to the client.
*/
virtual void ClientConPrintf(edict_t *client, const char *fmt, ...) =0;
virtual void ClientConPrintf(MMSPlayer_t client, const char *fmt, ...) =0;
/**
* @brief Wrapper around InterfaceSearch(). Assumes no maximum.

View File

@ -200,7 +200,7 @@ static class ProviderCallbacks : public IMetamodSourceProviderCallbacks
return Command_Meta(info);
}
virtual bool OnCommand_ClientMeta(edict_t* client, IMetamodSourceCommandInfo* info) override
virtual bool OnCommand_ClientMeta(MMSPlayer_t client, IMetamodSourceCommandInfo* info) override
{
return Command_ClientMeta(client, info);
}
@ -750,7 +750,7 @@ size_t MetamodSource::PathFormat(char *buffer, size_t len, const char *fmt, ...)
return mylen;
}
void MetamodSource::ClientConPrintf(edict_t *client, const char *fmt, ...)
void MetamodSource::ClientConPrintf(MMSPlayer_t client, const char *fmt, ...)
{
va_list ap;
char buffer[2048];

View File

@ -53,40 +53,40 @@ using namespace SourceMM;
class MetamodSource : public ISmmAPI
{
public: // ISmmAPI
void LogMsg(ISmmPlugin *pl, const char *msg, ...) override;
CreateInterfaceFn GetEngineFactory(bool syn=true) override;
CreateInterfaceFn GetPhysicsFactory(bool syn=true) override;
CreateInterfaceFn GetFileSystemFactory(bool syn=true) override;
CreateInterfaceFn GetServerFactory(bool syn=true) override;
CGlobalVars *GetCGlobals() override;
bool RegisterConCommandBase(ISmmPlugin *plugin, ConCommandBase *pCommand) override;
void UnregisterConCommandBase(ISmmPlugin *plugin, ConCommandBase *pCommand) override;
void ConPrint(const char *str) override;
void ConPrintf(const char *fmt, ...) override;
void GetApiVersions(int &major, int &minor, int &plvers, int &plmin) override;
void GetShVersions(int &shvers, int &shimpl) override;
void AddListener(ISmmPlugin *plugin, IMetamodListener *pListener) override;
void *MetaFactory(const char *iface, int *ret, PluginId *id) override;
int FormatIface(char iface[], size_t maxlength) override;
void *InterfaceSearch(CreateInterfaceFn fn, const char *iface, int max, int *ret) override;
const char *GetBaseDir() override;
size_t PathFormat(char *buffer, size_t len, const char *fmt, ...) override;
void ClientConPrintf(MMSPlayer_t client, const char *fmt, ...) override;
void *VInterfaceMatch(CreateInterfaceFn fn, const char *iface, int min=-1) override;
void EnableVSPListener() override;
int GetGameDLLVersion() override;
int GetUserMessageCount() override;
int FindUserMessage(const char *name, int *size=NULL) override;
const char *GetUserMessage(int index, int *size=NULL) override;
int GetVSPVersion() override;
int GetSourceEngineBuild() override;
IServerPluginCallbacks *GetVSPInfo(int *pVersion) override;
size_t Format(char *buffer, size_t maxlength, const char *format, ...) override;
size_t FormatArgs(char *buffer, size_t maxlength, const char *format, va_list ap) override;
public:
void LogMsg(ISmmPlugin *pl, const char *msg, ...);
CreateInterfaceFn GetEngineFactory(bool syn=true);
CreateInterfaceFn GetPhysicsFactory(bool syn=true);
CreateInterfaceFn GetFileSystemFactory(bool syn=true);
CreateInterfaceFn GetServerFactory(bool syn=true);
CGlobalVars *GetCGlobals();
void SetLastMetaReturn(META_RES res);
META_RES GetLastMetaReturn();
bool RegisterConCommandBase(ISmmPlugin *plugin, ConCommandBase *pCommand);
void UnregisterConCommandBase(ISmmPlugin *plugin, ConCommandBase *pCommand);
void ConPrint(const char *str);
void ConPrintf(const char *fmt, ...);
void GetApiVersions(int &major, int &minor, int &plvers, int &plmin);
void GetShVersions(int &shvers, int &shimpl);
void AddListener(ISmmPlugin *plugin, IMetamodListener *pListener);
void *MetaFactory(const char *iface, int *ret, PluginId *id);
int FormatIface(char iface[], size_t maxlength);
void *InterfaceSearch(CreateInterfaceFn fn, const char *iface, int max, int *ret);
const char *GetBaseDir();
size_t PathFormat(char *buffer, size_t len, const char *fmt, ...);
void ClientConPrintf(edict_t *client, const char *fmt, ...);
void *VInterfaceMatch(CreateInterfaceFn fn, const char *iface, int min=-1);
void EnableVSPListener();
int GetGameDLLVersion();
int GetUserMessageCount();
int FindUserMessage(const char *name, int *size=NULL);
const char *GetUserMessage(int index, int *size=NULL);
int GetVSPVersion();
int GetSourceEngineBuild();
IServerPluginCallbacks *GetVSPInfo(int *pVersion);
size_t Format(char *buffer, size_t maxlength, const char *format, ...);
size_t FormatArgs(char *buffer, size_t maxlength, const char *format, va_list ap);
public:
bool IsLoadedAsGameDLL();
const char *GetGameBinaryPath();
const char *GetPluginsFile();

View File

@ -44,9 +44,9 @@ using namespace SourceHook;
#define CLIENT_CONMSG g_Metamod.ClientConPrintf
template <typename ... Ts>
void CMDMSG(edict_t *client, const char *pMsg, Ts ... ts)
void CMDMSG(MMSPlayer_t client, const char *pMsg, Ts ... ts)
{
if (client)
if (client != MMSPlayer_INVALID)
{
CLIENT_CONMSG(client, pMsg, ts...);
}
@ -56,7 +56,7 @@ void CMDMSG(edict_t *client, const char *pMsg, Ts ... ts)
}
}
static void ReplyCredits(edict_t *client = nullptr)
static void ReplyCredits(MMSPlayer_t client = MMSPlayer_INVALID)
{
CMDMSG(client, "Metamod:Source was developed by:\n");
CMDMSG(client, " SourceHook: Pavol \"PM OnoTo\" Marko\n");
@ -66,7 +66,7 @@ static void ReplyCredits(edict_t *client = nullptr)
CMDMSG(client, "http://www.metamodsource.net/\n");
}
static void ReplyVersion(edict_t *client = nullptr)
static void ReplyVersion(MMSPlayer_t client = MMSPlayer_INVALID)
{
CMDMSG(client, " Metamod:Source Version Information\n");
CMDMSG(client, " Metamod:Source version %s\n", METAMOD_VERSION);
@ -642,7 +642,7 @@ bool Command_Meta(IMetamodSourceCommandInfo *info)
return true;
}
bool Command_ClientMeta(edict_t *client, IMetamodSourceCommandInfo *info)
bool Command_ClientMeta(MMSPlayer_t client, IMetamodSourceCommandInfo *info)
{
const char *cmd = info->GetArg(0);

View File

@ -31,6 +31,6 @@
#include "metamod_provider.h"
bool Command_Meta(IMetamodSourceCommandInfo *info);
bool Command_ClientMeta(edict_t *client, IMetamodSourceCommandInfo *info);
bool Command_ClientMeta(MMSPlayer_t client, IMetamodSourceCommandInfo *info);
#endif //_INCLUDE_CONCOMMANDS_H

View File

@ -98,7 +98,7 @@ namespace SourceMM
/**
* @brief Called when a client executes "meta" as a ClientCommand
*/
virtual bool OnCommand_ClientMeta(edict_t* client, IMetamodSourceCommandInfo* info) = 0;
virtual bool OnCommand_ClientMeta(MMSPlayer_t player, IMetamodSourceCommandInfo* info) = 0;
};
class IMetamodSourceProvider
@ -150,10 +150,10 @@ namespace SourceMM
/**
* @brief Prints text in the specified client's console.
*
* @param client Client edict pointer.
* @param player Player identifier
* @param msg Message string.
*/
virtual void ClientConsolePrint(edict_t *client, const char *msg) =0;
virtual void ClientConsolePrint(MMSPlayer_t player, const char *msg) =0;
/**
* @brief Halts the server with a fatal error message.

View File

@ -60,7 +60,7 @@ public: // Must implement
virtual bool ProcessVDF(const char* file, char path[], size_t path_len, char alias[], size_t alias_len) override = 0;
virtual const char* GetCommandLineValue(const char* key, const char* defval) override = 0;
virtual void ConsolePrint(const char* msg) override = 0;
virtual void ClientConsolePrint(edict_t* client, const char* msg) override = 0;
virtual void ClientConsolePrint(MMSPlayer_t player, const char* msg) override = 0;
virtual void ServerCommand(const char* cmd) override = 0;
virtual MetamodSourceConVar *CreateConVar(const char* name,
const char* defval,

View File

@ -347,7 +347,7 @@ const char* SourceProvider::GetCommandLineValue(const char* key, const char* def
return NULL;
}
void SourceProvider::ClientConsolePrint(edict_t* pEdict, const char* message)
void SourceProvider::ClientConsolePrint(MMSPlayer_t pEdict, const char* message)
{
engine->ClientPrintf(pEdict, message);
}

View File

@ -45,7 +45,7 @@ public: // BaseProvider
virtual const char* GetGameDescription() override;
virtual const char* GetCommandLineValue(const char* key, const char* defval) override;
virtual void ConsolePrint(const char* msg) override;
virtual void ClientConsolePrint(edict_t* client, const char* msg) override;
virtual void ClientConsolePrint(MMSPlayer_t client, const char* msg) override;
virtual void ServerCommand(const char* cmd) override;
virtual MetamodSourceConVar *CreateConVar(const char* name,
const char* defval,

View File

@ -38,8 +38,8 @@ static Source2Provider g_Source2Provider;
IMetamodSourceProvider* provider = &g_Source2Provider;
CON_COMMAND_EXTERN(meta, LocalCommand_Meta, "Metamod:Source control options");
ConCommand meta_local_cmd("meta", LocalCommand_Meta, "Metamod:Source control options");
static ISource2ServerConfig* serverconfig = NULL;
INetworkServerService* netservice = NULL;
@ -53,7 +53,7 @@ SH_DECL_HOOK3_void(INetworkServerService, StartupServer, SH_NOATTRIB, 0, const G
SH_DECL_HOOK5_void(IEngineServiceMgr, SwitchToLoop, SH_NOATTRIB, 0, const char *, KeyValues *, uint32, const char *, bool);
SH_DECL_HOOK2_void(INetworkGameServer, Init, SH_NOATTRIB, 0, const GameSessionConfiguration_t &, const char *);
SH_DECL_HOOK3(INetworkGameServer, StartChangeLevel, SH_NOATTRIB, 0, CUtlVector<INetworkGameClient *> *, const char *, const char *, void *);
SH_DECL_HOOK2_void(IServerGameClients, ClientCommand, SH_NOATTRIB, 0, CEntityIndex, const CCommand&);
SH_DECL_HOOK2_void(IServerGameClients, ClientCommand, SH_NOATTRIB, 0, CPlayerSlot, const CCommand&);
#ifdef SHOULD_OVERRIDE_ALLOWDEDICATED_SERVER
SH_DECL_HOOK1(ISource2ServerConfig, AllowDedicatedServers, const, 0, bool, EUniverse);
@ -125,9 +125,7 @@ void Source2Provider::Notify_DLLInit_Pre(CreateInterfaceFn engineFactory,
g_pCVar = icvar;
#ifdef S2_CONVAR_UNFINISHED
g_SMConVarAccessor.RegisterConCommandBase(&meta_local_cmd);
#endif
ConVar_Register(FCVAR_RELEASE);
if (gameclients)
{
@ -144,9 +142,7 @@ void Source2Provider::Notify_DLLInit_Pre(CreateInterfaceFn engineFactory,
void Source2Provider::Notify_DLLShutdown_Pre()
{
#ifdef S2_CONVAR_UNFINISHED
g_SMConVarAccessor.RemoveMetamodCommands();
#endif
ConVar_Unregister();
}
bool Source2Provider::ProcessVDF(const char* file, char path[], size_t path_len, char alias[], size_t alias_len)
@ -242,9 +238,8 @@ void Source2Provider::ConsolePrint(const char* str)
ConMsg("%s", str);
}
void Source2Provider::ClientConsolePrint(edict_t* pEdict, const char* message)
void Source2Provider::ClientConsolePrint(MMSPlayer_t client, const char* message)
{
int client = (int)(pEdict - gpGlobals->pEdicts);
engine->ClientPrintf(client, message);
}
@ -263,7 +258,7 @@ const char* Source2Provider::GetConVarString(MetamodSourceConVar *convar)
return convar->GetString();
#else
return "";
return nullptr;
#endif
}
@ -350,7 +345,7 @@ private:
const CCommand* m_cmd;
};
void LocalCommand_Meta(const CCommand& args)
void LocalCommand_Meta(const CCommandContext &, const CCommand& args)
{
if (nullptr != g_Source2Provider.m_pCallbacks)
{
@ -438,17 +433,15 @@ void Source2Provider::Hook_SwitchToLoop(const char *pszLoopName, KeyValues *pKV,
RETURN_META(MRES_IGNORED);
}
void Source2Provider::Hook_ClientCommand(CEntityIndex index, const CCommand& _cmd)
void Source2Provider::Hook_ClientCommand(CPlayerSlot nSlot, const CCommand& _cmd)
{
int client = index.Get();
GlobCommand cmd(&_cmd);
if (strcmp(cmd.GetArg(0), "meta") == 0)
{
if (nullptr != m_pCallbacks)
{
auto pEdict = reinterpret_cast<edict_t *>(gpGlobals->pEdicts + (intp)client);
m_pCallbacks->OnCommand_ClientMeta(pEdict, &cmd);
m_pCallbacks->OnCommand_ClientMeta(nSlot, &cmd);
}
RETURN_META(MRES_SUPERCEDE);

View File

@ -52,7 +52,7 @@ public:
virtual const char* GetGameDescription() override;
virtual const char* GetCommandLineValue(const char* key, const char* defval) override;
virtual void ConsolePrint(const char* msg) override;
virtual void ClientConsolePrint(edict_t* client, const char* msg) override;
virtual void ClientConsolePrint(MMSPlayer_t player, const char* msg) override;
virtual void ServerCommand(const char* cmd) override;
virtual MetamodSourceConVar *CreateConVar(const char* name,
const char* defval,
@ -71,14 +71,14 @@ public:
void Hook_Init(const GameSessionConfiguration_t &config, const char* pszMapName);
CUtlVector<INetworkGameClient *> *Hook_StartChangeLevel(const char*, const char*, void*);
void Hook_SwitchToLoop(const char *pszLoopName, KeyValues *pKV, uint32 nId, const char *pszUnk, bool bUnk);
void Hook_ClientCommand(CEntityIndex index, const CCommand& args);
void Hook_ClientCommand(CPlayerSlot nSlot, const CCommand& args);
private:
bool KVLoadFromFile(KeyValues *kv, IFileSystem *filesystem, const char *resourceName, const char *pathID);
private:
IFileSystem* baseFs = nullptr;
std::string sLastMap;
friend void LocalCommand_Meta(const CCommand& args);
friend void LocalCommand_Meta(const CCommandContext& context, const CCommand& args);
};
#endif