ModuleManager class. More...
#include <ModuleManager.h>
Classes | |
struct | DLLEntity |
Structure for DLL management. More... | |
class | DllPred |
Module list that has already loaded. More... | |
struct | Error |
Structure for exception handling when file open is failed. More... | |
struct | FileNotFound |
Structure for exception handling when specified file cannot be found. More... | |
struct | InvalidArguments |
Structure for exception handling when specified argument is invalid. More... | |
struct | InvalidOperation |
Structure for exception handling when specified operation is invalid. More... | |
struct | ModuleNotFound |
Structure for exception handling when specified module cannot be found. More... | |
struct | NotAllowedOperation |
Structure for exception handling when specified operation cannot be allowed. More... | |
struct | NotFound |
Structure for exception handling of unimplemented part and specified module missing. More... | |
struct | SymbolNotFound |
Structure for exception handling when specified symbol cannot be found. More... | |
class | UnloadPred |
Module unloading functor. More... | |
Public Types | |
typedef void(* | ModuleInitFunc )(Manager *) |
Public Member Functions | |
void | addLoadpath (const std::vector< std::string > &load_path) |
Add the module load path. | |
void | allowAbsolutePath () |
Allow absolute path when specify module path. | |
void | allowModuleDownload () |
Allow URL when specify module path. | |
void | disallowAbsolutePath () |
Disallow absolute path when specify module path. | |
void | disallowModuleDownload () |
Disallow URL when specify module path. | |
bool | fileExist (const std::string &filename) |
Check whether the file exists. | |
std::string | findFile (const std::string &fname, const std::vector< std::string > &load_path) |
Search the file from the LoadPath. | |
std::string | getInitFuncName (const std::string &file_path) |
Create initialization function symbol. | |
std::vector< coil::Properties > | getLoadableModules () |
Get the loadable module list. | |
std::vector< coil::Properties > | getLoadedModules () |
Get the module list that has been loaded. | |
std::vector< std::string > | getLoadPath () |
Get the module load path. | |
std::string | load (const std::string &file_name) |
Load the module. | |
std::string | load (const std::string &file_name, const std::string &init_func) |
Load and intialize the module. | |
ModuleManager (coil::Properties &prop) | |
Constructor. | |
void | setLoadpath (const std::vector< std::string > &load_path) |
Set the module load path. | |
void * | symbol (const std::string &file_name, const std::string &func_name) throw (ModuleNotFound, SymbolNotFound) |
Refer to the symbol of the module. | |
void | unload (const std::string &file_name) |
Unload the module. | |
void | unloadAll () |
Unload all modules. | |
~ModuleManager (void) | |
Destructor. | |
Protected Types | |
typedef std::vector< DLLEntity > | DllMap |
typedef DllMap::const_iterator | DllMapConstItr |
typedef DllMap::iterator | DllMapItr |
typedef std::vector< std::string > | StringVector |
typedef StringVector::const_iterator | StringVectorConstItr |
typedef StringVector::iterator | StringVectorItr |
Protected Member Functions | |
void | addNewFile (const std::string &fpath, coil::vstring &modules) |
Adding file path not existing cache. | |
void | getModuleList (const std::string &lang, coil::vstring &modules) |
Getting loadable file list on the loadpath for given language. | |
void | getModuleProfiles (const std::string &lang, const coil::vstring &modules, vProperties &modprops) |
Getting module properties from given language and file list. | |
void | removeInvalidModules () |
Removing incalid module profiles. | |
Protected Attributes | |
bool | m_absoluteAllowed |
Flag of absolute path when specify module for the load. | |
StringVector | m_configPath |
Configuration path list. | |
bool | m_downloadAllowed |
Flag of URL when specify module for the load. | |
std::string | m_initFuncPrefix |
Initial execution function prefix. | |
std::string | m_initFuncSuffix |
Initial execution function suffix. | |
StringVector | m_loadPath |
Module load path list. | |
vProperties | m_modprofs |
ObjectManager< const char *, DLLEntity, DllPred > | m_modules |
Module list that has already loaded. | |
coil::Properties & | m_properties |
Module Manager properties. | |
Logger | rtclog |
Logger stream. | |
Private Types | |
typedef std::vector < coil::Properties > | vProperties |
ModuleManager class.
This is a class to manage for loading and unloading modules.
Definition at line 74 of file ModuleManager.h.
typedef std::vector<DLLEntity> RTC::ModuleManager::DllMap [protected] |
Definition at line 666 of file ModuleManager.h.
typedef DllMap::const_iterator RTC::ModuleManager::DllMapConstItr [protected] |
Definition at line 668 of file ModuleManager.h.
typedef DllMap::iterator RTC::ModuleManager::DllMapItr [protected] |
Definition at line 667 of file ModuleManager.h.
typedef void(* RTC::ModuleManager::ModuleInitFunc)(Manager *) |
Definition at line 232 of file ModuleManager.h.
typedef std::vector<std::string> RTC::ModuleManager::StringVector [protected] |
Definition at line 662 of file ModuleManager.h.
typedef StringVector::const_iterator RTC::ModuleManager::StringVectorConstItr [protected] |
Definition at line 664 of file ModuleManager.h.
typedef StringVector::iterator RTC::ModuleManager::StringVectorItr [protected] |
Definition at line 663 of file ModuleManager.h.
typedef std::vector<coil::Properties> RTC::ModuleManager::vProperties [private] |
Definition at line 76 of file ModuleManager.h.
Constructor.
Constructor. Initialize based on information in the set Property object.
prop | Properties for initialization |
Definition at line 40 of file ModuleManager.cpp.
RTC::ModuleManager::~ModuleManager | ( | void | ) |
Destructor.
Definition at line 60 of file ModuleManager.cpp.
void RTC::ModuleManager::addLoadpath | ( | const std::vector< std::string > & | load_path | ) |
Add the module load path.
Add specified path list to search path list.
Definition at line 251 of file ModuleManager.cpp.
void RTC::ModuleManager::addNewFile | ( | const std::string & | fpath, |
coil::vstring & | modules | ||
) | [protected] |
Adding file path not existing cache.
Definition at line 472 of file ModuleManager.cpp.
void RTC::ModuleManager::allowAbsolutePath | ( | ) | [inline] |
Allow absolute path when specify module path.
Set to allow the absolute path when specify the module for the load.
Definition at line 467 of file ModuleManager.h.
void RTC::ModuleManager::allowModuleDownload | ( | ) | [inline] |
Allow URL when specify module path.
Allow URL when specify module for the load. When this setup is allowed, downloading and loading the module will be allowed.
Definition at line 507 of file ModuleManager.h.
void RTC::ModuleManager::disallowAbsolutePath | ( | ) | [inline] |
Disallow absolute path when specify module path.
Set to disallow the absolute path when specify the module for the load.
Definition at line 485 of file ModuleManager.h.
void RTC::ModuleManager::disallowModuleDownload | ( | ) | [inline] |
Disallow URL when specify module path.
Disallow URL when specify module for the load.
Definition at line 525 of file ModuleManager.h.
bool RTC::ModuleManager::fileExist | ( | const std::string & | filename | ) |
Check whether the file exists.
Check whether the specified file exists.
filename | Name of file existence for checking |
Definition at line 358 of file ModuleManager.cpp.
std::string RTC::ModuleManager::findFile | ( | const std::string & | fname, |
const std::vector< std::string > & | load_path | ||
) |
Search the file from the LoadPath.
Check whether the specified file exists in the specified path.
fname | Target file name of the search |
load_path | Path list for the search |
Definition at line 329 of file ModuleManager.cpp.
std::string RTC::ModuleManager::getInitFuncName | ( | const std::string & | file_path | ) |
Create initialization function symbol.
Assemble names of the initialization functions.
file_path | Name of module for initialization |
Definition at line 384 of file ModuleManager.cpp.
std::vector< coil::Properties > RTC::ModuleManager::getLoadableModules | ( | ) |
Get the loadable module list.
Get the loadable module list(not implemented)
Get the loadable module list (not implemented).
Definition at line 290 of file ModuleManager.cpp.
std::vector< coil::Properties > RTC::ModuleManager::getLoadedModules | ( | ) |
Get the module list that has been loaded.
Get the module list that has been loaded.
Definition at line 272 of file ModuleManager.cpp.
std::vector<std::string> RTC::ModuleManager::getLoadPath | ( | ) | [inline] |
Get the module load path.
Get the search path of the set module.
Definition at line 391 of file ModuleManager.h.
void RTC::ModuleManager::getModuleList | ( | const std::string & | lang, |
coil::vstring & | modules | ||
) | [protected] |
Getting loadable file list on the loadpath for given language.
Definition at line 420 of file ModuleManager.cpp.
void RTC::ModuleManager::getModuleProfiles | ( | const std::string & | lang, |
const coil::vstring & | modules, | ||
vProperties & | modprops | ||
) | [protected] |
Getting module properties from given language and file list.
Definition at line 500 of file ModuleManager.cpp.
std::string RTC::ModuleManager::load | ( | const std::string & | file_name | ) |
Load the module.
Load file_name as DLL or a shared liblary. The file_name is specified by the relative path to default load path (manager.modules.load_path).
If Property manager.modules.abs_path_allowed is yes, the load module can be specified by the absolute path.
If Property manager.modules.download_allowed is yes, the load module can be specified with URL.
The file_name can be specified by the absolute path. If manager.modules.abs_path_allowed is no, module of file_name will be searched from the default module load path and loaded.
file_name | The target module name for the loading |
Definition at line 72 of file ModuleManager.cpp.
std::string RTC::ModuleManager::load | ( | const std::string & | file_name, |
const std::string & | init_func | ||
) |
Load and intialize the module.
Load and initialize the module.
Load the specified file as DLL or a shared library, and execute operation for specified initialization.
file_name | The target module name for the loading |
init_func | Operation for initialization |
Definition at line 135 of file ModuleManager.cpp.
void RTC::ModuleManager::removeInvalidModules | ( | ) | [protected] |
Removing incalid module profiles.
Definition at line 399 of file ModuleManager.cpp.
void RTC::ModuleManager::setLoadpath | ( | const std::vector< std::string > & | load_path | ) |
Set the module load path.
Specify searching path to find the target module when loading module.
load_path | List of module search path |
Definition at line 238 of file ModuleManager.cpp.
void * RTC::ModuleManager::symbol | ( | const std::string & | file_name, |
const std::string & | func_name | ||
) | throw (ModuleNotFound, SymbolNotFound) |
Refer to the symbol of the module.
Definition at line 209 of file ModuleManager.cpp.
void RTC::ModuleManager::unload | ( | const std::string & | file_name | ) |
Unload the module.
Close and unload the specified module that has been loaded.
file_name | Name of module for the unloading |
Definition at line 166 of file ModuleManager.cpp.
void RTC::ModuleManager::unloadAll | ( | ) |
Unload all modules.
Unload all modules that have been loaded.
Definition at line 189 of file ModuleManager.cpp.
bool RTC::ModuleManager::m_absoluteAllowed [protected] |
Flag of absolute path when specify module for the load.
Definition at line 738 of file ModuleManager.h.
StringVector RTC::ModuleManager::m_configPath [protected] |
Configuration path list.
Definition at line 722 of file ModuleManager.h.
bool RTC::ModuleManager::m_downloadAllowed [protected] |
Flag of URL when specify module for the load.
Definition at line 730 of file ModuleManager.h.
std::string RTC::ModuleManager::m_initFuncPrefix [protected] |
Initial execution function prefix.
Definition at line 756 of file ModuleManager.h.
std::string RTC::ModuleManager::m_initFuncSuffix [protected] |
Initial execution function suffix.
Definition at line 747 of file ModuleManager.h.
StringVector RTC::ModuleManager::m_loadPath [protected] |
Module load path list.
Definition at line 714 of file ModuleManager.h.
vProperties RTC::ModuleManager::m_modprofs [protected] |
Definition at line 776 of file ModuleManager.h.
ObjectManager<const char*, DLLEntity, DllPred> RTC::ModuleManager::m_modules [protected] |
Module list that has already loaded.
Definition at line 705 of file ModuleManager.h.
coil::Properties& RTC::ModuleManager::m_properties [protected] |
Module Manager properties.
Definition at line 678 of file ModuleManager.h.
Logger RTC::ModuleManager::rtclog [protected] |
Logger stream.
Definition at line 647 of file ModuleManager.h.