#include <OW_dlSharedLibrary.hpp>
Inheritance diagram for OW_NAMESPACE::dlSharedLibrary:
Public Member Functions | |
dlSharedLibrary (void *libhandle, const String &libName) | |
virtual | ~dlSharedLibrary () |
Static Public Member Functions | |
static void | setCallDlclose (bool callDlclose) |
on some platforms (e.g. | |
static bool | isFakeLibrary (const String &library_path) |
Returns if the given path is a fake library or not. | |
Protected Member Functions | |
virtual bool | doGetFunctionPointer (const String &functionName, void **fp) const |
Derived classes have to override this function to implement the symbol loading. | |
Private Member Functions | |
dlSharedLibrary (const dlSharedLibrary &) | |
dlSharedLibrary & | operator= (const dlSharedLibrary &) |
Private Attributes | |
void * | m_libhandle |
String | m_libName |
Static Private Attributes | |
static bool | s_call_dlclose = true |
Using dlsym & friends.
Definition at line 57 of file OW_dlSharedLibrary.hpp.
|
Definition at line 86 of file OW_dlSharedLibrary.cpp. References isFakeLibrary(). |
|
Definition at line 100 of file OW_dlSharedLibrary.cpp. References m_libhandle, and s_call_dlclose. |
|
|
|
Derived classes have to override this function to implement the symbol loading. The symbol to be looked up is contained in functionName, and the pointer to the function should be written into *fp. Return true if the function succeeded, false otherwise.
Implements OW_NAMESPACE::SharedLibrary. Definition at line 109 of file OW_dlSharedLibrary.cpp. References OW_NAMESPACE::dlSharedLibrary_guard, and OW_NAMESPACE::Map< Key, T, Compare >::end(). |
|
Returns if the given path is a fake library or not.
Definition at line 138 of file OW_dlSharedLibrary.cpp. References OW_NAMESPACE::FileSystem::canRead(), OW_NAMESPACE::FileSystem::openFile(), and OW_NAMESPACE::File::read(). Referenced by dlSharedLibrary(), and OW_NAMESPACE::dlSharedLibraryLoader::loadSharedLibrary(). |
|
|
|
on some platforms (e.g. glibc 2.2.x), there are bugs in the dl* functions, and the workaround is to not call dlclose. Setting this variable to 0 will cause dlclose to never be called. Doing this has some problems: memory mapped to the shared library will never be freed up. New versions of the library can't be loaded (if a provider is updated) Definition at line 70 of file OW_dlSharedLibrary.hpp. References s_call_dlclose. |
|
Definition at line 93 of file OW_dlSharedLibrary.hpp. Referenced by ~dlSharedLibrary(). |
|
Definition at line 94 of file OW_dlSharedLibrary.hpp. |
|
Definition at line 107 of file OW_dlSharedLibrary.hpp. Referenced by setCallDlclose(), and ~dlSharedLibrary(). |