X-Git-Url: https://git.netwichtig.de/gitweb/?a=blobdiff_plain;f=src%2Fdynamic.cpp;h=2092d0f4ecbca73d780a4259ba893151bf4d33a9;hb=1552f3918ac0dad7fef9b86b70c0f4a63d4e37a7;hp=3a6c0897c7c261f7b0b2157f8e7077af63f7d6db;hpb=6050df73f498d05597fb37c6157868df1f6f4db2;p=user%2Fhenk%2Fcode%2Finspircd.git diff --git a/src/dynamic.cpp b/src/dynamic.cpp index 3a6c0897c..2092d0f4e 100644 --- a/src/dynamic.cpp +++ b/src/dynamic.cpp @@ -2,23 +2,16 @@ * | Inspire Internet Relay Chat Daemon | * +------------------------------------+ * - * InspIRCd is copyright (C) 2002-2006 ChatSpike-Dev. - * E-mail: - * - * - * - * Written by Craig Edwards, Craig McLure, and others. + * InspIRCd: (C) 2002-2007 InspIRCd Development Team + * See: http://www.inspircd.org/wiki/index.php/Credits + * * This program is free but copyrighted software; see * the file COPYING for details. * * --------------------------------------------------- */ -using namespace std; - -#include "inspircd_config.h" #include "configreader.h" -#include "globals.h" #include "dynamic.h" #ifndef STATIC_LINK @@ -27,12 +20,7 @@ using namespace std; #include "modlist.h" #endif -#include "inspstring.h" - #include "inspircd.h" -#include -#include -#include DLLManager::DLLManager(InspIRCd* ServerInstance, const char *fname) { @@ -59,67 +47,15 @@ DLLManager::DLLManager(InspIRCd* ServerInstance, const char *fname) } err = "Module is not statically compiled into the ircd"; #else - // Copy the library to a temp location, this makes recompiles - // a little safer if the ircd is running at the time as the - // shared libraries are mmap()ed and not doing this causes - // segfaults. - FILE* x = fopen(fname,"rb"); - if (!x) - { - err = strerror(errno); - return; - } - ServerInstance->Log(DEBUG,"Opened module file %s",fname); - char tmpfile_template[255]; - char buffer[65536]; - snprintf(tmpfile_template, 255, "%s/inspircd_file.so.%d.XXXXXXXXXX",ServerInstance->Config->TempDir,getpid()); - int fd = mkstemp(tmpfile_template); - if (fd == -1) - { - fclose(x); - err = strerror(errno); - return; - } - ServerInstance->Log(DEBUG,"Copying %s to %s",fname, tmpfile_template); - while (!feof(x)) - { - int n = fread(buffer, 1, 65535, x); - if (n) - { - int written = write(fd,buffer,n); - if (written != n) - { - fclose(x); - err = strerror(errno); - return; - } - } - } - ServerInstance->Log(DEBUG,"Copied entire file."); - // Try to open the library now and get any error message. - - if (close(fd) == -1) - err = strerror(errno); - if (fclose(x) == EOF) - err = strerror(errno); - h = dlopen(fname, RTLD_NOW|RTLD_LOCAL); if (!h) { - ServerInstance->Log(DEBUG,"dlerror occured!"); err = (char*)dlerror(); + ServerInstance->Log(DEBUG,"dlerror '%s' occured!", err); return; } - ServerInstance->Log(DEBUG,"Finished loading '%s': %0x",tmpfile_template, h); - - // We can delete the tempfile once it's loaded, leaving just the inode. - if (!err && !ServerInstance->Config->debugging) - { - ServerInstance->Log(DEBUG,"Deleteting %s",tmpfile_template); - if (unlink(tmpfile_template) == -1) - err = strerror(errno); - } + ServerInstance->Log(DEBUG,"Finished loading '%s': %0x", fname, h); #endif }