2008-02-18 23:11:25 +00:00
|
|
|
/*
|
2007-10-04 20:15:25 +00:00
|
|
|
* vim: set ts=4 :
|
|
|
|
* ======================================================
|
|
|
|
* Metamod:Source
|
2008-03-26 21:32:31 +00:00
|
|
|
* Copyright (C) 2004-2008 AlliedModders LLC and authors.
|
2007-10-04 20:15:25 +00:00
|
|
|
* 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$
|
|
|
|
*/
|
2005-04-16 23:33:39 +00:00
|
|
|
|
2007-10-08 18:47:31 +00:00
|
|
|
#ifndef _INCLUDE_METAMOD_IPLUGINMANAGER_H
|
|
|
|
#define _INCLUDE_METAMOD_IPLUGINMANAGER_H
|
2005-04-16 19:59:26 +00:00
|
|
|
|
2005-04-16 23:33:39 +00:00
|
|
|
/**
|
|
|
|
* @brief Plugin Manager interface
|
|
|
|
* @file IPluginManager.h
|
|
|
|
*/
|
|
|
|
|
2008-01-10 17:22:14 +00:00
|
|
|
#include <ISmmPluginExt.h>
|
|
|
|
|
2007-10-08 18:47:31 +00:00
|
|
|
namespace SourceMM
|
2005-04-16 19:59:26 +00:00
|
|
|
{
|
|
|
|
/**
|
2007-10-08 18:47:31 +00:00
|
|
|
* @brief Load sources
|
2005-04-16 19:59:26 +00:00
|
|
|
*/
|
2007-10-08 18:47:31 +00:00
|
|
|
enum
|
|
|
|
{
|
|
|
|
Pl_BadLoad=0,
|
|
|
|
Pl_Console=-1,
|
|
|
|
Pl_File=-2,
|
|
|
|
Pl_MinId=1,
|
|
|
|
};
|
|
|
|
|
2005-04-16 19:59:26 +00:00
|
|
|
/**
|
2007-10-08 18:47:31 +00:00
|
|
|
* @brief Status of a plugin at runtime
|
2005-04-16 19:59:26 +00:00
|
|
|
*/
|
2007-10-08 18:47:31 +00:00
|
|
|
enum Pl_Status
|
|
|
|
{
|
|
|
|
Pl_NotFound=-4,
|
|
|
|
Pl_Error=-3,
|
|
|
|
Pl_Refused=-2,
|
|
|
|
Pl_Paused=-1,
|
|
|
|
Pl_Running=0,
|
|
|
|
};
|
|
|
|
|
2008-02-18 23:11:25 +00:00
|
|
|
/**
|
|
|
|
* @brief Programmatic management of the "loaded plugin" list.
|
|
|
|
*/
|
2007-10-08 18:47:31 +00:00
|
|
|
class ISmmPluginManager
|
|
|
|
{
|
|
|
|
public:
|
|
|
|
/**
|
|
|
|
* @brief Loads a plugin and returns its id. If this is called before DLLInit(),
|
|
|
|
* then the plugin is considered to be "hot" - it might refuse its own load later!
|
|
|
|
* Also, a hot plugin might not have an error message.
|
|
|
|
*
|
2008-02-18 23:11:25 +00:00
|
|
|
* @param file String containing file name.
|
|
|
|
* @param source Specifies who loaded the plugin.
|
|
|
|
* @param already Whether or not the plugin was already loaded.
|
|
|
|
* @param error String buffer for error messages.
|
|
|
|
* @param maxlen Maximum length of buffer.
|
|
|
|
* @return Id of plugin.
|
2007-10-08 18:47:31 +00:00
|
|
|
*/
|
|
|
|
virtual PluginId Load(const char *file, PluginId source, bool &already, char *error, size_t maxlen) =0;
|
|
|
|
|
|
|
|
/**
|
2008-02-18 23:11:25 +00:00
|
|
|
* @brief Unloads a plugin.
|
2007-10-08 18:47:31 +00:00
|
|
|
*
|
2008-02-18 23:11:25 +00:00
|
|
|
* @param id Id of plugin
|
|
|
|
* @param force True to forcefully unload, false to let plugin opt-out.
|
|
|
|
* @param error String buffer for error messages
|
|
|
|
* @param maxlen Maximum length of buffer
|
|
|
|
* @return True on success, false otherwise
|
2007-10-08 18:47:31 +00:00
|
|
|
*/
|
|
|
|
virtual bool Unload(PluginId id, bool force, char *error, size_t maxlen) =0;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Pauses a plugin
|
|
|
|
*
|
2008-02-18 23:11:25 +00:00
|
|
|
* @param id Id of plugin
|
|
|
|
* @param error String buffer for error messages
|
|
|
|
* @param maxlen Maximum length of buffer
|
|
|
|
* @return True on success, false otherwise
|
2007-10-08 18:47:31 +00:00
|
|
|
*/
|
|
|
|
virtual bool Pause(PluginId id, char *error, size_t maxlen) =0;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Unpauses a plugin
|
|
|
|
*
|
2008-02-18 23:11:25 +00:00
|
|
|
* @param id Id of plugin
|
|
|
|
* @param error String buffer for error messages
|
|
|
|
* @param maxlen Maximum length of buffer
|
|
|
|
* @return True on success, false otherwise
|
2007-10-08 18:47:31 +00:00
|
|
|
*/
|
|
|
|
virtual bool Unpause(PluginId id, char *error, size_t maxlen) =0;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Unloads all plugins forcefully
|
|
|
|
*
|
2008-02-18 23:11:25 +00:00
|
|
|
* @return True on success, false otherwise
|
2007-10-08 18:47:31 +00:00
|
|
|
*/
|
|
|
|
virtual bool UnloadAll() =0;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Returns information about a plugin
|
|
|
|
*
|
2007-10-08 18:51:51 +00:00
|
|
|
* @param id Id of plugin
|
|
|
|
* @param file Pointer to store filename pointer, or NULL to ignore.
|
|
|
|
* @param status Pointer to store status, or NULL to ignore.
|
|
|
|
* @param source Pointer to store source, or NULL to ignore.
|
|
|
|
* @return True on success, false if not found
|
2007-10-08 18:47:31 +00:00
|
|
|
*/
|
2007-10-08 18:51:51 +00:00
|
|
|
virtual bool Query(PluginId id, const char **file, Pl_Status *status, PluginId *source) =0;
|
2007-10-08 18:47:31 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Checks another plugin's QueryRunning() status.
|
|
|
|
*
|
|
|
|
* @param id Id of plugin
|
|
|
|
* @param error Message buffer
|
2008-02-18 23:11:25 +00:00
|
|
|
* @param maxlength Size of error buffer
|
2007-10-08 18:47:31 +00:00
|
|
|
* @return Status value
|
|
|
|
*/
|
|
|
|
virtual bool QueryRunning(PluginId id, char *error, size_t maxlength) =0;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Returns the handle of a plugin (OS dependent meaning)
|
|
|
|
*
|
|
|
|
* @param id Id of plugin
|
2007-10-08 18:51:51 +00:00
|
|
|
* @param handle Pointer to store handle pointer, or NULL to ignore.
|
2007-10-08 18:47:31 +00:00
|
|
|
* @return True if plugin id is valid, false otherwise
|
|
|
|
*/
|
2007-10-08 18:51:51 +00:00
|
|
|
virtual bool QueryHandle(PluginId id, void **handle) =0;
|
2007-10-08 18:47:31 +00:00
|
|
|
};
|
|
|
|
}
|
|
|
|
|
|
|
|
#if !defined METAMOD_NO_AUTO_NAMESPACE
|
|
|
|
using namespace SourceMM;
|
|
|
|
#endif
|
2005-04-16 19:59:26 +00:00
|
|
|
|
|
|
|
#endif //_INCLUDE_PLUGINMANAGER_H
|
2007-10-08 18:47:31 +00:00
|
|
|
|