2007-01-26 02:55:06 +01:00
|
|
|
/**
|
2007-01-26 03:27:34 +01:00
|
|
|
* vim: set ts=4 :
|
2007-01-26 02:55:06 +01:00
|
|
|
* ===============================================================
|
2007-01-26 03:50:48 +01:00
|
|
|
* SourceMod, Copyright (C) 2004-2007 AlliedModders LLC.
|
|
|
|
* All rights reserved.
|
2007-01-26 02:55:06 +01:00
|
|
|
* ===============================================================
|
|
|
|
*
|
2007-01-26 05:35:08 +01:00
|
|
|
* 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 public/licenses/LICENSE.txt. As of this notice, derivative
|
|
|
|
* works must be licensed under the GNU General Public License (version 2 or
|
|
|
|
* greater). A copy of the GPL is included under public/licenses/GPL.txt.
|
|
|
|
*
|
|
|
|
* To view the latest information, see: http://www.sourcemod.net/license.php
|
2007-01-26 02:55:06 +01:00
|
|
|
*
|
|
|
|
* Version: $Id$
|
|
|
|
*/
|
|
|
|
|
2006-11-05 01:29:44 +01:00
|
|
|
#ifndef _INCLUDE_SOURCEMOD_PLUGINMNGR_INTERFACE_H_
|
|
|
|
#define _INCLUDE_SOURCEMOD_PLUGINMNGR_INTERFACE_H_
|
|
|
|
|
2007-01-26 02:55:06 +01:00
|
|
|
/**
|
|
|
|
* @file IPluginSys.h
|
|
|
|
* @brief Defines the interface for the Plugin System, which manages loaded plugins.
|
|
|
|
*/
|
|
|
|
|
2006-11-05 01:29:44 +01:00
|
|
|
#include <IShareSys.h>
|
2006-11-10 08:49:38 +01:00
|
|
|
#include <sp_vm_api.h>
|
2006-11-05 01:29:44 +01:00
|
|
|
|
2006-12-16 23:30:58 +01:00
|
|
|
#define SMINTERFACE_PLUGINSYSTEM_NAME "IPluginManager"
|
2007-02-13 20:20:48 +01:00
|
|
|
#define SMINTERFACE_PLUGINSYSTEM_VERSION 2
|
2006-11-05 01:29:44 +01:00
|
|
|
|
2007-01-26 02:55:06 +01:00
|
|
|
/** Context user slot 3 is used Core for holding an IPluginContext pointer. */
|
2006-11-11 02:19:46 +01:00
|
|
|
#define SM_CONTEXTVAR_USER 3
|
|
|
|
|
2006-11-05 01:29:44 +01:00
|
|
|
namespace SourceMod
|
|
|
|
{
|
2006-11-11 12:10:24 +01:00
|
|
|
class IPlugin;
|
|
|
|
|
2006-11-08 07:30:20 +01:00
|
|
|
/**
|
2007-01-26 02:55:06 +01:00
|
|
|
* @brief Encapsulates plugin public information exposed through "myinfo."
|
2006-11-08 07:30:20 +01:00
|
|
|
*/
|
|
|
|
typedef struct sm_plugininfo_s
|
|
|
|
{
|
2007-01-26 02:55:06 +01:00
|
|
|
const char *name; /**< Plugin name */
|
|
|
|
const char *author; /**< Plugin author */
|
|
|
|
const char *description; /**< Plugin description */
|
|
|
|
const char *version; /**< Plugin version string */
|
|
|
|
const char *url; /**< Plugin URL */
|
2006-11-08 07:30:20 +01:00
|
|
|
} sm_plugininfo_t;
|
|
|
|
|
2006-12-15 14:38:04 +01:00
|
|
|
|
2006-11-08 07:30:20 +01:00
|
|
|
/**
|
|
|
|
* @brief Describes the usability status of a plugin.
|
|
|
|
*/
|
|
|
|
enum PluginStatus
|
|
|
|
{
|
2007-01-26 02:55:06 +01:00
|
|
|
Plugin_Running=0, /**< Plugin is running */
|
2006-12-15 14:38:04 +01:00
|
|
|
/* All states below are unexecutable */
|
2007-01-26 02:55:06 +01:00
|
|
|
Plugin_Paused, /**< Plugin is loaded but paused */
|
|
|
|
Plugin_Error, /**< Plugin is loaded but errored/locked */
|
2006-12-15 14:38:04 +01:00
|
|
|
/* All states below do not have all natives */
|
2007-01-26 02:55:06 +01:00
|
|
|
Plugin_Loaded, /**< Plugin has passed loading and can be finalized */
|
|
|
|
Plugin_Failed, /**< Plugin has a fatal failure */
|
|
|
|
Plugin_Created, /**< Plugin is created but not initialized */
|
|
|
|
Plugin_Uncompiled, /**< Plugin is not yet compiled by the JIT */
|
|
|
|
Plugin_BadLoad, /**< Plugin failed to load */
|
2006-11-08 07:30:20 +01:00
|
|
|
};
|
|
|
|
|
2006-11-11 02:19:46 +01:00
|
|
|
|
2006-11-08 07:30:20 +01:00
|
|
|
/**
|
|
|
|
* @brief Describes the object lifetime of a plugin.
|
|
|
|
*/
|
2006-11-11 02:19:46 +01:00
|
|
|
enum PluginType
|
2006-11-08 07:30:20 +01:00
|
|
|
{
|
2007-01-26 02:55:06 +01:00
|
|
|
PluginType_Private, /**< Plugin is privately managed and receives no forwards */
|
|
|
|
PluginType_MapUpdated, /**< Plugin will never be unloaded unless for updates on mapchange */
|
|
|
|
PluginType_MapOnly, /**< Plugin will be removed at mapchange */
|
|
|
|
PluginType_Global, /**< Plugin will never be unloaded or updated */
|
2006-11-08 07:30:20 +01:00
|
|
|
};
|
|
|
|
|
2006-11-11 02:19:46 +01:00
|
|
|
/**
|
|
|
|
* @brief Encapsulates a run-time plugin as maintained by SourceMod.
|
|
|
|
*/
|
|
|
|
class IPlugin
|
|
|
|
{
|
2006-11-08 07:30:20 +01:00
|
|
|
public:
|
2007-01-26 02:55:06 +01:00
|
|
|
/** Virtual destructor */
|
2006-11-11 02:19:46 +01:00
|
|
|
virtual ~IPlugin()
|
|
|
|
{
|
|
|
|
}
|
|
|
|
|
2006-11-08 07:30:20 +01:00
|
|
|
/**
|
|
|
|
* @brief Returns the lifetime of a plugin.
|
|
|
|
*/
|
2006-11-11 02:19:46 +01:00
|
|
|
virtual PluginType GetType() const =0;
|
2006-11-08 07:30:20 +01:00
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Returns the current API context being used in the plugin.
|
|
|
|
*
|
|
|
|
* @return Pointer to an IPluginContext, or NULL if not loaded.
|
|
|
|
*/
|
2006-11-10 08:49:38 +01:00
|
|
|
virtual SourcePawn::IPluginContext *GetBaseContext() const =0;
|
2006-11-08 07:30:20 +01:00
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Returns the context structure being used in the plugin.
|
|
|
|
*
|
2006-11-10 08:49:38 +01:00
|
|
|
* @return Pointer to an sp_context_t, or NULL if not loaded.
|
2006-11-08 07:30:20 +01:00
|
|
|
*/
|
2006-11-10 08:49:38 +01:00
|
|
|
virtual sp_context_t *GetContext() const =0;
|
2006-11-08 07:30:20 +01:00
|
|
|
|
|
|
|
/**
|
2006-11-10 08:49:38 +01:00
|
|
|
* @brief Returns the plugin file structure.
|
2006-11-08 07:30:20 +01:00
|
|
|
*
|
2006-11-10 08:49:38 +01:00
|
|
|
* @return Pointer to an sp_plugin_t, or NULL if not loaded.
|
2006-11-08 07:30:20 +01:00
|
|
|
*/
|
2006-11-10 08:49:38 +01:00
|
|
|
virtual const sp_plugin_t *GetPluginStructure() const =0;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Returns information about the plugin by reference.
|
|
|
|
*
|
|
|
|
* @return Pointer to a sm_plugininfo_t object, NULL if plugin is not loaded.
|
|
|
|
*/
|
|
|
|
virtual const sm_plugininfo_t *GetPublicInfo() const =0;
|
2006-11-08 07:30:20 +01:00
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Returns the plugin filename (relative to plugins dir).
|
|
|
|
*/
|
2006-11-10 08:49:38 +01:00
|
|
|
virtual const char *GetFilename() const =0;
|
2006-11-08 07:30:20 +01:00
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Returns true if a plugin is in debug mode, false otherwise.
|
|
|
|
*/
|
2006-11-10 08:49:38 +01:00
|
|
|
virtual bool IsDebugging() const =0;
|
2006-11-08 07:30:20 +01:00
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Returns the plugin status.
|
|
|
|
*/
|
2006-11-10 08:49:38 +01:00
|
|
|
virtual PluginStatus GetStatus() const =0;
|
2006-11-08 07:30:20 +01:00
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Sets whether the plugin is paused or not.
|
|
|
|
*
|
2006-11-10 08:49:38 +01:00
|
|
|
* @return True on successful state change, false otherwise.
|
2006-11-08 07:30:20 +01:00
|
|
|
*/
|
|
|
|
virtual bool SetPauseState(bool paused) =0;
|
|
|
|
|
|
|
|
/**
|
2006-11-11 02:19:46 +01:00
|
|
|
* @brief Returns the unique serial number of a plugin.
|
2006-11-08 07:30:20 +01:00
|
|
|
*/
|
2006-11-11 02:19:46 +01:00
|
|
|
virtual unsigned int GetSerial() const =0;
|
2006-11-08 07:30:20 +01:00
|
|
|
|
2006-12-16 23:30:58 +01:00
|
|
|
/**
|
|
|
|
* @brief Returns a plugin's identity token.
|
|
|
|
*/
|
2007-01-15 01:56:39 +01:00
|
|
|
virtual IdentityToken_t *GetIdentity() const =0;
|
2007-02-13 20:20:48 +01:00
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Sets a property on this plugin. This is used for per-plugin
|
|
|
|
* data from extensions or other parts of core. The property's value must
|
|
|
|
* be manually destructed when the plugin is destroyed.
|
|
|
|
*
|
|
|
|
* @param prop String containing name of the property.
|
|
|
|
* @param ptr Generic pointer to set.
|
|
|
|
* @return True on success, false if the property is already set.
|
|
|
|
*/
|
|
|
|
virtual bool SetProperty(const char *prop, void *ptr) =0;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Gets a property from a plugin.
|
|
|
|
*
|
|
|
|
* @param prop String containing the property's name.
|
|
|
|
* @param ptr Optional pointer to the generic pointer.
|
|
|
|
* @param remove Optional boolean value; if true, property is removed
|
|
|
|
* (so it can be set again).
|
|
|
|
* @return True if the property existed, false otherwise.
|
|
|
|
*/
|
|
|
|
virtual bool GetProperty(const char *prop, void **ptr, bool remove=false) =0;
|
2006-11-05 01:29:44 +01:00
|
|
|
};
|
|
|
|
|
2006-11-08 07:30:20 +01:00
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Iterates over a list of plugins.
|
|
|
|
*/
|
|
|
|
class IPluginIterator
|
2006-11-05 01:29:44 +01:00
|
|
|
{
|
2006-11-08 07:30:20 +01:00
|
|
|
public:
|
2007-01-26 02:55:06 +01:00
|
|
|
/** Virtual destructor */
|
2006-11-10 08:49:38 +01:00
|
|
|
virtual ~IPluginIterator()
|
2006-11-08 07:30:20 +01:00
|
|
|
{
|
|
|
|
};
|
|
|
|
public:
|
|
|
|
/**
|
|
|
|
* @brief Returns true if there are more plugins in the iterator.
|
|
|
|
*/
|
|
|
|
virtual bool MorePlugins() =0;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Returns the plugin at the current iterator position.
|
|
|
|
*/
|
|
|
|
virtual IPlugin *GetPlugin() =0;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Advances to the next plugin in the iterator.
|
|
|
|
*/
|
|
|
|
virtual void NextPlugin() =0;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Destroys the iterator object.
|
|
|
|
* Note: You may use 'delete' in lieu of this function.
|
|
|
|
*/
|
|
|
|
virtual void Release() =0;
|
2006-11-05 01:29:44 +01:00
|
|
|
};
|
|
|
|
|
2006-11-11 02:19:46 +01:00
|
|
|
/**
|
|
|
|
* @brief Listens for plugin-oriented events.
|
|
|
|
*/
|
|
|
|
class IPluginsListener
|
|
|
|
{
|
|
|
|
public:
|
|
|
|
/**
|
|
|
|
* @brief Called when a plugin is created/mapped into memory.
|
|
|
|
*/
|
|
|
|
virtual void OnPluginCreated(IPlugin *plugin)
|
|
|
|
{
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Called when a plugin is fully loaded successfully.
|
|
|
|
*/
|
|
|
|
virtual void OnPluginLoaded(IPlugin *plugin)
|
|
|
|
{
|
|
|
|
}
|
|
|
|
|
2007-02-04 23:41:44 +01:00
|
|
|
/**
|
|
|
|
* @brief Called when a plugin is paused or unpaused.
|
|
|
|
*/
|
|
|
|
virtual void OnPluginPauseChange(IPlugin *plugin, bool paused)
|
|
|
|
{
|
|
|
|
}
|
|
|
|
|
2006-11-11 02:19:46 +01:00
|
|
|
/**
|
|
|
|
* @brief Called when a plugin is unloaded (only if fully loaded).
|
|
|
|
*/
|
|
|
|
virtual void OnPluginUnloaded(IPlugin *plugin)
|
|
|
|
{
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Called when a plugin is destroyed.
|
|
|
|
* NOTE: Always called if Created, even if load failed.
|
|
|
|
*/
|
|
|
|
virtual void OnPluginDestroyed(IPlugin *plugin)
|
|
|
|
{
|
|
|
|
}
|
|
|
|
};
|
|
|
|
|
2006-11-08 07:30:20 +01:00
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Manages the runtime loading and unloading of plugins.
|
|
|
|
*/
|
2006-11-05 01:29:44 +01:00
|
|
|
class IPluginManager : public SMInterface
|
|
|
|
{
|
|
|
|
public:
|
|
|
|
virtual const char *GetInterfaceName()
|
|
|
|
{
|
2006-12-16 23:30:58 +01:00
|
|
|
return SMINTERFACE_PLUGINSYSTEM_NAME;
|
2006-11-05 01:29:44 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
virtual unsigned int GetInterfaceVersion()
|
|
|
|
{
|
2006-12-16 23:30:58 +01:00
|
|
|
return SMINTERFACE_PLUGINSYSTEM_VERSION;
|
2006-11-05 01:29:44 +01:00
|
|
|
}
|
|
|
|
public:
|
|
|
|
/**
|
|
|
|
* @brief Attempts to load a plugin.
|
|
|
|
*
|
|
|
|
* @param path Path and filename of plugin, relative to plugins folder.
|
|
|
|
* @param debug Whether or not to default the plugin into debug mode.
|
2006-11-13 14:55:44 +01:00
|
|
|
* @param type Lifetime of the plugin.
|
2006-11-05 01:29:44 +01:00
|
|
|
* @param error Buffer to hold any error message.
|
|
|
|
* @param err_max Maximum length of error message buffer.
|
2007-01-27 01:03:34 +01:00
|
|
|
* @param wasloaded Stores if the plugin is already loaded.
|
2006-11-05 01:29:44 +01:00
|
|
|
* @return A new plugin pointer on success, false otherwise.
|
|
|
|
*/
|
|
|
|
virtual IPlugin *LoadPlugin(const char *path,
|
|
|
|
bool debug,
|
2006-11-11 02:19:46 +01:00
|
|
|
PluginType type,
|
2006-11-05 01:29:44 +01:00
|
|
|
char error[],
|
2007-01-27 01:03:34 +01:00
|
|
|
size_t err_max,
|
|
|
|
bool *wasloaded) =0;
|
2006-11-08 07:30:20 +01:00
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Attempts to unload a plugin.
|
|
|
|
*
|
2006-11-13 14:55:44 +01:00
|
|
|
* @param plugin Pointer to the plugin handle.
|
2006-11-08 07:30:20 +01:00
|
|
|
* @return True on success, false otherwise.
|
|
|
|
*/
|
|
|
|
virtual bool UnloadPlugin(IPlugin *plugin) =0;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Finds a plugin by its context.
|
|
|
|
* Note: This function should be considered O(1).
|
|
|
|
*
|
2006-11-13 14:55:44 +01:00
|
|
|
* @param ctx Pointer to an sp_context_t.
|
2006-11-08 07:30:20 +01:00
|
|
|
* @return Pointer to a matching IPlugin, or NULL if none found.
|
|
|
|
*/
|
|
|
|
virtual IPlugin *FindPluginByContext(const sp_context_t *ctx) =0;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Returns the number of plugins (both failed and loaded).
|
|
|
|
*
|
|
|
|
* @return The number of internally cached plugins.
|
|
|
|
*/
|
|
|
|
virtual unsigned int GetPluginCount() =0;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Returns a pointer that can be used to iterate through plugins.
|
|
|
|
* Note: This pointer must be freed using EITHER delete OR IPluginIterator::Release().
|
|
|
|
*/
|
|
|
|
virtual IPluginIterator *GetPluginIterator() =0;
|
2006-11-11 02:19:46 +01:00
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Adds a plugin manager listener.
|
|
|
|
*
|
|
|
|
* @param listener Pointer to a listener.
|
|
|
|
*/
|
|
|
|
virtual void AddPluginsListener(IPluginsListener *listener) =0;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Removes a plugin listener.
|
|
|
|
*
|
|
|
|
* @param listener Pointer to a listener.
|
|
|
|
*/
|
|
|
|
virtual void RemovePluginsListener(IPluginsListener *listener) =0;
|
2006-11-05 01:29:44 +01:00
|
|
|
};
|
2007-02-05 09:58:03 +01:00
|
|
|
}
|
2006-11-05 01:29:44 +01:00
|
|
|
|
|
|
|
#endif //_INCLUDE_SOURCEMOD_PLUGINMNGR_INTERFACE_H_
|