2007-01-26 02:55:06 +01:00
|
|
|
/**
|
|
|
|
* ===============================================================
|
|
|
|
* SourceMod (C)2004-2007 AlliedModders LLC. All rights reserved.
|
|
|
|
* ===============================================================
|
|
|
|
*
|
|
|
|
* This file is part of the SourceMod/SourcePawn SDK. This file may only be used
|
|
|
|
* or modified under the Terms and Conditions of its License Agreement, which is found
|
|
|
|
* in LICENSE.txt. The Terms and Conditions for making SourceMod extensions/plugins
|
|
|
|
* may change at any time. To view the latest information, see:
|
|
|
|
* http://www.sourcemod.net/license.php
|
|
|
|
*
|
|
|
|
* Version: $Id$
|
|
|
|
*/
|
|
|
|
|
2007-01-16 20:42:05 +01:00
|
|
|
#ifndef _INCLUDE_SOURCEMOD_EXTENSION_BASESDK_H_
|
|
|
|
#define _INCLUDE_SOURCEMOD_EXTENSION_BASESDK_H_
|
|
|
|
|
2007-01-26 02:55:06 +01:00
|
|
|
/**
|
|
|
|
* @file smsdk_ext.h
|
|
|
|
* @brief Contains wrappers for making Extensions easier to write.
|
|
|
|
*/
|
|
|
|
|
2007-01-16 20:42:05 +01:00
|
|
|
#include "smsdk_config.h"
|
|
|
|
#include <IExtensionSys.h>
|
|
|
|
#include <IHandleSys.h>
|
|
|
|
#include <sp_vm_api.h>
|
|
|
|
#include <sm_platform.h>
|
2007-01-19 03:17:24 +01:00
|
|
|
#include <ISourceMod.h>
|
2007-01-19 11:02:43 +01:00
|
|
|
#include <IForwardSys.h>
|
2007-01-16 20:42:05 +01:00
|
|
|
|
|
|
|
#if defined SMEXT_CONF_METAMOD
|
|
|
|
#include <ISmmPlugin.h>
|
|
|
|
#include <eiface.h>
|
|
|
|
#endif
|
|
|
|
|
|
|
|
using namespace SourceMod;
|
2007-01-19 00:28:14 +01:00
|
|
|
using namespace SourcePawn;
|
2007-01-16 20:42:05 +01:00
|
|
|
|
|
|
|
class SDKExtension :
|
|
|
|
#if defined SMEXT_CONF_METAMOD
|
|
|
|
public ISmmPlugin,
|
|
|
|
#endif
|
|
|
|
public IExtensionInterface
|
|
|
|
{
|
|
|
|
public:
|
2007-01-26 02:55:06 +01:00
|
|
|
/** Constructor */
|
2007-01-16 20:42:05 +01:00
|
|
|
SDKExtension();
|
|
|
|
public:
|
|
|
|
/**
|
|
|
|
* @brief This is called after the initial loading sequence has been processed.
|
|
|
|
*
|
|
|
|
* @param error Error message buffer.
|
|
|
|
* @param err_max Size of error message buffer.
|
|
|
|
* @param late Whether or not the module was loaded after map load.
|
|
|
|
* @return True to succeed loading, false to fail.
|
|
|
|
*/
|
|
|
|
virtual bool SDK_OnLoad(char *error, size_t err_max, bool late);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief This is called right before the extension is unloaded.
|
|
|
|
*/
|
|
|
|
virtual void SDK_OnUnload();
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief This is called once all known extensions have been loaded.
|
|
|
|
*/
|
|
|
|
virtual void SDK_OnAllLoaded();
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Called when the pause state is changed.
|
|
|
|
*/
|
|
|
|
virtual void SDK_OnPauseChange(bool paused);
|
|
|
|
|
|
|
|
#if defined SMEXT_CONF_METAMOD
|
|
|
|
/**
|
|
|
|
* @brief Called when Metamod is attached, before the extension version is called.
|
|
|
|
*
|
|
|
|
* @param error Error buffer.
|
|
|
|
* @param err_max Maximum size of error buffer.
|
|
|
|
* @param late Whether or not Metamod considers this a late load.
|
|
|
|
* @return True to succeed, false to fail.
|
|
|
|
*/
|
|
|
|
virtual bool SDK_OnMetamodLoad(char *error, size_t err_max, bool late);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Called when Metamod is detaching, after the extension version is called.
|
|
|
|
* NOTE: By default this is blocked unless sent from SourceMod.
|
|
|
|
*
|
|
|
|
* @param error Error buffer.
|
|
|
|
* @param err_max Maximum size of error buffer.
|
|
|
|
* @return True to succeed, false to fail.
|
|
|
|
*/
|
|
|
|
virtual bool SDK_OnMetamodUnload(char *error, size_t err_max);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Called when Metamod's pause state is changing.
|
|
|
|
* NOTE: By default this is blocked unless sent from SourceMod.
|
|
|
|
*
|
|
|
|
* @param paused Pause state being set.
|
|
|
|
* @param error Error buffer.
|
|
|
|
* @param err_max Maximum size of error buffer.
|
|
|
|
* @return True to succeed, false to fail.
|
|
|
|
*/
|
|
|
|
virtual bool SDK_OnMetamodPauseChange(bool paused, char *error, size_t err_max);
|
|
|
|
#endif
|
|
|
|
|
|
|
|
public: //IExtensionInterface
|
|
|
|
virtual bool OnExtensionLoad(IExtension *me, IShareSys *sys, char *error, size_t err_max, bool late);
|
|
|
|
virtual void OnExtensionUnload();
|
|
|
|
virtual void OnExtensionsAllLoaded();
|
2007-01-26 02:55:06 +01:00
|
|
|
|
|
|
|
/** Returns whether or not this is a Metamod-based extension */
|
2007-01-16 20:42:05 +01:00
|
|
|
virtual bool IsMetamodExtension();
|
2007-01-26 02:55:06 +01:00
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Called when the pause state changes.
|
|
|
|
*
|
|
|
|
* @param state True if being paused, false if being unpaused.
|
|
|
|
*/
|
2007-01-16 20:42:05 +01:00
|
|
|
virtual void OnExtensionPauseChange(bool state);
|
2007-01-26 02:55:06 +01:00
|
|
|
|
|
|
|
/** Returns name */
|
2007-01-16 20:42:05 +01:00
|
|
|
virtual const char *GetExtensionName();
|
2007-01-26 02:55:06 +01:00
|
|
|
/** Returns URL */
|
2007-01-16 20:42:05 +01:00
|
|
|
virtual const char *GetExtensionURL();
|
2007-01-26 02:55:06 +01:00
|
|
|
/** Returns log tag */
|
2007-01-16 20:42:05 +01:00
|
|
|
virtual const char *GetExtensionTag();
|
2007-01-26 02:55:06 +01:00
|
|
|
/** Returns author */
|
2007-01-16 20:42:05 +01:00
|
|
|
virtual const char *GetExtensionAuthor();
|
2007-01-26 02:55:06 +01:00
|
|
|
/** Returns version string */
|
2007-01-16 20:42:05 +01:00
|
|
|
virtual const char *GetExtensionVerString();
|
2007-01-26 02:55:06 +01:00
|
|
|
/** Returns description string */
|
2007-01-16 20:42:05 +01:00
|
|
|
virtual const char *GetExtensionDescription();
|
2007-01-26 02:55:06 +01:00
|
|
|
/** Returns date string */
|
2007-01-16 20:42:05 +01:00
|
|
|
virtual const char *GetExtensionDateString();
|
|
|
|
#if defined SMEXT_CONF_METAMOD
|
|
|
|
public: //ISmmPlugin
|
2007-01-26 02:55:06 +01:00
|
|
|
/** Called when the extension is attached to Metamod. */
|
2007-01-16 20:42:05 +01:00
|
|
|
virtual bool Load(PluginId id, ISmmAPI *ismm, char *error, size_t maxlength, bool late);
|
2007-01-26 02:55:06 +01:00
|
|
|
/** Returns the author to MM */
|
2007-01-16 20:42:05 +01:00
|
|
|
virtual const char *GetAuthor();
|
2007-01-26 02:55:06 +01:00
|
|
|
/** Returns the name to MM */
|
2007-01-16 20:42:05 +01:00
|
|
|
virtual const char *GetName();
|
2007-01-26 02:55:06 +01:00
|
|
|
/** Returns the description to MM */
|
2007-01-16 20:42:05 +01:00
|
|
|
virtual const char *GetDescription();
|
2007-01-26 02:55:06 +01:00
|
|
|
/** Returns the URL to MM */
|
2007-01-16 20:42:05 +01:00
|
|
|
virtual const char *GetURL();
|
2007-01-26 02:55:06 +01:00
|
|
|
/** Returns the license to MM */
|
2007-01-16 20:42:05 +01:00
|
|
|
virtual const char *GetLicense();
|
2007-01-26 02:55:06 +01:00
|
|
|
/** Returns the version string to MM */
|
2007-01-16 20:42:05 +01:00
|
|
|
virtual const char *GetVersion();
|
2007-01-26 02:55:06 +01:00
|
|
|
/** Returns the date string to MM */
|
2007-01-16 20:42:05 +01:00
|
|
|
virtual const char *GetDate();
|
2007-01-26 02:55:06 +01:00
|
|
|
/** Returns the logtag to MM */
|
2007-01-16 20:42:05 +01:00
|
|
|
virtual const char *GetLogTag();
|
2007-01-26 02:55:06 +01:00
|
|
|
/** Called on unload */
|
2007-01-16 20:42:05 +01:00
|
|
|
virtual bool Unload(char *error, size_t maxlen);
|
2007-01-26 02:55:06 +01:00
|
|
|
/** Called on pause */
|
2007-01-16 20:42:05 +01:00
|
|
|
virtual bool Pause(char *error, size_t maxlen);
|
2007-01-26 02:55:06 +01:00
|
|
|
/** Called on unpause */
|
2007-01-16 20:42:05 +01:00
|
|
|
virtual bool Unpause(char *error, size_t maxlen);
|
|
|
|
private:
|
|
|
|
bool m_SourceMMLoaded;
|
|
|
|
bool m_WeAreUnloaded;
|
|
|
|
bool m_WeGotPauseChange;
|
|
|
|
#endif
|
|
|
|
};
|
|
|
|
|
|
|
|
extern SDKExtension *g_pExtensionIface;
|
|
|
|
|
|
|
|
extern IShareSys *g_pShareSys;
|
2007-01-17 04:01:38 +01:00
|
|
|
extern IExtension *myself;
|
2007-01-16 20:42:05 +01:00
|
|
|
extern IHandleSys *g_pHandleSys;
|
2007-01-19 03:17:24 +01:00
|
|
|
extern ISourceMod *g_pSM;
|
2007-01-19 11:02:43 +01:00
|
|
|
extern IForwardManager *g_pForwards;
|
2007-01-16 20:42:05 +01:00
|
|
|
|
|
|
|
#if defined SMEXT_CONF_METAMOD
|
|
|
|
PLUGIN_GLOBALVARS();
|
|
|
|
extern IVEngineServer *engine;
|
|
|
|
extern IServerGameDLL *gamedll;
|
|
|
|
#endif
|
|
|
|
|
2007-01-26 02:55:06 +01:00
|
|
|
/** Creates a SourceMod interface macro pair */
|
2007-01-16 20:42:05 +01:00
|
|
|
#define SM_MKIFACE(name) SMINTERFACE_##name##_NAME, SMINTERFACE_##name##_VERSION
|
2007-01-26 02:55:06 +01:00
|
|
|
/** Automates retrieving SourceMod interfaces */
|
2007-01-16 20:42:05 +01:00
|
|
|
#define SM_GET_IFACE(prefix,addr) \
|
|
|
|
if (!g_pShareSys->RequestInterface(SM_MKIFACE(prefix), myself, (SMInterface **)&addr)) { \
|
|
|
|
if (error) { \
|
|
|
|
snprintf(error, err_max, "Could not find interface: %s", SMINTERFACE_##prefix##_NAME); \
|
|
|
|
} \
|
|
|
|
return false; \
|
|
|
|
}
|
|
|
|
|
|
|
|
#endif //_INCLUDE_SOURCEMOD_EXTENSION_BASESDK_H_
|