mirror of
https://github.com/alliedmodders/metamod-source.git
synced 2025-01-25 14:52:19 +01:00
90 lines
3.1 KiB
C
90 lines
3.1 KiB
C
|
/**
|
||
|
* 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$
|
||
|
*/
|
||
|
|
||
|
#ifndef _INCLUDE_METAMOD_SOURCE_PLUGIN_EXT_H_
|
||
|
#define _INCLUDE_METAMOD_SOUrCE_PLUGIN_EXT_H_
|
||
|
|
||
|
namespace SourceMM
|
||
|
{
|
||
|
class ISmmAPI;
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* @file ISmmPluginExt.h Definitions for extended plugin exposure syntax.
|
||
|
* @brief Provides an alternate method for loading plugins, without needing to
|
||
|
* include the default headers and all their Half-Life baggage.
|
||
|
*/
|
||
|
|
||
|
/**
|
||
|
* @brief Contains version information.
|
||
|
*/
|
||
|
struct MetamodVersionInfo
|
||
|
{
|
||
|
int api_major; /**< ISmmAPI major version */
|
||
|
int api_minor; /**< ISmmAPI minor version */
|
||
|
int sh_iface; /**< SourceHook interface version */
|
||
|
int sh_impl; /**< SourceHook implementation version */
|
||
|
int pl_min; /**< Plugin API minimum version */
|
||
|
int pl_max; /**< Plugin API maximum version */
|
||
|
int source_engine; /**< Source Engine version (SOURCE_* constants) */
|
||
|
};
|
||
|
|
||
|
/**
|
||
|
* @brief Contains information about loading a plugin.
|
||
|
*/
|
||
|
struct MetamodLoaderInfo
|
||
|
{
|
||
|
const char *pl_file; /**< File path to the plugin being loaded. */
|
||
|
const char *pl_path; /**< Folder path containing the plugin. */
|
||
|
};
|
||
|
|
||
|
/**
|
||
|
* @brief If a function of this type is exposed as "CreateInterface_MMS", then
|
||
|
* Metamod:Source will attempt to call this function before calling
|
||
|
* CreateInterface. If this function returns a valid ISmmPlugin pointer, then
|
||
|
* CreateInterface will not be called.
|
||
|
*
|
||
|
* This is useful for implementing a mini-loader plugin for multiple versions.
|
||
|
*
|
||
|
* @param mvi MetamodVersionInfo structure.
|
||
|
* @param mli MetamodLoaderInfo structure.
|
||
|
* @return ISmmAPI pointer, or NULL if none.
|
||
|
*/
|
||
|
typedef SourceMM::ISmmAPI *(*METAMOD_FN_LOAD)(const MetamodVersionInfo *mvi,
|
||
|
const MetamodLoaderInfo *mli);
|
||
|
|
||
|
/**
|
||
|
* @brief If a function of this type is exposed as "UnloadInterface_MMS", then
|
||
|
* Metamod:Source will attempt to call this function after calling
|
||
|
* ISmmAPI::Unload(), and before closing the library. This lets loader plugins
|
||
|
* clean up before exiting.
|
||
|
*/
|
||
|
typedef void (*METAMOD_FN_UNLOAD)();
|
||
|
|
||
|
#endif //INCLUDE_METAMOD_SOURCE_PLUGIN_EXT_H_
|
||
|
|