X-Git-Url: https://git.netwichtig.de/gitweb/?a=blobdiff_plain;f=src%2Fdynamic.cpp;h=70d5e7cae8b5a47d278c0199ba381f284889d693;hb=a8878569083bfa4753e9e118adee0ed1da6a0325;hp=704c4d9ddc7736f20f48c92a1d7937e789f536ba;hpb=deb6822302cb9009adc3450dd405817cc0dae9cd;p=user%2Fhenk%2Fcode%2Finspircd.git diff --git a/src/dynamic.cpp b/src/dynamic.cpp index 704c4d9dd..70d5e7cae 100644 --- a/src/dynamic.cpp +++ b/src/dynamic.cpp @@ -11,21 +11,18 @@ * --------------------------------------------------- */ -/* $Core */ - #include "inspircd.h" #include "dynamic.h" #ifndef WIN32 #include #endif -DLLManager::DLLManager(InspIRCd*, const char *fname) +DLLManager::DLLManager(const char *fname) { - err = NULL; - if (!strstr(fname,".so")) { err = "This doesn't look like a module file to me..."; + h = NULL; return; } @@ -33,7 +30,6 @@ DLLManager::DLLManager(InspIRCd*, const char *fname) if (!h) { err = dlerror(); - return; } } @@ -44,24 +40,23 @@ DLLManager::~DLLManager() dlclose(h); } +union init_t { + void* vptr; + Module* (*fptr)(); +}; - -bool DLLManager::GetSymbol(void** v, const char* sym_name) +Module* DLLManager::callInit() { - /* - * try extract a symbol from the library - * get any error message is there is any - */ + if (!h) + return NULL; - if (h) + init_t initfn; + initfn.vptr = dlsym(h, MODULE_INIT_STR); + if (!initfn.vptr) { - dlerror(); // clear value - *v = dlsym(h, sym_name); err = dlerror(); - if (!*v || err) - return false; + return NULL; } - /* succeeded :) */ - return true; + return (*initfn.fptr)(); }