2007-09-29 18:16:24 +02:00
|
|
|
/**
|
|
|
|
* vim: set ts=4 :
|
|
|
|
* ======================================================
|
|
|
|
* Metamod:Source
|
|
|
|
* Copyright (C) 2004-2007 AlliedModders LLC and authors.
|
|
|
|
* All rights reserved.
|
|
|
|
* ======================================================
|
|
|
|
*
|
|
|
|
* This software is provided 'as-is', without any express or implied warranty.
|
|
|
|
* In no event will the authors be held liable for any damages arising from
|
|
|
|
* the use of this software.
|
|
|
|
*
|
|
|
|
* Permission is granted to anyone to use this software for any purpose,
|
|
|
|
* including commercial applications, and to alter it and redistribute it
|
|
|
|
* freely, subject to the following restrictions:
|
|
|
|
*
|
|
|
|
* 1. The origin of this software must not be misrepresented; you must not
|
|
|
|
* claim that you wrote the original software. If you use this software in a
|
|
|
|
* product, an acknowledgment in the product documentation would be
|
|
|
|
* appreciated but is not required.
|
|
|
|
* 2. Altered source versions must be plainly marked as such, and must not be
|
|
|
|
* misrepresented as being the original software.
|
|
|
|
* 3. This notice may not be removed or altered from any source distribution.
|
|
|
|
*
|
|
|
|
* Version: $Id$
|
|
|
|
*/
|
2007-09-18 22:03:47 +02:00
|
|
|
|
|
|
|
#ifndef _INCLUDE_CPLUGIN_H
|
|
|
|
#define _INCLUDE_CPLUGIN_H
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Implementation of Plugin API and Management routines
|
|
|
|
* @file CPlugin.cpp
|
|
|
|
*/
|
|
|
|
|
|
|
|
#include <interface.h>
|
|
|
|
#include <eiface.h>
|
2007-09-22 20:08:30 +02:00
|
|
|
#include <sh_list.h>
|
|
|
|
#include <sh_string.h>
|
2007-09-18 22:03:47 +02:00
|
|
|
#include "IPluginManager.h"
|
2007-09-28 23:31:02 +02:00
|
|
|
#include "metamod_oslink.h"
|
2007-09-18 22:03:47 +02:00
|
|
|
|
|
|
|
/**
|
|
|
|
* History of plugin versions: (M=min, C=current)
|
|
|
|
* 1: Initial interface
|
|
|
|
* 2: Added GetLogTag()
|
|
|
|
* 3: Moved GetApiVersion() to top (2005-04-16)
|
|
|
|
* 4: Added AllPluginsLoaded() callback (2005-04-18)
|
|
|
|
* 5: Bumped version for SourceHook V4 (2005-05-01)
|
|
|
|
* 6: Added functions for console printing (2005-05-26)
|
|
|
|
* M 7: Changed template libraries (2005-08-11)
|
|
|
|
* New loading structure mechanism
|
|
|
|
* New SourceHook version
|
|
|
|
* 8: New SourceHook version (2005-12-23)
|
|
|
|
* New ISmmAPI additions
|
|
|
|
* 9: New ISmmPluginManager additions
|
|
|
|
* C 10: Added VSP listen functions to ISmmAPI and IMetamodListener (2007-02-09)
|
2007-09-18 22:35:29 +02:00
|
|
|
* C 11: New SourceHook version V5 (May, 2007)
|
2007-09-18 22:03:47 +02:00
|
|
|
*/
|
|
|
|
|
|
|
|
#define PLAPI_MIN_VERSION 7
|
|
|
|
|
|
|
|
namespace SourceMM
|
|
|
|
{
|
|
|
|
struct CNameAlias
|
|
|
|
{
|
|
|
|
SourceHook::String alias;
|
|
|
|
SourceHook::String value;
|
|
|
|
};
|
|
|
|
/**
|
|
|
|
* @brief Implements Plugin Manager API
|
|
|
|
*/
|
|
|
|
class CPluginManager : public ISmmPluginManager
|
|
|
|
{
|
|
|
|
public:
|
|
|
|
/**
|
|
|
|
* @brief Internal structure for holding plugin data
|
|
|
|
*/
|
|
|
|
class CPlugin
|
|
|
|
{
|
|
|
|
public:
|
|
|
|
CPlugin();
|
|
|
|
public:
|
|
|
|
PluginId m_Id;
|
|
|
|
SourceHook::String m_File;
|
|
|
|
Pl_Status m_Status;
|
|
|
|
PluginId m_Source;
|
|
|
|
ISmmPlugin *m_API;
|
|
|
|
HINSTANCE m_Lib;
|
|
|
|
SourceHook::List<ConCommandBase *> m_Cvars;
|
|
|
|
SourceHook::List<ConCommandBase *> m_Cmds;
|
|
|
|
SourceHook::List<IMetamodListener *> m_Events;
|
|
|
|
};
|
|
|
|
public:
|
|
|
|
CPluginManager();
|
|
|
|
~CPluginManager();
|
|
|
|
void SetAllLoaded();
|
|
|
|
public:
|
|
|
|
PluginId Load(const char *file, PluginId source, bool &already, char *error, size_t maxlen);
|
|
|
|
bool Unload(PluginId id, bool force, char *error, size_t maxlen);
|
|
|
|
bool Pause(PluginId id, char *error, size_t maxlen);
|
|
|
|
bool Unpause(PluginId id, char *error, size_t maxlen);
|
|
|
|
bool UnloadAll();
|
|
|
|
void SetAlias(const char *alias, const char *value);
|
|
|
|
public:
|
|
|
|
bool Query(PluginId id, const char *&file, Pl_Status &status, PluginId &source);
|
|
|
|
bool QueryRunning(PluginId id, char *error, size_t maxlength);
|
|
|
|
bool QueryHandle(PluginId id, void *&handle);
|
|
|
|
|
|
|
|
void AddPluginCvar(ISmmPlugin *api, ConCommandBase *pCvar);
|
|
|
|
void AddPluginCmd(ISmmPlugin *api, ConCommandBase *pCmd);
|
|
|
|
void RemovePluginCvar(ISmmPlugin *api, ConCommandBase *pCvar);
|
|
|
|
void RemovePluginCmd(ISmmPlugin *api, ConCommandBase *pCmd);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Finds a plugin by Id
|
|
|
|
*
|
|
|
|
* @param id Id of plugin
|
|
|
|
* @return CPlugin on success, NULL otherwise
|
|
|
|
*/
|
|
|
|
CPlugin *FindById(PluginId id);
|
|
|
|
|
|
|
|
CPlugin *FindByAPI(ISmmPlugin *api);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Attempts to reload a failed plugin
|
|
|
|
*
|
|
|
|
* @param id Id of plugin
|
|
|
|
* @param error Error message buffer
|
|
|
|
* @param len Maximum length of buffer
|
|
|
|
* @return True on success, false otherwise
|
|
|
|
*/
|
|
|
|
bool Retry(PluginId id, char *error, size_t len);
|
|
|
|
|
2007-09-18 22:35:29 +02:00
|
|
|
int GetPluginCount();
|
|
|
|
const char *GetStatusText(CPlugin *pl);
|
|
|
|
|
2007-09-18 22:03:47 +02:00
|
|
|
//get alias info
|
|
|
|
const char *LookupAlias(const char *alias);
|
|
|
|
SourceHook::List<SourceMM::CNameAlias *>::iterator _alias_begin();
|
|
|
|
SourceHook::List<SourceMM::CNameAlias *>::iterator _alias_end();
|
|
|
|
|
|
|
|
//Internal iterators
|
|
|
|
SourceHook::List<SourceMM::CPluginManager::CPlugin *>::iterator _begin();
|
|
|
|
SourceHook::List<SourceMM::CPluginManager::CPlugin *>::iterator _end();
|
|
|
|
private:
|
|
|
|
//These are identical internal functions for the wrappers above.
|
|
|
|
CPlugin *_Load(const char *file, PluginId source, char *error, size_t maxlen);
|
|
|
|
bool _Unload(CPlugin *pl, bool force, char *error, size_t maxlen);
|
|
|
|
bool _Pause(CPlugin *pl, char *error, size_t maxlen);
|
|
|
|
bool _Unpause(CPlugin *pl, char *error, size_t maxlen);
|
|
|
|
void UnregAllConCmds(CPlugin *pl);
|
|
|
|
private:
|
|
|
|
PluginId m_LastId;
|
|
|
|
SourceHook::List<CPlugin *> m_Plugins;
|
|
|
|
SourceHook::List<CNameAlias *> m_Aliases;
|
|
|
|
bool m_AllLoaded;
|
|
|
|
};
|
|
|
|
};
|
|
|
|
|
|
|
|
typedef SourceHook::List<SourceMM::CPluginManager::CPlugin *>::iterator PluginIter;
|
|
|
|
|
|
|
|
/** @brief Singleton for plugin manager */
|
|
|
|
extern SourceMM::CPluginManager g_PluginMngr;
|
|
|
|
|
|
|
|
#endif //_INCLUDE_CPLUGIN_H
|
2007-09-29 17:35:59 +02:00
|
|
|
|