1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68
|
/* Icinga 2 | (c) 2012 Icinga GmbH | GPLv2+ */
#include "base/library.hpp"
#include "base/loader.hpp"
#include "base/logger.hpp"
#include "base/exception.hpp"
#include "base/application.hpp"
using namespace icinga;
/**
* Loads the specified library.
*
* @param name The name of the library.
*/
Library::Library(const String& name)
{
String path;
#if defined(_WIN32)
path = name + ".dll";
#elif defined(__APPLE__)
path = "lib" + name + "." + Application::GetAppSpecVersion() + ".dylib";
#else /* __APPLE__ */
path = "lib" + name + ".so." + Application::GetAppSpecVersion();
#endif /* _WIN32 */
Log(LogNotice, "Library")
<< "Loading library '" << path << "'";
#ifdef _WIN32
HMODULE hModule = LoadLibrary(path.CStr());
if (!hModule) {
BOOST_THROW_EXCEPTION(win32_error()
<< boost::errinfo_api_function("LoadLibrary")
<< errinfo_win32_error(GetLastError())
<< boost::errinfo_file_name(path));
}
#else /* _WIN32 */
void *hModule = dlopen(path.CStr(), RTLD_NOW | RTLD_GLOBAL);
if (!hModule) {
BOOST_THROW_EXCEPTION(std::runtime_error("Could not load library '" + path + "': " + dlerror()));
}
#endif /* _WIN32 */
Loader::ExecuteDeferredInitializers();
m_Handle.reset(new LibraryHandle(hModule), [](LibraryHandle *handle) {
#ifdef _WIN32
FreeLibrary(*handle);
#else /* _WIN32 */
dlclose(*handle);
#endif /* _WIN32 */
});
}
void *Library::GetSymbolAddress(const String& name) const
{
if (!m_Handle)
BOOST_THROW_EXCEPTION(std::runtime_error("Invalid library handle"));
#ifdef _WIN32
return GetProcAddress(*m_Handle.get(), name.CStr());
#else /* _WIN32 */
return dlsym(*m_Handle.get(), name.CStr());
#endif /* _WIN32 */
}
|