/* -*- Base: 10 ; Mode: C++ -*- */ /*------------------------------------------------------------------------ ** FOST project ** -------------------------------------------------------------------------- -------------------------------------------------------------------------- FILE LOG $Revision: 1.3 $ $Date: 2012-06-15 13:04:40 $ -------------------------------------------------------------------------- CREATION F.CASIMIR SUMMARY DESCRIPTION The main function performs the following actions : ------------------------------------------------------------------------*/ //============================================================================= // // History of code // // creation // // modification //============================================================================= /** */ //============================================================================= // Include section //============================================================================= // Standard libraries include files //----------------------------------------------------------------------------- #include #include #include #include #include #include #include #include #include #include #include #include "log4cxx/logger.h" #include "Helper.hh" // Module Kernel include files //----------------------------------------------------------------------------- #include namespace AMDA { namespace Plugins { log4cxx::LoggerPtr gLogger = log4cxx::Logger::getLogger("AMDA-Kernel.Plugins"); //============================================================================= // Methods of Class PluginManager //============================================================================= //============================================================================= // Other Methods void PluginManager::registerPlugin( const std::string &pluginName, const std::string &pluginPath) { try { LOG4CXX_DEBUG(gLogger, "PluginManager::registerPlugin :: attempt to load: " << pluginPath << pluginName ); Plugin plugin( pluginPath+"/"+pluginName); _loadedPlugins.insert(PluginMap::value_type( pluginName, plugin)).first->second.registerPlugin(*this); //PluginWatcher::getInstance()->addPluginToWatch(pluginPath); LOG4CXX_INFO(gLogger, "PluginManager::loadPlugin :: " << pluginName << " plugin load successfully" ); } catch( AMDA::AMDA_exception & e ) { LOG4CXX_WARN(gLogger, "PluginManager::registerPlugin exception resume: " << boost::diagnostic_information(e)); } catch( ...) { LOG4CXX_WARN(gLogger, "Problem in loadPlugin " << pluginPath); } } /** */ void PluginManager::loadPlugin(const std::string &sPluginName) { if(_loadedPlugins.find(sPluginName) == _loadedPlugins.end()) { registerPlugin( sPluginName+".so", std::string(getenv(sPluginName.c_str()))+"/lib/"); } } void PluginManager::loadPlugin(const std::string &path, const std::string &sPluginName) { int soPos = sPluginName.find(".so"); if ( soPos > 1 ) { registerPlugin( sPluginName, path); } } void PluginManager::loadPluginFromPath(const std::string& pluginPath) { if ( ! pluginPath.empty()) { const char *myDir = pluginPath.c_str(); struct stat myStat; if ((stat(myDir, &myStat) == 0) && (((myStat.st_mode) & S_IFMT) == S_IFDIR)) { // myDir exists and is a directory. std::vector files = std::vector(); AMDA::Helpers::Helper::getMatchFiles(pluginPath.c_str(), files, ".*.so$"); for (unsigned int i = 0; i < files.size(); i++) { loadPlugin(std::string(pluginPath), files[i]); } files.clear(); } } } } // namespace Plugins } // namespace AMDA