2007-01-25 23:36:38 +01:00
|
|
|
/**
|
2007-03-22 22:50:20 +01:00
|
|
|
* vim: set ts=4 :
|
2007-08-15 08:19:30 +02:00
|
|
|
* =============================================================================
|
2007-08-01 04:12:47 +02:00
|
|
|
* SourceMod
|
|
|
|
* Copyright (C) 2004-2007 AlliedModders LLC. All rights reserved.
|
2007-08-15 08:19:30 +02:00
|
|
|
* =============================================================================
|
2007-01-25 23:36:38 +01:00
|
|
|
*
|
2007-08-15 08:19:30 +02:00
|
|
|
* This program is free software; you can redistribute it and/or modify it under
|
|
|
|
* the terms of the GNU General Public License, version 3.0, as published by the
|
|
|
|
* Free Software Foundation.
|
2007-08-01 04:12:47 +02:00
|
|
|
*
|
2007-08-15 08:19:30 +02:00
|
|
|
* This program is distributed in the hope that it will be useful, but WITHOUT
|
|
|
|
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS
|
|
|
|
* FOR A PARTICULAR PURPOSE. See the GNU General Public License for more
|
|
|
|
* details.
|
2007-08-01 04:12:47 +02:00
|
|
|
*
|
2007-08-15 08:19:30 +02:00
|
|
|
* You should have received a copy of the GNU General Public License along with
|
|
|
|
* this program. If not, see <http://www.gnu.org/licenses/>.
|
2007-08-01 04:12:47 +02:00
|
|
|
*
|
2007-08-15 08:19:30 +02:00
|
|
|
* As a special exception, AlliedModders LLC gives you permission to link the
|
|
|
|
* code of this program (as well as its derivative works) to "Half-Life 2," the
|
|
|
|
* "Source Engine," the "SourcePawn JIT," and any Game MODs that run on software
|
|
|
|
* by the Valve Corporation. You must obey the GNU General Public License in
|
|
|
|
* all respects for all other code used. Additionally, AlliedModders LLC grants
|
|
|
|
* this exception to all derivative works. AlliedModders LLC defines further
|
|
|
|
* exceptions, found in LICENSE.txt (as of this writing, version JULY-31-2007),
|
|
|
|
* or <http://www.sourcemod.net/license.php>.
|
2007-01-25 23:36:38 +01:00
|
|
|
*
|
|
|
|
* Version: $Id$
|
|
|
|
*/
|
|
|
|
|
2006-11-10 19:08:13 +01:00
|
|
|
#ifndef _INCLUDE_SOURCEMOD_PLUGINSYSTEM_H_
|
|
|
|
#define _INCLUDE_SOURCEMOD_PLUGINSYSTEM_H_
|
|
|
|
|
2006-12-15 14:38:04 +01:00
|
|
|
#include <time.h>
|
2007-01-20 03:12:53 +01:00
|
|
|
#include <errno.h>
|
|
|
|
#include <sys/stat.h>
|
2006-11-10 19:08:13 +01:00
|
|
|
#include <IPluginSys.h>
|
2006-12-16 23:31:32 +01:00
|
|
|
#include <IHandleSys.h>
|
2007-03-14 08:54:54 +01:00
|
|
|
#include <IForwardSys.h>
|
2006-11-11 02:19:46 +01:00
|
|
|
#include <sh_list.h>
|
|
|
|
#include <sh_stack.h>
|
2007-01-27 04:25:34 +01:00
|
|
|
#include <sh_vector.h>
|
2007-03-12 08:08:05 +01:00
|
|
|
#include <sh_string.h>
|
2006-11-10 19:08:13 +01:00
|
|
|
#include "sm_globals.h"
|
2007-01-04 03:08:27 +01:00
|
|
|
#include "vm/sp_vm_basecontext.h"
|
2006-12-10 10:19:59 +01:00
|
|
|
#include "PluginInfoDatabase.h"
|
2006-12-15 14:38:04 +01:00
|
|
|
#include "sm_trie.h"
|
2006-12-16 23:31:32 +01:00
|
|
|
#include "sourcemod.h"
|
2007-01-17 19:22:00 +01:00
|
|
|
#include <IRootConsoleMenu.h>
|
2007-10-14 02:04:21 +02:00
|
|
|
#if defined ORANGEBOX_BUILD
|
|
|
|
#include "convar_sm_ob.h"
|
|
|
|
#else
|
2007-02-08 22:41:28 +01:00
|
|
|
#include "convar_sm.h"
|
2007-10-14 02:04:21 +02:00
|
|
|
#endif
|
2006-11-10 19:08:13 +01:00
|
|
|
|
2006-11-11 02:19:46 +01:00
|
|
|
using namespace SourceHook;
|
|
|
|
|
2006-12-13 12:16:20 +01:00
|
|
|
/**
|
|
|
|
* NOTES:
|
|
|
|
*
|
2008-03-12 03:12:47 +01:00
|
|
|
* UPDATE 2008-03-11: These comments are horribly out of date. They paint a good overall
|
|
|
|
* picture of how PluginSys works, but things like dependencies and fake natives have
|
|
|
|
* complicated things quite a bit.
|
|
|
|
*
|
2006-12-13 12:16:20 +01:00
|
|
|
* Currently this system needs a lot of work but it's good skeletally. Plugin creation
|
|
|
|
* is done without actually compiling anything. This is done by Load functions in the
|
|
|
|
* manager. This will need a rewrite when we add context switching.
|
|
|
|
*
|
|
|
|
* The plugin object itself has a few things to note. The most important is that it stores
|
|
|
|
* a table of function objects. The manager marshals allocation and freeing of these objects.
|
|
|
|
* The plugin object can be in erroneous states, they are:
|
|
|
|
* Plugin_Error --> Some error occurred any time during or after compilation.
|
|
|
|
* This error can be cleared since the plugin itself is valid.
|
|
|
|
* However, the state itself being set prevents any runtime action.
|
|
|
|
* Plugin_BadLoad --> The plugin failed to load entirely and nothing can be done to save it.
|
|
|
|
*
|
|
|
|
* If a plugin fails to load externally, it is never added to the internal tracker. However,
|
|
|
|
* plugins that failed to load from the internal loading mechanism are always tracked. This
|
|
|
|
* allows users to see which automatically loaded plugins failed, and makes the interface a bit
|
|
|
|
* more flexible.
|
2006-12-15 14:38:04 +01:00
|
|
|
*
|
|
|
|
* Once a plugin is compiled, it sets its own state to Plugin_Created. This state is still invalid
|
|
|
|
* for execution. SourceMod is a two pass system, and even though the second pass is not implemented
|
|
|
|
* yet, it is structured so Plugin_Created must be switched to Plugin_Running in the second pass. When
|
|
|
|
* implemented, a Created plugin will be switched to Error in the second pass if it not loadable.
|
|
|
|
*
|
|
|
|
* The two pass loading mechanism is described below. Modules/natives are not implemented yet.
|
|
|
|
* PASS ONE: All loadable plugins are found and have the following steps performed:
|
|
|
|
* 1. Loading and compilation is attempted.
|
|
|
|
* 2. If successful, all natives from Core are added.
|
|
|
|
* 3. OnPluginLoad() is called.
|
|
|
|
* 4. If failed, any user natives are scrapped and the process halts here.
|
|
|
|
* 5. If successful, the plugin is ready for Pass 2.
|
|
|
|
* INTERMEDIATE:
|
|
|
|
* 1. All forced modules are loaded.
|
|
|
|
* PASS TWO: All loaded plugins are found and have these steps performed:
|
|
|
|
* 1. Any modules referenced in the plugin that are not already loaded, are loaded.
|
|
|
|
* 2. If any module fails to load and the plugin requires it, load fails and jump to step 6.
|
|
|
|
* 3. If any natives are unresolved, check if they are found in the user-natives pool.
|
|
|
|
* 4. If yes, load succeeds. If not, natives are passed through a native acceptance filter.
|
|
|
|
* 5. If the filter fails, the plugin is marked as failed.
|
|
|
|
* 6. If the plugin has failed to load at this point, any dynamic natives it has added are scrapped.
|
|
|
|
* Furthermore, any plugin that referenced these natives must now have pass 2 re-ran.
|
|
|
|
* PASS THREE (not a real pass):
|
2007-02-02 23:47:14 +01:00
|
|
|
* 7. Once all plugins are deemed to be loaded, OnPluginStart() is called
|
2006-12-13 12:16:20 +01:00
|
|
|
*/
|
|
|
|
|
2006-11-11 02:19:46 +01:00
|
|
|
#define SM_CONTEXTVAR_MYSELF 0
|
|
|
|
|
2006-11-10 19:08:13 +01:00
|
|
|
struct ContextPair
|
|
|
|
{
|
2006-12-13 12:16:20 +01:00
|
|
|
ContextPair() : base(NULL), ctx(NULL), co(NULL)
|
2006-11-10 19:08:13 +01:00
|
|
|
{
|
|
|
|
};
|
2007-01-04 03:08:27 +01:00
|
|
|
BaseContext *base;
|
2006-11-10 19:08:13 +01:00
|
|
|
sp_context_t *ctx;
|
2006-12-13 12:16:20 +01:00
|
|
|
ICompilation *co;
|
|
|
|
IVirtualMachine *vm;
|
2006-11-10 19:08:13 +01:00
|
|
|
};
|
|
|
|
|
2007-03-12 21:40:30 +01:00
|
|
|
struct FakeNative
|
|
|
|
{
|
|
|
|
IPluginContext *ctx;
|
|
|
|
IPluginFunction *call;
|
|
|
|
String name;
|
|
|
|
SPVM_NATIVE_FUNC func;
|
|
|
|
};
|
|
|
|
|
2007-01-27 01:03:34 +01:00
|
|
|
enum LoadRes
|
|
|
|
{
|
|
|
|
LoadRes_Successful,
|
|
|
|
LoadRes_AlreadyLoaded,
|
2007-09-18 19:44:17 +02:00
|
|
|
LoadRes_Failure,
|
|
|
|
LoadRes_NeverLoad
|
2007-01-27 01:03:34 +01:00
|
|
|
};
|
|
|
|
|
2007-06-18 09:04:22 +02:00
|
|
|
struct AutoConfig
|
|
|
|
{
|
|
|
|
String autocfg;
|
|
|
|
String folder;
|
|
|
|
bool create;
|
|
|
|
};
|
|
|
|
|
2007-07-15 03:04:34 +02:00
|
|
|
class CPlugin;
|
|
|
|
struct WeakNative
|
|
|
|
{
|
|
|
|
WeakNative(CPlugin *plugin, uint32_t index)
|
|
|
|
{
|
|
|
|
pl = plugin;
|
|
|
|
idx = index;
|
|
|
|
}
|
|
|
|
CPlugin *pl;
|
|
|
|
uint32_t idx;
|
|
|
|
};
|
|
|
|
|
2006-11-10 19:08:13 +01:00
|
|
|
class CPlugin : public IPlugin
|
|
|
|
{
|
2006-11-11 02:19:46 +01:00
|
|
|
friend class CPluginManager;
|
2006-11-11 06:49:52 +01:00
|
|
|
friend class CFunction;
|
2006-12-13 12:16:20 +01:00
|
|
|
public:
|
|
|
|
CPlugin(const char *file);
|
|
|
|
~CPlugin();
|
2006-11-10 19:08:13 +01:00
|
|
|
public:
|
2007-03-17 01:55:46 +01:00
|
|
|
PluginType GetType();
|
|
|
|
SourcePawn::IPluginContext *GetBaseContext();
|
|
|
|
sp_context_t *GetContext();
|
|
|
|
const sm_plugininfo_t *GetPublicInfo();
|
|
|
|
const char *GetFilename();
|
|
|
|
bool IsDebugging();
|
|
|
|
PluginStatus GetStatus();
|
|
|
|
bool SetPauseState(bool paused);
|
|
|
|
unsigned int GetSerial();
|
|
|
|
const sp_plugin_t *GetPluginStructure();
|
|
|
|
IdentityToken_t *GetIdentity();
|
2007-12-05 19:07:18 +01:00
|
|
|
unsigned int CalcMemUsage();
|
2007-03-17 01:55:46 +01:00
|
|
|
bool SetProperty(const char *prop, void *ptr);
|
|
|
|
bool GetProperty(const char *prop, void **ptr, bool remove=false);
|
2006-11-10 19:08:13 +01:00
|
|
|
public:
|
2006-12-13 12:16:20 +01:00
|
|
|
/**
|
|
|
|
* Creates a plugin object with default values.
|
|
|
|
* If an error buffer is specified, and an error occurs, the error will be copied to the buffer
|
|
|
|
* and NULL will be returned.
|
|
|
|
* If an error buffer is not specified, the error will be copied to an internal buffer and
|
|
|
|
* a valid (but error-stated) CPlugin will be returned.
|
|
|
|
*/
|
|
|
|
static CPlugin *CreatePlugin(const char *file, char *error, size_t maxlength);
|
|
|
|
public:
|
|
|
|
/**
|
|
|
|
* Starts the initial compilation of a plugin.
|
|
|
|
* Returns false if another compilation exists or there is a current context set.
|
|
|
|
*/
|
|
|
|
ICompilation *StartMyCompile(IVirtualMachine *vm);
|
|
|
|
/**
|
|
|
|
* Finalizes a compilation. If error buffer is NULL, the error is saved locally.
|
|
|
|
*/
|
|
|
|
bool FinishMyCompile(char *error, size_t maxlength);
|
|
|
|
void CancelMyCompile();
|
2006-12-30 00:18:13 +01:00
|
|
|
|
2006-12-13 12:16:20 +01:00
|
|
|
/**
|
|
|
|
* Sets an error state on the plugin
|
|
|
|
*/
|
|
|
|
void SetErrorState(PluginStatus status, const char *error_fmt, ...);
|
2006-12-15 14:38:04 +01:00
|
|
|
|
2006-12-30 00:18:13 +01:00
|
|
|
/**
|
|
|
|
* Initializes the plugin's identity information
|
|
|
|
*/
|
|
|
|
void InitIdentity();
|
|
|
|
|
2006-12-15 14:38:04 +01:00
|
|
|
/**
|
|
|
|
* Calls the OnPluginLoad function, and sets any failed states if necessary.
|
|
|
|
* NOTE: Valid pre-states are: Plugin_Created
|
2007-01-11 02:13:34 +01:00
|
|
|
* NOTE: If validated, plugin state is changed to Plugin_Loaded
|
2006-12-15 14:38:04 +01:00
|
|
|
*
|
|
|
|
* If the error buffer is NULL, the error message is cached locally.
|
|
|
|
*/
|
|
|
|
bool Call_AskPluginLoad(char *error, size_t maxlength);
|
|
|
|
|
|
|
|
/**
|
2007-02-02 23:47:14 +01:00
|
|
|
* Calls the OnPluginStart function.
|
2006-12-15 14:38:04 +01:00
|
|
|
* NOTE: Valid pre-states are: Plugin_Created
|
2007-01-11 02:13:34 +01:00
|
|
|
* NOTE: Post-state will be Plugin_Running
|
2006-12-15 14:38:04 +01:00
|
|
|
*/
|
2007-02-02 23:47:14 +01:00
|
|
|
void Call_OnPluginStart();
|
2007-01-11 02:13:34 +01:00
|
|
|
|
|
|
|
/**
|
2007-02-02 23:47:14 +01:00
|
|
|
* Calls the OnPluginEnd function.
|
2007-01-11 02:13:34 +01:00
|
|
|
*/
|
2007-02-02 23:47:14 +01:00
|
|
|
void Call_OnPluginEnd();
|
2007-01-15 01:56:39 +01:00
|
|
|
|
2007-08-01 00:34:52 +02:00
|
|
|
/**
|
|
|
|
* Calls the OnAllPluginsLoaded function.
|
|
|
|
*/
|
|
|
|
void Call_OnAllPluginsLoaded();
|
|
|
|
|
2007-01-15 01:56:39 +01:00
|
|
|
/**
|
2007-01-19 00:28:14 +01:00
|
|
|
* Toggles debug mode in the plugin
|
|
|
|
*/
|
2007-01-17 19:22:00 +01:00
|
|
|
bool ToggleDebugMode(bool debug, char *error, size_t maxlength);
|
2007-01-15 01:56:39 +01:00
|
|
|
|
|
|
|
/**
|
2007-01-19 00:28:14 +01:00
|
|
|
* Returns true if a plugin is usable.
|
|
|
|
*/
|
2007-03-15 05:34:42 +01:00
|
|
|
bool IsRunnable();
|
2007-01-27 04:25:34 +01:00
|
|
|
|
|
|
|
/**
|
2007-02-26 09:32:20 +01:00
|
|
|
* Adds a language file index to the plugin's list.
|
|
|
|
*/
|
2007-01-27 04:25:34 +01:00
|
|
|
void AddLangFile(unsigned int index);
|
|
|
|
|
|
|
|
/**
|
2007-02-26 09:32:20 +01:00
|
|
|
* Get language file count for this plugin.
|
|
|
|
*/
|
2007-03-15 05:34:42 +01:00
|
|
|
size_t GetLangFileCount();
|
2007-01-27 04:25:34 +01:00
|
|
|
|
|
|
|
/**
|
2007-02-26 09:32:20 +01:00
|
|
|
* Get language file index based on the vector index.
|
|
|
|
*/
|
2007-03-15 05:34:42 +01:00
|
|
|
unsigned int GetLangFileByIndex(unsigned int index);
|
2006-12-15 14:38:04 +01:00
|
|
|
public:
|
2007-01-20 03:12:53 +01:00
|
|
|
/**
|
2007-02-26 09:32:20 +01:00
|
|
|
* Returns the modification time during last plugin load.
|
|
|
|
*/
|
2007-03-15 05:34:42 +01:00
|
|
|
time_t GetTimeStamp();
|
2007-01-20 03:12:53 +01:00
|
|
|
|
|
|
|
/**
|
2007-02-26 09:32:20 +01:00
|
|
|
* Returns the current modification time of the plugin file.
|
|
|
|
*/
|
2007-01-20 03:12:53 +01:00
|
|
|
time_t GetFileTimeStamp();
|
2007-01-11 02:13:34 +01:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Returns true if the plugin was running, but is now invalid.
|
|
|
|
*/
|
|
|
|
bool WasRunning();
|
2007-02-26 09:32:20 +01:00
|
|
|
|
|
|
|
Handle_t GetMyHandle();
|
2007-06-18 09:04:22 +02:00
|
|
|
|
|
|
|
void AddConfig(bool autoCreate, const char *cfg, const char *folder);
|
|
|
|
unsigned int GetConfigCount();
|
|
|
|
AutoConfig *GetConfig(unsigned int i);
|
2007-07-15 03:04:34 +02:00
|
|
|
inline void AddLibrary(const char *name)
|
2007-07-12 04:57:43 +02:00
|
|
|
{
|
2007-07-15 03:04:34 +02:00
|
|
|
m_Libraries.push_back(name);
|
2007-07-12 04:57:43 +02:00
|
|
|
}
|
2007-07-16 04:06:02 +02:00
|
|
|
void LibraryActions(bool dropping);
|
2006-11-10 19:08:13 +01:00
|
|
|
protected:
|
|
|
|
void UpdateInfo();
|
2007-01-20 03:12:53 +01:00
|
|
|
void SetTimeStamp(time_t t);
|
2007-03-12 21:40:30 +01:00
|
|
|
void DependencyDropped(CPlugin *pOwner);
|
2006-11-10 19:08:13 +01:00
|
|
|
private:
|
2006-12-13 12:16:20 +01:00
|
|
|
ContextPair m_ctx;
|
2006-11-11 02:19:46 +01:00
|
|
|
PluginType m_type;
|
2007-03-22 22:12:17 +01:00
|
|
|
char m_filename[PLATFORM_MAX_PATH];
|
2006-11-10 19:08:13 +01:00
|
|
|
PluginStatus m_status;
|
|
|
|
unsigned int m_serial;
|
|
|
|
sm_plugininfo_t m_info;
|
|
|
|
sp_plugin_t *m_plugin;
|
2006-12-13 12:16:20 +01:00
|
|
|
char m_errormsg[256];
|
2006-12-15 14:38:04 +01:00
|
|
|
time_t m_LastAccess;
|
2006-12-30 00:18:13 +01:00
|
|
|
IdentityToken_t *m_ident;
|
2006-12-16 23:31:32 +01:00
|
|
|
Handle_t m_handle;
|
2007-01-11 02:13:34 +01:00
|
|
|
bool m_WasRunning;
|
2007-01-27 04:25:34 +01:00
|
|
|
CVector<unsigned int> m_PhraseFiles;
|
2007-03-12 21:40:30 +01:00
|
|
|
List<CPlugin *> m_dependents;
|
|
|
|
List<CPlugin *> m_dependsOn;
|
|
|
|
List<FakeNative *> m_fakeNatives;
|
2007-07-15 23:29:49 +02:00
|
|
|
List<WeakNative> m_WeakNatives;
|
2007-07-15 03:04:34 +02:00
|
|
|
List<String> m_RequiredLibs;
|
|
|
|
List<String> m_Libraries;
|
2007-02-13 20:20:48 +01:00
|
|
|
Trie *m_pProps;
|
2007-03-12 21:40:30 +01:00
|
|
|
bool m_FakeNativesMissing;
|
2007-07-15 03:04:34 +02:00
|
|
|
bool m_LibraryMissing;
|
2007-06-18 09:04:22 +02:00
|
|
|
CVector<AutoConfig *> m_configs;
|
2007-10-22 07:35:31 +02:00
|
|
|
bool m_bGotAllLoaded;
|
2007-03-12 08:08:05 +01:00
|
|
|
};
|
|
|
|
|
2006-12-16 23:31:32 +01:00
|
|
|
class CPluginManager :
|
|
|
|
public IPluginManager,
|
|
|
|
public SMGlobalClass,
|
2007-01-17 19:22:00 +01:00
|
|
|
public IHandleTypeDispatch,
|
|
|
|
public IRootConsoleCommand
|
2006-11-11 02:19:46 +01:00
|
|
|
{
|
2006-11-11 06:49:52 +01:00
|
|
|
friend class CPlugin;
|
2006-11-11 02:19:46 +01:00
|
|
|
public:
|
|
|
|
CPluginManager();
|
2006-11-11 06:49:52 +01:00
|
|
|
~CPluginManager();
|
2006-11-11 02:19:46 +01:00
|
|
|
public:
|
2006-12-10 10:19:59 +01:00
|
|
|
/* Implements iterator class */
|
2006-11-11 02:19:46 +01:00
|
|
|
class CPluginIterator : public IPluginIterator
|
|
|
|
{
|
|
|
|
public:
|
2006-12-15 14:53:58 +01:00
|
|
|
CPluginIterator(List<CPlugin *> *mylist);
|
2006-11-11 02:19:46 +01:00
|
|
|
virtual ~CPluginIterator();
|
|
|
|
virtual bool MorePlugins();
|
|
|
|
virtual IPlugin *GetPlugin();
|
|
|
|
virtual void NextPlugin();
|
2007-01-11 02:13:34 +01:00
|
|
|
void Release();
|
2006-11-11 02:19:46 +01:00
|
|
|
public:
|
|
|
|
void Reset();
|
|
|
|
private:
|
2006-12-15 14:53:58 +01:00
|
|
|
List<CPlugin *> *mylist;
|
|
|
|
List<CPlugin *>::iterator current;
|
2006-11-11 02:19:46 +01:00
|
|
|
};
|
|
|
|
friend class CPluginManager::CPluginIterator;
|
2006-12-10 10:19:59 +01:00
|
|
|
public: //IPluginManager
|
2007-01-11 02:13:34 +01:00
|
|
|
IPlugin *LoadPlugin(const char *path,
|
2006-11-11 02:19:46 +01:00
|
|
|
bool debug,
|
|
|
|
PluginType type,
|
|
|
|
char error[],
|
2007-05-08 02:21:44 +02:00
|
|
|
size_t maxlength,
|
2007-01-27 01:03:34 +01:00
|
|
|
bool *wasloaded);
|
2007-01-11 02:13:34 +01:00
|
|
|
bool UnloadPlugin(IPlugin *plugin);
|
|
|
|
IPlugin *FindPluginByContext(const sp_context_t *ctx);
|
|
|
|
unsigned int GetPluginCount();
|
|
|
|
IPluginIterator *GetPluginIterator();
|
|
|
|
void AddPluginsListener(IPluginsListener *listener);
|
|
|
|
void RemovePluginsListener(IPluginsListener *listener);
|
2006-12-16 23:31:32 +01:00
|
|
|
public: //SMGlobalClass
|
2007-01-11 02:13:34 +01:00
|
|
|
void OnSourceModAllInitialized();
|
|
|
|
void OnSourceModShutdown();
|
2006-12-16 23:31:32 +01:00
|
|
|
public: //IHandleTypeDispatch
|
2007-01-11 02:13:34 +01:00
|
|
|
void OnHandleDestroy(HandleType_t type, void *object);
|
2007-12-05 19:07:18 +01:00
|
|
|
bool GetHandleApproxSize(HandleType_t type, void *object, unsigned int *pSize);
|
2007-01-17 19:22:00 +01:00
|
|
|
public: //IRootConsoleCommand
|
2007-10-14 02:04:21 +02:00
|
|
|
void OnRootConsoleCommand(const char *cmdname, const CCommand &command);
|
2006-12-06 01:09:46 +01:00
|
|
|
public:
|
2006-12-10 10:19:59 +01:00
|
|
|
/**
|
2006-12-15 14:38:04 +01:00
|
|
|
* Loads all plugins not yet loaded
|
|
|
|
*/
|
|
|
|
void LoadAll_FirstPass(const char *config, const char *basedir);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Runs the second loading pass for all plugins
|
2006-12-10 10:19:59 +01:00
|
|
|
*/
|
2006-12-15 14:38:04 +01:00
|
|
|
void LoadAll_SecondPass();
|
2006-12-10 10:19:59 +01:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Tests a plugin file mask against a local folder.
|
|
|
|
* The alias is searched backwards from localdir - i.e., given this input:
|
|
|
|
* csdm/ban csdm/ban
|
|
|
|
* ban csdm/ban
|
|
|
|
* csdm/ban optional/csdm/ban
|
|
|
|
* All of these will return true for an alias match.
|
|
|
|
* Wildcards are allowed in the filename.
|
|
|
|
*/
|
2006-12-13 12:16:20 +01:00
|
|
|
bool TestAliasMatch(const char *alias, const char *localdir);
|
2006-12-15 14:38:04 +01:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Returns whether anything loaded will be a late load.
|
|
|
|
*/
|
2007-01-15 01:56:39 +01:00
|
|
|
bool IsLateLoadTime() const;
|
2006-12-30 08:23:17 +01:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Adds natives from core into the native pool.
|
|
|
|
*/
|
|
|
|
void RegisterNativesFromCore(sp_nativeinfo_t *natives);
|
2007-01-01 11:33:51 +01:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Converts a Handle to an IPlugin if possible.
|
|
|
|
*/
|
|
|
|
IPlugin *PluginFromHandle(Handle_t handle, HandleError *err);
|
2007-01-15 01:56:39 +01:00
|
|
|
|
|
|
|
/**
|
2007-01-17 19:22:00 +01:00
|
|
|
* Finds a plugin based on its index. (starts on index 1)
|
|
|
|
*/
|
2007-01-15 01:56:39 +01:00
|
|
|
CPlugin *GetPluginByOrder(int num);
|
2007-01-17 19:22:00 +01:00
|
|
|
|
2007-10-22 10:53:15 +02:00
|
|
|
int GetOrderOfPlugin(IPlugin *pl);
|
|
|
|
|
2007-02-08 22:41:28 +01:00
|
|
|
/**
|
|
|
|
* Internal version of FindPluginByContext()
|
|
|
|
*/
|
|
|
|
inline CPlugin *GetPluginByCtx(const sp_context_t *ctx)
|
|
|
|
{
|
|
|
|
return reinterpret_cast<CPlugin *>(ctx->user[SM_CONTEXTVAR_MYSELF]);
|
|
|
|
}
|
|
|
|
|
2007-01-17 19:22:00 +01:00
|
|
|
/**
|
|
|
|
* Gets status text for a status code
|
|
|
|
*/
|
|
|
|
const char *GetStatusText(PluginStatus status);
|
2007-01-19 00:28:14 +01:00
|
|
|
|
2007-01-20 03:12:53 +01:00
|
|
|
/**
|
|
|
|
* Reload or update plugins on level shutdown.
|
|
|
|
*/
|
|
|
|
void ReloadOrUnloadPlugins();
|
|
|
|
|
2007-03-14 08:54:54 +01:00
|
|
|
/**
|
|
|
|
* Add public functions from all running or paused
|
|
|
|
* plugins to the specified forward if the names match.
|
|
|
|
*/
|
|
|
|
void AddFunctionsToForward(const char *name, IChangeableForward *pForward);
|
|
|
|
|
2007-08-01 00:34:52 +02:00
|
|
|
/**
|
|
|
|
* Iterates through plugins to call OnAllPluginsLoaded.
|
|
|
|
*/
|
|
|
|
void AllPluginsLoaded();
|
|
|
|
|
2007-06-07 04:36:54 +02:00
|
|
|
CPlugin *GetPluginFromIdentity(IdentityToken_t *pToken);
|
|
|
|
|
2007-06-26 19:08:07 +02:00
|
|
|
void Shutdown();
|
|
|
|
|
2007-10-15 06:06:57 +02:00
|
|
|
void OnLibraryAction(const char *lib, bool is_a_plugin, bool drop);
|
2007-07-16 04:06:02 +02:00
|
|
|
|
|
|
|
bool LibraryExists(const char *lib);
|
2007-08-18 19:15:22 +02:00
|
|
|
|
|
|
|
bool ReloadPlugin(CPlugin *pl);
|
2007-10-22 07:35:31 +02:00
|
|
|
|
|
|
|
void UnloadAll();
|
2008-03-01 06:42:25 +01:00
|
|
|
|
|
|
|
CPlugin *FindPluginByConsoleArg(const char *arg);
|
2006-12-13 12:16:20 +01:00
|
|
|
private:
|
2007-05-08 02:21:44 +02:00
|
|
|
LoadRes _LoadPlugin(CPlugin **pPlugin, const char *path, bool debug, PluginType type, char error[], size_t maxlength);
|
2007-01-16 20:41:21 +01:00
|
|
|
|
|
|
|
void LoadAutoPlugin(const char *plugin);
|
|
|
|
|
2006-12-13 12:16:20 +01:00
|
|
|
/**
|
|
|
|
* Recursively loads all plugins in the given directory.
|
|
|
|
*/
|
|
|
|
void LoadPluginsFromDir(const char *basedir, const char *localdir);
|
|
|
|
|
|
|
|
/**
|
2006-12-15 14:38:04 +01:00
|
|
|
* Adds a plugin object. This is wrapped by LoadPlugin functions.
|
|
|
|
*/
|
|
|
|
void AddPlugin(CPlugin *pPlugin);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Runs the second loading pass on a plugin.
|
|
|
|
*/
|
2007-01-16 20:41:21 +01:00
|
|
|
bool RunSecondPass(CPlugin *pPlugin, char *error, size_t maxlength);
|
2006-12-15 14:38:04 +01:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Adds any globally registered natives to a plugin
|
2006-12-13 12:16:20 +01:00
|
|
|
*/
|
2006-12-15 14:38:04 +01:00
|
|
|
void AddCoreNativesToPlugin(CPlugin *pPlugin);
|
2007-01-19 00:28:14 +01:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Runs an extension pass on a plugin.
|
|
|
|
*/
|
|
|
|
bool LoadOrRequireExtensions(CPlugin *pPlugin, unsigned int pass, char *error, size_t maxlength);
|
2007-02-04 23:41:44 +01:00
|
|
|
|
2007-07-15 03:04:34 +02:00
|
|
|
/**
|
|
|
|
* Manages required natives.
|
|
|
|
*/
|
|
|
|
bool FindOrRequirePluginDeps(CPlugin *pPlugin, char *error, size_t maxlength);
|
|
|
|
|
2007-02-04 23:41:44 +01:00
|
|
|
void _SetPauseState(CPlugin *pPlugin, bool pause);
|
2006-11-11 02:19:46 +01:00
|
|
|
protected:
|
2006-12-13 12:16:20 +01:00
|
|
|
/**
|
|
|
|
* Caching internal objects
|
|
|
|
*/
|
2006-11-11 02:19:46 +01:00
|
|
|
void ReleaseIterator(CPluginIterator *iter);
|
2007-06-07 04:36:54 +02:00
|
|
|
public:
|
2006-12-30 00:18:13 +01:00
|
|
|
inline IdentityToken_t *GetIdentity()
|
|
|
|
{
|
|
|
|
return m_MyIdent;
|
|
|
|
}
|
2007-03-12 08:08:05 +01:00
|
|
|
public:
|
|
|
|
bool AddFakeNative(IPluginFunction *pFunction, const char *name, SPVM_FAKENATIVE_FUNC func);
|
2007-11-17 05:31:01 +01:00
|
|
|
SPVM_NATIVE_FUNC FindCoreNative(const char *name);
|
2007-03-12 08:08:05 +01:00
|
|
|
private:
|
|
|
|
void AddFakeNativesToPlugin(CPlugin *pPlugin);
|
2007-07-15 03:04:34 +02:00
|
|
|
void TryRefreshDependencies(CPlugin *pOther);
|
2006-11-11 02:19:46 +01:00
|
|
|
private:
|
|
|
|
List<IPluginsListener *> m_listeners;
|
2006-12-15 14:53:58 +01:00
|
|
|
List<CPlugin *> m_plugins;
|
2006-11-11 02:19:46 +01:00
|
|
|
CStack<CPluginManager::CPluginIterator *> m_iters;
|
2006-12-10 10:19:59 +01:00
|
|
|
CPluginInfoDatabase m_PluginInfo;
|
2006-12-15 14:38:04 +01:00
|
|
|
Trie *m_LoadLookup;
|
|
|
|
bool m_AllPluginsLoaded;
|
2006-12-30 00:18:13 +01:00
|
|
|
IdentityToken_t *m_MyIdent;
|
2007-08-29 02:47:05 +02:00
|
|
|
Trie *m_pCoreNatives;
|
2007-03-12 08:08:05 +01:00
|
|
|
|
|
|
|
/* Dynamic native stuff */
|
|
|
|
List<FakeNative *> m_Natives;
|
|
|
|
Trie *m_pNativeLookup;
|
|
|
|
|
2007-10-22 07:35:31 +02:00
|
|
|
bool m_LoadingLocked;
|
2006-11-11 02:19:46 +01:00
|
|
|
};
|
|
|
|
|
2006-12-15 14:38:04 +01:00
|
|
|
extern CPluginManager g_PluginSys;
|
2006-11-11 02:19:46 +01:00
|
|
|
|
2006-11-10 19:08:13 +01:00
|
|
|
#endif //_INCLUDE_SOURCEMOD_PLUGINSYSTEM_H_
|