summaryrefslogtreecommitdiffstats
path: root/source
diff options
context:
space:
mode:
authormadmaxoft@gmail.com <madmaxoft@gmail.com@0a769ca7-a7f5-676a-18bf-c427514a06d6>2012-02-08 18:38:02 +0100
committermadmaxoft@gmail.com <madmaxoft@gmail.com@0a769ca7-a7f5-676a-18bf-c427514a06d6>2012-02-08 18:38:02 +0100
commit356981a51d6d0fe6f0a21ec79d6ce4ccce416043 (patch)
tree87290f0e30b56ee2194510f6e3300048430757a0 /source
parentcMonsterConfig: removed excessive logging (diff)
downloadcuberite-356981a51d6d0fe6f0a21ec79d6ce4ccce416043.tar
cuberite-356981a51d6d0fe6f0a21ec79d6ce4ccce416043.tar.gz
cuberite-356981a51d6d0fe6f0a21ec79d6ce4ccce416043.tar.bz2
cuberite-356981a51d6d0fe6f0a21ec79d6ce4ccce416043.tar.lz
cuberite-356981a51d6d0fe6f0a21ec79d6ce4ccce416043.tar.xz
cuberite-356981a51d6d0fe6f0a21ec79d6ce4ccce416043.tar.zst
cuberite-356981a51d6d0fe6f0a21ec79d6ce4ccce416043.zip
Diffstat (limited to '')
-rw-r--r--source/cPluginManager.cpp450
1 files changed, 272 insertions, 178 deletions
diff --git a/source/cPluginManager.cpp b/source/cPluginManager.cpp
index eefc50491..fd1a093d7 100644
--- a/source/cPluginManager.cpp
+++ b/source/cPluginManager.cpp
@@ -26,6 +26,10 @@
typedef std::list< cPlugin_Lua* > LuaPluginList;
typedef std::map< cPluginManager::PluginHook, cPluginManager::PluginList > HookMap;
+
+
+
+
struct cPluginManager::sPluginManagerState
{
LuaPluginList LuaPlugins;
@@ -33,12 +37,20 @@ struct cPluginManager::sPluginManagerState
HookMap Hooks;
};
+
+
+
+
cPluginManager* cPluginManager::GetPluginManager()
{
LOGWARN("WARNING: Using deprecated function cPluginManager::GetPluginManager() use cRoot::Get()->GetPluginManager() instead!");
return cRoot::Get()->GetPluginManager();
}
+
+
+
+
cPluginManager::cPluginManager()
: m_pState( new sPluginManagerState )
, m_LuaCommandBinder( new cLuaCommandBinder() )
@@ -46,6 +58,10 @@ cPluginManager::cPluginManager()
{
}
+
+
+
+
cPluginManager::~cPluginManager()
{
UnloadPluginsNow();
@@ -54,113 +70,121 @@ cPluginManager::~cPluginManager()
delete m_pState;
}
+
+
+
+
void cPluginManager::ReloadPlugins()
{
m_bReloadPlugins = true;
}
+
+
+
+
void cPluginManager::ReloadPluginsNow()
{
- LOG("--Loading plugins--");
+ LOG("Loading plugins");
m_bReloadPlugins = false;
UnloadPluginsNow();
-
-
-#if USE_SQUIRREL
+ #if USE_SQUIRREL
if( !SquirrelBindings::IsBound ) // Can only do this once apparently, or we're making ambiguous calls in the script
{
SquirrelVM::Init();
SquirrelBindings::Bind( SquirrelVM::GetVMPtr() );
}
-#endif
+ #endif // USE_SQUIRREL
cIniFile IniFile("settings.ini");
- if( IniFile.ReadFile() )
+ if (!IniFile.ReadFile() )
{
- unsigned int KeyNum = IniFile.FindKey("Plugins");
- unsigned int NumPlugins = IniFile.GetNumValues( KeyNum );
- if( NumPlugins > 0 )
+ LOGWARNING("cPluginManager: Can't find settings.ini, so can't load any plugins.");
+ }
+
+ unsigned int KeyNum = IniFile.FindKey("Plugins");
+ unsigned int NumPlugins = IniFile.GetNumValues( KeyNum );
+ if( NumPlugins > 0 )
+ {
+ for(unsigned int i = 0; i < NumPlugins; i++)
{
- for(unsigned int i = 0; i < NumPlugins; i++)
- {
- std::string ValueName = IniFile.GetValueName(KeyNum, i );
- if( ValueName.compare("Plugin") == 0 ) // It's a Lua plugin
- {
- std::string PluginFile = IniFile.GetValue(KeyNum, i );
- if( !PluginFile.empty() )
+ AString ValueName = IniFile.GetValueName(KeyNum, i );
+ if( ValueName.compare("Plugin") == 0 ) // It's a Lua plugin
+ {
+ AString PluginFile = IniFile.GetValue(KeyNum, i );
+ if( !PluginFile.empty() )
+ {
+ // allow for comma separated plugin list
+ // degrades and works fine for the plugin
+ // per line
+ AStringVector split = StringSplit( PluginFile, "," );
+ for (unsigned int j = 0; j < split.size(); j++)
{
- // allow for comma separated plugin list
- // degrades and works fine for the plugin
- // per line
- AStringVector split = StringSplit( PluginFile, "," );
- for (unsigned int j = 0; j < split.size(); j++) {
- cPlugin_Lua* Plugin = new cPlugin_Lua( (split[j] + std::string(".lua") ).c_str() );
- if( !AddLuaPlugin( Plugin ) )
- {
- delete Plugin;
- }
+ cPlugin_Lua* Plugin = new cPlugin_Lua( (split[j] + AString(".lua") ).c_str() );
+ if( !AddLuaPlugin( Plugin ) )
+ {
+ delete Plugin;
}
}
}
- else if( ValueName.compare("NewPlugin") == 0 ) // New plugin style
+ }
+ else if( ValueName.compare("NewPlugin") == 0 ) // New plugin style
+ {
+ AString PluginFile = IniFile.GetValue(KeyNum, i );
+ if( !PluginFile.empty() )
{
- std::string PluginFile = IniFile.GetValue(KeyNum, i );
- if( !PluginFile.empty() )
+ cPlugin_NewLua* Plugin = new cPlugin_NewLua( PluginFile.c_str() );
+ if( !AddPlugin( Plugin ) )
{
- cPlugin_NewLua* Plugin = new cPlugin_NewLua( PluginFile.c_str() );
- if( !AddPlugin( Plugin ) )
- {
- delete Plugin;
- }
+ delete Plugin;
}
}
-#if USE_SQUIRREL
- else if( ValueName.compare("Squirrel") == 0 ) // Squirrel plugin
+ }
+
+ #if USE_SQUIRREL
+ else if( ValueName.compare("Squirrel") == 0 ) // Squirrel plugin
+ {
+ AString PluginFile = IniFile.GetValue(KeyNum, i );
+ if( !PluginFile.empty() )
{
- std::string PluginFile = IniFile.GetValue(KeyNum, i );
- if( !PluginFile.empty() )
+ LOGINFO("Loading Squirrel plugin: %s", PluginFile.c_str() );
+ try
{
- LOGINFO("Loading Squirrel plugin: %s", PluginFile.c_str() );
+ SquirrelObject SquirrelScript = SquirrelVM::CompileScript( (AString("Plugins/") + PluginFile + ".nut").c_str() );
try
{
- SquirrelObject SquirrelScript = SquirrelVM::CompileScript( (std::string("Plugins/") + PluginFile + ".nut").c_str() );
- try
- {
- SquirrelVM::RunScript( SquirrelScript );
- }
- catch (SquirrelError & e)
- {
- LOGERROR("Error: %s, %s\n", e.desc, "SquirrelVM::RunScript");
- }
- }
- catch (SquirrelError & e)
+ SquirrelVM::RunScript( SquirrelScript );
+ }
+ catch (SquirrelError & e)
{
- LOGERROR("Error: %s, %s\n", e.desc, "SquirrelVM::CompileScript");
+ LOGERROR("SquirrelScript error: %s, %s\n", e.desc, "SquirrelVM::RunScript");
}
}
+ catch (SquirrelError & e)
+ {
+ LOGERROR("SquirrelScript error: %s, %s\n", e.desc, "SquirrelVM::CompileScript");
+ }
}
-#endif
}
+ #endif // USE_SQUIRREL
+
}
+ }
- if( GetNumPlugins() == 0 )
- {
- LOG("No plugins loaded");
- }
- else
- {
- LOG("Loaded %i plugin(s)", GetNumPlugins() );
- }
+ if( GetNumPlugins() == 0 )
+ {
+ LOG("No plugins loaded");
}
else
{
- LOG("WARNING: Can't find settings.ini, so can't load any plugins.");
+ LOG("Loaded %i plugin(s)", GetNumPlugins() );
}
+}
+
+
- LOG("--Done loading plugins--");
-}
void cPluginManager::Tick(float a_Dt)
{
@@ -169,7 +193,6 @@ void cPluginManager::Tick(float a_Dt)
ReloadPluginsNow();
}
-
HookMap::iterator Plugins = m_pState->Hooks.find( E_PLUGIN_TICK );
if( Plugins != m_pState->Hooks.end() )
{
@@ -180,6 +203,10 @@ void cPluginManager::Tick(float a_Dt)
}
}
+
+
+
+
bool cPluginManager::CallHook( PluginHook a_Hook, unsigned int a_NumArgs, ... )
{
HookMap::iterator Plugins = m_pState->Hooks.find( a_Hook );
@@ -209,154 +236,171 @@ bool cPluginManager::CallHook( PluginHook a_Hook, unsigned int a_NumArgs, ... )
return false;
}
- if( Plugins != m_pState->Hooks.end() )
+ if( Plugins == m_pState->Hooks.end() )
+ {
+ return false;
+ }
+
+ switch( a_Hook )
{
- switch( a_Hook )
- {
case E_PLUGIN_COLLECT_ITEM:
+ {
+ if( a_NumArgs != 2 ) break;
+ va_list argptr;
+ va_start( argptr, a_NumArgs);
+ cPickup* Pickup = va_arg(argptr, cPickup* );
+ cPlayer* Player = va_arg(argptr, cPlayer* );
+ va_end (argptr);
+ for( PluginList::iterator itr = Plugins->second.begin(); itr != Plugins->second.end(); ++itr )
{
- if( a_NumArgs != 2 ) break;
- va_list argptr;
- va_start( argptr, a_NumArgs);
- cPickup* Pickup = va_arg(argptr, cPickup* );
- cPlayer* Player = va_arg(argptr, cPlayer* );
- va_end (argptr);
- for( PluginList::iterator itr = Plugins->second.begin(); itr != Plugins->second.end(); ++itr )
- {
- if( (*itr)->OnCollectItem( Pickup, Player ) )
- return true;
- }
+ if( (*itr)->OnCollectItem( Pickup, Player ) )
+ return true;
}
break;
+ }
+
case E_PLUGIN_BLOCK_DIG:
+ {
+ if( a_NumArgs != 2 ) break;
+ va_list argptr;
+ va_start( argptr, a_NumArgs);
+ cPacket_BlockDig* Packet = va_arg(argptr, cPacket_BlockDig* );
+ cPlayer* Player = va_arg(argptr, cPlayer* );
+ cItem* Item = va_arg( argptr, cItem* );
+ va_end (argptr);
+ for( PluginList::iterator itr = Plugins->second.begin(); itr != Plugins->second.end(); ++itr )
{
- if( a_NumArgs != 2 ) break;
- va_list argptr;
- va_start( argptr, a_NumArgs);
- cPacket_BlockDig* Packet = va_arg(argptr, cPacket_BlockDig* );
- cPlayer* Player = va_arg(argptr, cPlayer* );
- cItem* Item = va_arg( argptr, cItem* );
- va_end (argptr);
- for( PluginList::iterator itr = Plugins->second.begin(); itr != Plugins->second.end(); ++itr )
- {
- if( (*itr)->OnBlockDig( Packet, Player, Item ) )
- return true;
- }
+ if( (*itr)->OnBlockDig( Packet, Player, Item ) )
+ return true;
}
break;
+ }
+
case E_PLUGIN_BLOCK_PLACE:
+ {
+ if( a_NumArgs != 2 ) break;
+ va_list argptr;
+ va_start( argptr, a_NumArgs);
+ cPacket_BlockPlace* Packet = va_arg(argptr, cPacket_BlockPlace* );
+ cPlayer* Player = va_arg(argptr, cPlayer* );
+ va_end (argptr);
+ for( PluginList::iterator itr = Plugins->second.begin(); itr != Plugins->second.end(); ++itr )
{
- if( a_NumArgs != 2 ) break;
- va_list argptr;
- va_start( argptr, a_NumArgs);
- cPacket_BlockPlace* Packet = va_arg(argptr, cPacket_BlockPlace* );
- cPlayer* Player = va_arg(argptr, cPlayer* );
- va_end (argptr);
- for( PluginList::iterator itr = Plugins->second.begin(); itr != Plugins->second.end(); ++itr )
- {
- if( (*itr)->OnBlockPlace( Packet, Player ) )
- return true;
- }
+ if( (*itr)->OnBlockPlace( Packet, Player ) )
+ return true;
}
break;
+ }
+
case E_PLUGIN_DISCONNECT:
+ {
+ if( a_NumArgs != 2 ) break;
+ va_list argptr;
+ va_start( argptr, a_NumArgs);
+ const char* Reason = va_arg(argptr, const char* );
+ cPlayer* Player = va_arg(argptr, cPlayer* );
+ va_end (argptr);
+ for( PluginList::iterator itr = Plugins->second.begin(); itr != Plugins->second.end(); ++itr )
{
- if( a_NumArgs != 2 ) break;
- va_list argptr;
- va_start( argptr, a_NumArgs);
- const char* Reason = va_arg(argptr, const char* );
- cPlayer* Player = va_arg(argptr, cPlayer* );
- va_end (argptr);
- for( PluginList::iterator itr = Plugins->second.begin(); itr != Plugins->second.end(); ++itr )
- {
- if( (*itr)->OnDisconnect( Reason, Player ) )
- return true;
- }
+ if( (*itr)->OnDisconnect( Reason, Player ) )
+ return true;
}
break;
+ }
+
case E_PLUGIN_LOGIN:
+ {
+ if( a_NumArgs != 1 ) break;
+ va_list argptr;
+ va_start( argptr, a_NumArgs);
+ cPacket_Login* Packet = va_arg(argptr, cPacket_Login* );
+ va_end (argptr);
+ for( PluginList::iterator itr = Plugins->second.begin(); itr != Plugins->second.end(); ++itr )
{
- if( a_NumArgs != 1 ) break;
- va_list argptr;
- va_start( argptr, a_NumArgs);
- cPacket_Login* Packet = va_arg(argptr, cPacket_Login* );
- va_end (argptr);
- for( PluginList::iterator itr = Plugins->second.begin(); itr != Plugins->second.end(); ++itr )
- {
- if( (*itr)->OnLogin( Packet ) )
- return true;
- }
+ if( (*itr)->OnLogin( Packet ) )
+ return true;
}
break;
+ }
+
case E_PLUGIN_PLAYER_JOIN:
+ {
+ if( a_NumArgs != 1 ) break;
+ va_list argptr;
+ va_start( argptr, a_NumArgs);
+ cPlayer* Player = va_arg(argptr, cPlayer* );
+ va_end (argptr);
+ for( PluginList::iterator itr = Plugins->second.begin(); itr != Plugins->second.end(); ++itr )
{
- if( a_NumArgs != 1 ) break;
- va_list argptr;
- va_start( argptr, a_NumArgs);
- cPlayer* Player = va_arg(argptr, cPlayer* );
- va_end (argptr);
- for( PluginList::iterator itr = Plugins->second.begin(); itr != Plugins->second.end(); ++itr )
- {
- if( (*itr)->OnPlayerJoin( Player ) )
- return true;
- }
+ if( (*itr)->OnPlayerJoin( Player ) )
+ return true;
}
break;
+ }
+
case E_PLUGIN_PLAYER_MOVE:
+ {
+ if( a_NumArgs != 1 ) break;
+ va_list argptr;
+ va_start( argptr, a_NumArgs);
+ cPlayer* Player = va_arg(argptr, cPlayer* );
+ va_end (argptr);
+ for( PluginList::iterator itr = Plugins->second.begin(); itr != Plugins->second.end(); ++itr )
{
- if( a_NumArgs != 1 ) break;
- va_list argptr;
- va_start( argptr, a_NumArgs);
- cPlayer* Player = va_arg(argptr, cPlayer* );
- va_end (argptr);
- for( PluginList::iterator itr = Plugins->second.begin(); itr != Plugins->second.end(); ++itr )
- {
- (*itr)->OnPlayerMove( Player );
- }
+ (*itr)->OnPlayerMove( Player );
}
break;
+ }
+
case E_PLUGIN_TAKE_DAMAGE:
+ {
+ if( a_NumArgs != 2 ) break;
+ va_list argptr;
+ va_start( argptr, a_NumArgs);
+ cPawn* Pawn = va_arg(argptr, cPawn* );
+ TakeDamageInfo* TDI = va_arg(argptr, TakeDamageInfo* );
+ va_end (argptr);
+ for( PluginList::iterator itr = Plugins->second.begin(); itr != Plugins->second.end(); ++itr )
{
- if( a_NumArgs != 2 ) break;
- va_list argptr;
- va_start( argptr, a_NumArgs);
- cPawn* Pawn = va_arg(argptr, cPawn* );
- TakeDamageInfo* TDI = va_arg(argptr, TakeDamageInfo* );
- va_end (argptr);
- for( PluginList::iterator itr = Plugins->second.begin(); itr != Plugins->second.end(); ++itr )
- {
- (*itr)->OnTakeDamage( Pawn, TDI );
- }
+ (*itr)->OnTakeDamage( Pawn, TDI );
}
break;
+ }
+
case E_PLUGIN_KILLED:
+ {
+ if( a_NumArgs != 2 ) break;
+ va_list argptr;
+ va_start( argptr, a_NumArgs);
+ cPawn* Killed = va_arg(argptr, cPawn* );
+ cEntity* Killer = va_arg(argptr, cEntity* );
+ va_end (argptr);
+ for( PluginList::iterator itr = Plugins->second.begin(); itr != Plugins->second.end(); ++itr )
{
- if( a_NumArgs != 2 ) break;
- va_list argptr;
- va_start( argptr, a_NumArgs);
- cPawn* Killed = va_arg(argptr, cPawn* );
- cEntity* Killer = va_arg(argptr, cEntity* );
- va_end (argptr);
- for( PluginList::iterator itr = Plugins->second.begin(); itr != Plugins->second.end(); ++itr )
- {
- if( (*itr)->OnKilled( Killed, Killer ) )
- return true;
- }
+ if( (*itr)->OnKilled( Killed, Killer ) )
+ return true;
}
break;
+ }
+
default:
- LOG("WARNING: Calling Unknown hook: %i", a_Hook );
+ {
+ LOGWARNING("cPluginManager: Calling Unknown hook: %i", a_Hook );
break;
}
- }
+ } // switch (a_Hook)
return false;
}
+
+
+
+
cPlugin* cPluginManager::GetPlugin( const char* a_Plugin )
{
for( PluginList::iterator itr = m_pState->Plugins.begin(); itr != m_pState->Plugins.end(); ++itr )
{
- if( std::string( (*itr)->GetName() ).compare( a_Plugin ) == 0 )
+ if (strcmp((*itr)->GetName(), a_Plugin) == 0 )
{
return *itr;
}
@@ -364,11 +408,19 @@ cPlugin* cPluginManager::GetPlugin( const char* a_Plugin )
return 0;
}
+
+
+
+
const cPluginManager::PluginList & cPluginManager::GetAllPlugins()
{
return m_pState->Plugins;
}
+
+
+
+
void cPluginManager::UnloadPluginsNow()
{
m_pState->Hooks.clear();
@@ -393,23 +445,31 @@ void cPluginManager::UnloadPluginsNow()
//SquirrelVM::Shutdown(); // This breaks shit
}
+
+
+
+
void cPluginManager::RemoveHooks( cPlugin* a_Plugin )
{
- m_pState->Hooks[ E_PLUGIN_TICK ].remove( a_Plugin );
- m_pState->Hooks[ E_PLUGIN_CHAT ].remove( a_Plugin );
- m_pState->Hooks[ E_PLUGIN_COLLECT_ITEM ].remove( a_Plugin );
- m_pState->Hooks[ E_PLUGIN_BLOCK_DIG ].remove( a_Plugin );
- m_pState->Hooks[ E_PLUGIN_BLOCK_PLACE ].remove( a_Plugin );
- m_pState->Hooks[ E_PLUGIN_DISCONNECT ].remove( a_Plugin );
- m_pState->Hooks[ E_PLUGIN_HANDSHAKE ].remove( a_Plugin );
- m_pState->Hooks[ E_PLUGIN_LOGIN ].remove( a_Plugin );
- m_pState->Hooks[ E_PLUGIN_PLAYER_SPAWN ].remove( a_Plugin );
- m_pState->Hooks[ E_PLUGIN_PLAYER_JOIN ].remove( a_Plugin );
- m_pState->Hooks[ E_PLUGIN_PLAYER_MOVE ].remove( a_Plugin );
- m_pState->Hooks[ E_PLUGIN_TAKE_DAMAGE ].remove( a_Plugin );
- m_pState->Hooks[ E_PLUGIN_KILLED ].remove( a_Plugin );
+ m_pState->Hooks[ E_PLUGIN_TICK].remove ( a_Plugin );
+ m_pState->Hooks[ E_PLUGIN_CHAT].remove ( a_Plugin );
+ m_pState->Hooks[ E_PLUGIN_COLLECT_ITEM].remove( a_Plugin );
+ m_pState->Hooks[ E_PLUGIN_BLOCK_DIG].remove ( a_Plugin );
+ m_pState->Hooks[ E_PLUGIN_BLOCK_PLACE].remove ( a_Plugin );
+ m_pState->Hooks[ E_PLUGIN_DISCONNECT].remove ( a_Plugin );
+ m_pState->Hooks[ E_PLUGIN_HANDSHAKE].remove ( a_Plugin );
+ m_pState->Hooks[ E_PLUGIN_LOGIN].remove ( a_Plugin );
+ m_pState->Hooks[ E_PLUGIN_PLAYER_SPAWN].remove( a_Plugin );
+ m_pState->Hooks[ E_PLUGIN_PLAYER_JOIN].remove ( a_Plugin );
+ m_pState->Hooks[ E_PLUGIN_PLAYER_MOVE].remove ( a_Plugin );
+ m_pState->Hooks[ E_PLUGIN_TAKE_DAMAGE].remove ( a_Plugin );
+ m_pState->Hooks[ E_PLUGIN_KILLED].remove ( a_Plugin );
}
+
+
+
+
void cPluginManager::RemovePlugin( cPlugin* a_Plugin, bool a_bDelete /* = false */ )
{
if( a_bDelete )
@@ -419,7 +479,9 @@ void cPluginManager::RemovePlugin( cPlugin* a_Plugin, bool a_bDelete /* = false
RemoveHooks( a_Plugin );
a_Plugin->OnDisable();
if( a_Plugin->GetLanguage() != cPlugin::E_SQUIRREL ) // Squirrel needs to clean it up himself!
+ {
delete a_Plugin;
+ }
}
else
{
@@ -430,6 +492,10 @@ void cPluginManager::RemovePlugin( cPlugin* a_Plugin, bool a_bDelete /* = false
}
}
+
+
+
+
bool cPluginManager::AddPlugin( cPlugin* a_Plugin )
{
if( a_Plugin->Initialize() )
@@ -443,6 +509,10 @@ bool cPluginManager::AddPlugin( cPlugin* a_Plugin )
return false;
}
+
+
+
+
bool cPluginManager::AddPlugin( lua_State* a_LuaState, cPlugin* a_Plugin )
{
a_Plugin->SetLanguage( cPlugin::E_LUA );
@@ -457,6 +527,10 @@ bool cPluginManager::AddPlugin( lua_State* a_LuaState, cPlugin* a_Plugin )
return false;
}
+
+
+
+
bool cPluginManager::AddLuaPlugin( cPlugin_Lua* a_Plugin )
{
m_pState->LuaPlugins.push_back( a_Plugin ); // It HAS to be in here before calling Initialize, so it can be found by AddPlugin()
@@ -469,6 +543,10 @@ bool cPluginManager::AddLuaPlugin( cPlugin_Lua* a_Plugin )
return false;
}
+
+
+
+
void cPluginManager::RemoveLuaPlugin( std::string a_FileName )
{
for( LuaPluginList::iterator itr = m_pState->LuaPlugins.begin(); itr != m_pState->LuaPlugins.end(); ++itr )
@@ -483,6 +561,10 @@ void cPluginManager::RemoveLuaPlugin( std::string a_FileName )
}
}
+
+
+
+
cPlugin_Lua* cPluginManager::GetLuaPlugin( lua_State* a_State )
{
for( LuaPluginList::iterator itr = m_pState->LuaPlugins.begin(); itr != m_pState->LuaPlugins.end(); ++itr )
@@ -495,6 +577,10 @@ cPlugin_Lua* cPluginManager::GetLuaPlugin( lua_State* a_State )
return 0;
}
+
+
+
+
void cPluginManager::AddHook( cPlugin* a_Plugin, PluginHook a_Hook )
{
if( !a_Plugin )
@@ -507,7 +593,15 @@ void cPluginManager::AddHook( cPlugin* a_Plugin, PluginHook a_Hook )
Plugins.push_back( a_Plugin );
}
+
+
+
+
unsigned int cPluginManager::GetNumPlugins()
{
return m_pState->Plugins.size();
}
+
+
+
+