From 69e7cbc722b6cc75055bc5e28b09a01a469a73fb Mon Sep 17 00:00:00 2001 From: David Anderson Date: Sun, 12 Sep 2004 07:18:54 +0000 Subject: [PATCH] removed debug info --- amxmodx/modules.cpp | 63 +++++++++++++++++++++++++++++++++++-- amxmodx/msvc/amxmodx.vcproj | 2 +- 2 files changed, 62 insertions(+), 3 deletions(-) diff --git a/amxmodx/modules.cpp b/amxmodx/modules.cpp index 755f0d77..d5844b23 100755 --- a/amxmodx/modules.cpp +++ b/amxmodx/modules.cpp @@ -502,6 +502,7 @@ void ConvertModuleName(const char *pathString, String &path) } } #else +#ifdef __linux__ char *ptr = strstr(pathString, "amd64"); if (ptr) { @@ -517,7 +518,7 @@ void ConvertModuleName(const char *pathString, String &path) path.assign(pathString); path.append("_i386.so"); } else { - //check to see if this file even has an extenti + //check to see if this file even has an extension ptr = strstr(pathString, ".so"); if (ptr) { @@ -528,7 +529,47 @@ void ConvertModuleName(const char *pathString, String &path) } } } -#endif +#else + char *ptr = strstr(pathString, ".dll"); + if (ptr) + { + path.assign(pathString); + } else { + //prevent this from loading .so too + ptr = strstr(pathString, ".so"); + if (ptr) + { + int i = 0, len = strlen(pathString), c = -1; + for (i=len-1; i>=0; i--) + { + //cut off at first _ + if (pathString[i] == '_') + { + //make sure this is a valid _ + if (i == len-1 || strncmp(&(pathString[i+1]), "amxx", 4) == 0) + break; + c = i; + break; + } + } + *ptr = 0; + if (c == -1) + { + path.assign(pathString); + path.append(".dll"); + } else { + ptr = (char *)&(pathString[c]); + *ptr = 0; + path.assign(pathString); + path.append(".dll"); + } + } else { + path.assign(pathString); + path.append(".dll"); + } + } +#endif //__linux__ +#endif //SMALL_CELL_SIZE==64 } int loadModules(const char* filename) @@ -717,6 +758,24 @@ void attachMetaModModules(PLUG_LOADTIME now, const char* filename) ConvertModuleName(pathname, modPath); ConvertModuleName(mmpathname, mmPath); + + CList::iterator iter = g_FakeMeta.m_Plugins.begin(); + + //prevent double loading + int foundFlag = 0; + + while (iter) + { + if ( strcmp( (*iter).GetPath(), mmPath.c_str() ) == 0 ) + { + foundFlag = 1; + break; + } + ++iter; + } + + if (foundFlag) + continue; module = DLLOAD( modPath.c_str() ); // link dll diff --git a/amxmodx/msvc/amxmodx.vcproj b/amxmodx/msvc/amxmodx.vcproj index 55599949..ddca6bab 100755 --- a/amxmodx/msvc/amxmodx.vcproj +++ b/amxmodx/msvc/amxmodx.vcproj @@ -386,7 +386,7 @@