@ -22,6 +22,7 @@ must not be misrepresented as being the original software.
distribution .
distribution .
*/
*/
# include "modules/EventManager.h"
# include "Internal.h"
# include "Internal.h"
# include "Core.h"
# include "Core.h"
# include "MemAccess.h"
# include "MemAccess.h"
@ -270,6 +271,7 @@ bool Plugin::unload(color_ostream &con)
// if we are actually loaded
// if we are actually loaded
if ( state = = PS_LOADED )
if ( state = = PS_LOADED )
{
{
EventManager : : unregisterAll ( this ) ;
// notify the plugin about an attempt to shutdown
// notify the plugin about an attempt to shutdown
if ( plugin_onstatechange & &
if ( plugin_onstatechange & &
plugin_onstatechange ( con , SC_BEGIN_UNLOAD ) = = CR_NOT_FOUND )
plugin_onstatechange ( con , SC_BEGIN_UNLOAD ) = = CR_NOT_FOUND )
@ -598,6 +600,22 @@ void Plugin::push_function(lua_State *state, LuaFunction *fn)
}
}
PluginManager : : PluginManager ( Core * core )
PluginManager : : PluginManager ( Core * core )
{
cmdlist_mutex = new mutex ( ) ;
eval_ruby = NULL ;
}
PluginManager : : ~ PluginManager ( )
{
for ( size_t i = 0 ; i < all_plugins . size ( ) ; i + + )
{
delete all_plugins [ i ] ;
}
all_plugins . clear ( ) ;
delete cmdlist_mutex ;
}
void PluginManager : : init ( Core * core )
{
{
# ifdef LINUX_BUILD
# ifdef LINUX_BUILD
string path = core - > getHackPath ( ) + " plugins/ " ;
string path = core - > getHackPath ( ) + " plugins/ " ;
@ -606,8 +624,6 @@ PluginManager::PluginManager(Core * core)
string path = core - > getHackPath ( ) + " plugins \\ " ;
string path = core - > getHackPath ( ) + " plugins \\ " ;
const string searchstr = " .plug.dll " ;
const string searchstr = " .plug.dll " ;
# endif
# endif
cmdlist_mutex = new mutex ( ) ;
eval_ruby = NULL ;
vector < string > filez ;
vector < string > filez ;
getdir ( path , filez ) ;
getdir ( path , filez ) ;
for ( size_t i = 0 ; i < filez . size ( ) ; i + + )
for ( size_t i = 0 ; i < filez . size ( ) ; i + + )
@ -622,16 +638,6 @@ PluginManager::PluginManager(Core * core)
}
}
}
}
PluginManager : : ~ PluginManager ( )
{
for ( size_t i = 0 ; i < all_plugins . size ( ) ; i + + )
{
delete all_plugins [ i ] ;
}
all_plugins . clear ( ) ;
delete cmdlist_mutex ;
}
Plugin * PluginManager : : getPluginByName ( const std : : string & name )
Plugin * PluginManager : : getPluginByName ( const std : : string & name )
{
{
for ( size_t i = 0 ; i < all_plugins . size ( ) ; i + + )
for ( size_t i = 0 ; i < all_plugins . size ( ) ; i + + )