2005-04-16 23:33:39 +00:00
|
|
|
/* ======== SourceMM ========
|
2006-01-07 14:38:18 +00:00
|
|
|
* Copyright (C) 2004-2006 Metamod:Source Development Team
|
2005-04-16 23:33:39 +00:00
|
|
|
* No warranties of any kind
|
|
|
|
*
|
|
|
|
* License: zlib/libpng
|
|
|
|
*
|
|
|
|
* Author(s): David "BAILOPAN" Anderson
|
|
|
|
* ============================
|
|
|
|
*/
|
|
|
|
|
2005-04-16 19:59:26 +00:00
|
|
|
#ifndef _INCLUDE_ISMM_API_H
|
|
|
|
#define _INCLUDE_ISMM_API_H
|
|
|
|
|
2005-04-16 23:33:39 +00:00
|
|
|
/**
|
|
|
|
* @brief External API interface
|
|
|
|
* @file ISmmAPI.h
|
|
|
|
*/
|
|
|
|
|
2005-04-16 19:59:26 +00:00
|
|
|
#include <interface.h>
|
|
|
|
#include <eiface.h>
|
2005-05-16 20:15:57 +00:00
|
|
|
#include <convar.h>
|
2005-04-16 19:59:26 +00:00
|
|
|
#include <sourcehook/sourcehook.h>
|
|
|
|
#include "IPluginManager.h"
|
|
|
|
|
2005-09-13 18:20:53 +00:00
|
|
|
#if defined __GNUC__
|
|
|
|
#if ((__GNUC__ == 3) && (__GNUC_MINOR__ < 4)) || (__GNUC__ < 3)
|
2005-09-13 20:25:30 +00:00
|
|
|
#error "You must compile with at least GCC 3.4! If you know what you are doing, you can remove this message."
|
2005-09-13 18:20:53 +00:00
|
|
|
#endif //version check
|
|
|
|
#endif //__GNUC__
|
|
|
|
|
2005-10-20 14:37:47 +00:00
|
|
|
class IMetamodListener;
|
2005-04-16 19:59:26 +00:00
|
|
|
class ISmmPluginManager;
|
|
|
|
class ISmmPlugin;
|
|
|
|
|
2005-10-20 14:37:47 +00:00
|
|
|
#define MMIFACE_SOURCEHOOK "ISourceHook"
|
|
|
|
#define MMIFACE_PLMANAGER "IPluginManager"
|
|
|
|
|
2005-04-16 19:59:26 +00:00
|
|
|
class ISmmAPI
|
|
|
|
{
|
|
|
|
public:
|
|
|
|
virtual void LogMsg(ISmmPlugin *pl, const char *msg, ...) =0;
|
|
|
|
public:
|
|
|
|
virtual CreateInterfaceFn engineFactory(bool syn=true) =0;
|
|
|
|
virtual CreateInterfaceFn physicsFactory(bool syn=true) =0;
|
|
|
|
virtual CreateInterfaceFn fileSystemFactory(bool syn=true) =0;
|
|
|
|
virtual CreateInterfaceFn serverFactory(bool syn=true) =0;
|
|
|
|
virtual CGlobalVars *pGlobals() =0;
|
|
|
|
virtual void SetLastMetaReturn(META_RES res) =0;
|
2005-04-16 23:33:39 +00:00
|
|
|
virtual META_RES GetLastMetaReturn() =0;
|
2005-10-06 21:59:10 +00:00
|
|
|
public: //Added in 1.00-RC2 (0:0)
|
|
|
|
//solves concommand problems by keeping track for loading/unloading
|
2005-05-16 20:15:57 +00:00
|
|
|
virtual IConCommandBaseAccessor *GetCvarBaseAccessor() =0;
|
2005-05-26 08:06:23 +00:00
|
|
|
virtual bool RegisterConCmdBase(ISmmPlugin *plugin, ConCommandBase *pCommand) =0;
|
|
|
|
virtual void UnregisterConCmdBase(ISmmPlugin *plugin, ConCommandBase *pCommand) =0;
|
2005-10-06 21:59:10 +00:00
|
|
|
//attempt fix at valve not exporting rcon printing
|
2005-06-24 22:26:19 +00:00
|
|
|
//these do not add newlines
|
|
|
|
virtual void ConPrint(const char *fmt) =0;
|
|
|
|
virtual void ConPrintf(const char *fmt, ...) =0;
|
2005-12-06 07:59:18 +00:00
|
|
|
public: //Added in 1.1.0 (1:0)
|
2005-10-06 21:59:10 +00:00
|
|
|
//added by request. Checks if ConPrint/ConPrintf will mirror to rcon.
|
|
|
|
virtual bool RemotePrintingAvailable() =0;
|
|
|
|
//Returns the Metamod Version numbers as major version and minor (API) version.
|
|
|
|
//changes to minor version are guaranteed to be backwards compatible.
|
|
|
|
//changes to major version are not.
|
|
|
|
//Also returns current plugin version and minimum plugin version
|
|
|
|
virtual void GetApiVersions(int &major, int &minor, int &plvers, int &plmin) =0;
|
|
|
|
//Returns sourcehook API version and implementation version
|
|
|
|
virtual void GetShVersions(int &shvers, int &shimpl) =0;
|
2005-10-20 14:37:47 +00:00
|
|
|
//Binds an event listener to your plugin
|
|
|
|
virtual void AddListener(ISmmPlugin *plugin, IMetamodListener *pListener) =0;
|
2005-10-20 14:52:49 +00:00
|
|
|
/**
|
|
|
|
* @brief Queries the metamod factory
|
|
|
|
*
|
|
|
|
* @param iface String containing interface name
|
|
|
|
* @param ret Optional pointer to store return status
|
|
|
|
* @param id Optional pointer to store id of plugin that overrode interface, 0 if none
|
|
|
|
* @return Returned pointer
|
|
|
|
*/
|
|
|
|
virtual void *MetaFactory(const char *iface, int *ret, PluginId *id) =0;
|
2005-12-06 07:59:18 +00:00
|
|
|
public: //Added in 1.1.2 (1:1)
|
|
|
|
/**
|
|
|
|
* @brief Given a base interface name, such as ServerGameDLL or ServerGameDLL003,
|
|
|
|
* reformats the string to increase the number, then returns the new number.
|
|
|
|
*/
|
|
|
|
virtual int FormatIface(char iface[], unsigned int maxlength) =0;
|
2005-12-23 23:38:38 +00:00
|
|
|
public: //Added in 1.2 (1:2)
|
|
|
|
/**
|
|
|
|
* @brief Searches for an interface for you.
|
|
|
|
*/
|
|
|
|
virtual void *InterfaceSearch(CreateInterfaceFn fn, const char *iface, int max, int *ret) =0;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Returns the base directory of the game/server, equivalent to IVEngineServer::GetGameDir
|
|
|
|
*/
|
|
|
|
virtual const char *GetBaseDir() =0;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Formats a file path to the local OS. Does not include any base directories.
|
|
|
|
*/
|
|
|
|
virtual void PathFormat(char *buffer, size_t len, const char *fmt, ...) =0;
|
2006-04-21 06:35:47 +00:00
|
|
|
public: // Added in 1.2.2 (1:3)
|
|
|
|
/**
|
|
|
|
* @brief Prints text in the specified client's console. Same as IVEngineServer::ClientPrintf
|
|
|
|
* except that it allows for string formatting.
|
|
|
|
*/
|
|
|
|
virtual void ClientConPrintf(edict_t *client, const char *fmt, ...) =0;
|
2005-04-16 19:59:26 +00:00
|
|
|
};
|
|
|
|
|
2005-10-20 14:37:47 +00:00
|
|
|
|
2005-10-06 21:59:10 +00:00
|
|
|
/** Version history
|
2005-12-06 07:59:18 +00:00
|
|
|
* 1.1.0 bumped API to 1:0. The breaking changes occured in sourcehook and the plugin API.
|
|
|
|
* 1.1.2 added API call for generating iface names.
|
2005-12-24 00:22:08 +00:00
|
|
|
* 1.2 added API more helper functions and new SourceHook version.
|
2006-04-21 06:35:47 +00:00
|
|
|
* 1.2.2 added API for printing to client console (with string formatting)
|
2005-10-06 21:59:10 +00:00
|
|
|
*/
|
|
|
|
|
2005-04-16 19:59:26 +00:00
|
|
|
#endif //_INCLUDE_ISMM_API_H
|