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