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. |