The SharedLibrary class loads shared libraries at runtime. More...
Public Member Functions | |
| SharedLibrary () | |
| SharedLibrary (const SharedLibrary &other) | |
| SharedLibrary (const std::string &libPath, const std::string &name) | |
| Construct a SharedLibrary object using a library search path and a library base name.  More... | |
| SharedLibrary (const std::string &absoluteFilePath) | |
| Construct a SharedLibrary object using an absolute file path to the shared library.  More... | |
| ~SharedLibrary () | |
| Destroys this object but does not unload the shared library.  More... | |
| SharedLibrary & | operator= (const SharedLibrary &other) | 
| void | Load () | 
| Loads the shared library pointed to by this SharedLibrary object.  More... | |
| void | Load (int flags) | 
| Loads the shared library pointed to by this SharedLibrary object, using the specified flags on POSIX systems.  More... | |
| void | Unload () | 
| Un-loads the shared library pointed to by this SharedLibrary object.  More... | |
| void | SetName (const std::string &name) | 
| Sets the base name of the shared library.  More... | |
| std::string | GetName () const | 
| Gets the base name of the shared library.  More... | |
| std::string | GetFilePath (const std::string &name) const | 
Gets the absolute file path for the shared library with base name name, using the search path returned by GetLibraryPath().  More... | |
| void | SetFilePath (const std::string &absoluteFilePath) | 
| Sets the absolute file path of this SharedLibrary object.  More... | |
| std::string | GetFilePath () const | 
| Gets the absolute file path of this SharedLibrary object.  More... | |
| void | SetLibraryPath (const std::string &path) | 
| Sets a new library search path.  More... | |
| std::string | GetLibraryPath () const | 
| Gets the library search path of this SharedLibrary object.  More... | |
| void | SetSuffix (const std::string &suffix) | 
| Sets the suffix for shared library names (e.g.  More... | |
| std::string | GetSuffix () const | 
| Gets the file name suffix of this SharedLibrary object.  More... | |
| void | SetPrefix (const std::string &prefix) | 
| Sets the file name prefix for shared library names (e.g.  More... | |
| std::string | GetPrefix () const | 
| Gets the file name prefix of this SharedLibrary object.  More... | |
| void * | GetHandle () const | 
| Gets the internal handle of this SharedLibrary object.  More... | |
| bool | IsLoaded () const | 
| Gets the loaded/unloaded stated of this SharedLibrary object.  More... | |
The SharedLibrary class loads shared libraries at runtime.
| SharedLibrary::SharedLibrary | ( | ) | 
| SharedLibrary::SharedLibrary | ( | const SharedLibrary & | other | ) | 
| SharedLibrary::SharedLibrary | ( | const std::string & | libPath, | 
| const std::string & | name | ||
| ) | 
Construct a SharedLibrary object using a library search path and a library base name.
| libPath | An absolute path containing the shared library | 
| name | The base name of the shared library, without prefix and suffix. | 
| SharedLibrary::SharedLibrary | ( | const std::string & | absoluteFilePath | ) | 
Construct a SharedLibrary object using an absolute file path to the shared library.
Using this constructor effectively disables all setters except SetFilePath().
| absoluteFilePath | The absolute path to the shared library. | 
| SharedLibrary::~SharedLibrary | ( | ) | 
Destroys this object but does not unload the shared library.
| std::string SharedLibrary::GetFilePath | ( | const std::string & | name | ) | const | 
Gets the absolute file path for the shared library with base name name, using the search path returned by GetLibraryPath(). 
| name | The shared library base name. | 
| std::string SharedLibrary::GetFilePath | ( | ) | const | 
Gets the absolute file path of this SharedLibrary object.
| void* SharedLibrary::GetHandle | ( | ) | const | 
Gets the internal handle of this SharedLibrary object.
NULL if the shared library is not loaded, the operating system specific handle otherwise. | std::string SharedLibrary::GetLibraryPath | ( | ) | const | 
Gets the library search path of this SharedLibrary object.
| std::string SharedLibrary::GetName | ( | ) | const | 
Gets the base name of the shared library.
| std::string SharedLibrary::GetPrefix | ( | ) | const | 
Gets the file name prefix of this SharedLibrary object.
| std::string SharedLibrary::GetSuffix | ( | ) | const | 
Gets the file name suffix of this SharedLibrary object.
| bool SharedLibrary::IsLoaded | ( | ) | const | 
Gets the loaded/unloaded stated of this SharedLibrary object.
true if the shared library is loaded, false otherwise. | void SharedLibrary::Load | ( | ) | 
Loads the shared library pointed to by this SharedLibrary object.
On POSIX systems dlopen() is called with the RTLD_LAZY and RTLD_LOCAL flags unless the compiler is gcc 4.4.x or older. Then the RTLD_LAZY and RTLD_GLOBAL flags are used to load the shared library to work around RTTI problems across shared library boundaries.
| std::logic_error | If the library is already loaded. | 
| std::runtime_error | If loading the library failed. | 
| void SharedLibrary::Load | ( | int | flags | ) | 
Loads the shared library pointed to by this SharedLibrary object, using the specified flags on POSIX systems.
| std::logic_error | If the library is already loaded. | 
| std::runtime_error | If loading the library failed. | 
| SharedLibrary& SharedLibrary::operator= | ( | const SharedLibrary & | other | ) | 
| void SharedLibrary::SetFilePath | ( | const std::string & | absoluteFilePath | ) | 
Sets the absolute file path of this SharedLibrary object.
Using this methods with a non-empty absoluteFilePath argument effectively disables all other setters.
| absoluteFilePath | The new absolute file path of this SharedLibrary object. | 
| void SharedLibrary::SetLibraryPath | ( | const std::string & | path | ) | 
Sets a new library search path.
Does nothing if the shared library is already loaded or the SharedLibrary(const std::string&) constructor was used.
| path | The new shared library search path. | 
| void SharedLibrary::SetName | ( | const std::string & | name | ) | 
Sets the base name of the shared library.
Does nothing if the shared library is already loaded or the SharedLibrary(const std::string&) constructor was used.
| name | The base name of the shared library, without prefix and suffix. | 
| void SharedLibrary::SetPrefix | ( | const std::string & | prefix | ) | 
Sets the file name prefix for shared library names (e.g.
.dll or .so). Does nothing if the shared library is already loaded or the SharedLibrary(const std::string&) constructor was used.
| prefix | The shared library name prefix. | 
| void SharedLibrary::SetSuffix | ( | const std::string & | suffix | ) | 
Sets the suffix for shared library names (e.g.
lib). Does nothing if the shared library is already loaded or the SharedLibrary(const std::string&) constructor was used.
| suffix | The shared library name suffix. | 
| void SharedLibrary::Unload | ( | ) | 
Un-loads the shared library pointed to by this SharedLibrary object.
| std::runtime_error | If an error occurred while un-loading the shared library. |