From f7691a51c6019fe9e3bd4fb6e8dece63cd95aac9 Mon Sep 17 00:00:00 2001 From: David Anderson Date: Thu, 17 Aug 2006 19:34:34 +0000 Subject: [PATCH] Added request am43012: per-map plugin files --- amxmodx/CPlugin.cpp | 7 ++-- amxmodx/CPlugin.h | 2 +- amxmodx/meta_api.cpp | 80 +++++++++++++++++++++++++++++--------------- 3 files changed, 59 insertions(+), 30 deletions(-) diff --git a/amxmodx/CPlugin.cpp b/amxmodx/CPlugin.cpp index 865ab083..96048268 100755 --- a/amxmodx/CPlugin.cpp +++ b/amxmodx/CPlugin.cpp @@ -81,14 +81,17 @@ void CPluginMngr::Finalize() m_Finalized = true; } -int CPluginMngr::loadPluginsFromFile(const char* filename) +int CPluginMngr::loadPluginsFromFile(const char* filename, bool warn) { char file[256]; FILE *fp = fopen(build_pathname_r(file, sizeof(file) - 1, "%s", filename), "rt"); if (!fp) { - AMXXLOG_Log("[AMXX] Plugins list not found (file \"%s\")", filename); + if (warn) + { + AMXXLOG_Log("[AMXX] Plugins list not found (file \"%s\")", filename); + } return 1; } diff --git a/amxmodx/CPlugin.h b/amxmodx/CPlugin.h index e24320de..77074c95 100755 --- a/amxmodx/CPlugin.h +++ b/amxmodx/CPlugin.h @@ -125,7 +125,7 @@ public: CPlugin* loadPlugin(const char* path, const char* name, char* error, int debug); void unloadPlugin(CPlugin** a); - int loadPluginsFromFile(const char* filename); + int loadPluginsFromFile(const char* filename, bool warn=true); inline CPlugin* findPluginFast(AMX *amx) { return (CPlugin*)(amx->userdata[UD_FINDPLUGIN]); } CPlugin* findPlugin(AMX *amx); diff --git a/amxmodx/meta_api.cpp b/amxmodx/meta_api.cpp index 99464a57..98f9c523 100755 --- a/amxmodx/meta_api.cpp +++ b/amxmodx/meta_api.cpp @@ -170,16 +170,18 @@ void ParseAndOrAdd(CStack & files, const char *name) } } -void BuildPluginFileList(CStack & files) +void BuildPluginFileList(const char *initialdir, CStack & files) { char path[255]; #if defined WIN32 - build_pathname_r(path, sizeof(path)-1, "%s/*.ini", get_localinfo("amxx_configsdir", "addons/amxmodx/configs")); + build_pathname_r(path, sizeof(path)-1, "%s/*.ini", initialdir); _finddata_t fd; intptr_t handle = _findfirst(path, &fd); if (handle < 0) + { return; + } while (!_findnext(handle, &fd)) { @@ -188,12 +190,14 @@ void BuildPluginFileList(CStack & files) _findclose(handle); #elif defined __linux__ - build_pathname_r(path, sizeof(path)-1, "%s/", get_localinfo("amxx_configsdir", "addons/amxmodx/configs")); + build_pathname_r(path, sizeof(path)-1, "%s/", initialdir); struct dirent *ep; DIR *dp; if ((dp = opendir(path)) == NULL) + { return; + } while ( (ep=readdir(dp)) != NULL ) { @@ -204,6 +208,41 @@ void BuildPluginFileList(CStack & files) #endif } +//Loads a plugin list into the Plugin Cache and Load Modules cache +void LoadExtraPluginsToPCALM(const char *initialdir) +{ + CStack files; + BuildPluginFileList(initialdir, files); + char path[255]; + while (!files.empty()) + { + String *pString = files.front(); + snprintf(path, sizeof(path)-1, "%s/%s", + initialdir, + pString->c_str()); + g_plugins.CALMFromFile(path); + delete pString; + files.pop(); + } +} + +void LoadExtraPluginsFromDir(const char *initialdir) +{ + CStack files; + char path[255]; + BuildPluginFileList(initialdir, files); + while (!files.empty()) + { + String *pString = files.front(); + snprintf(path, sizeof(path)-1, "%s/%s", + initialdir, + pString->c_str()); + g_plugins.loadPluginsFromFile(path); + delete pString; + files.pop(); + } +} + // Precache stuff from force consistency calls // or check for pointed files won't be done int C_PrecacheModel(char *s) @@ -318,22 +357,18 @@ int C_Spawn(edict_t *pent) get_localinfo("amxx_configsdir", "addons/amxmodx/configs"); get_localinfo("amxx_customdir", "addons/amxmodx/custom"); + char map_pluginsfile_path[256]; + // ###### Load modules loadModules(get_localinfo("amxx_modules", "addons/amxmodx/configs/modules.ini"), PT_ANYTIME); g_plugins.CALMFromFile(get_localinfo("amxx_plugins", "addons/amxmodx/configs/plugins.ini")); - CStack files; - BuildPluginFileList(files); - char path[255]; - while (!files.empty()) - { - String *pString = files.front(); - snprintf(path, sizeof(path)-1, "%s/%s", - get_localinfo("amxx_configsdir", "addons/amxmodx/configs"), - pString->c_str()); - g_plugins.CALMFromFile(path); - delete pString; - files.pop(); - } + LoadExtraPluginsToPCALM(get_localinfo("amxx_configsdir", "addons/amxmodx/configs")); + snprintf(map_pluginsfile_path, sizeof(map_pluginsfile_path)-1, + "%s/maps/plugins-%s.ini", + get_localinfo("amxx_configsdir", "addons/amxmodx/configs"), + STRING(gpGlobals->mapname)); + g_plugins.CALMFromFile(map_pluginsfile_path); + int loaded = countModules(CountModules_Running); // Call after attachModules so all modules don't have pending stat // Set some info about amx version and modules @@ -371,17 +406,8 @@ int C_Spawn(edict_t *pent) // ###### Load AMX Mod X plugins g_plugins.loadPluginsFromFile(get_localinfo("amxx_plugins", "addons/amxmodx/configs/plugins.ini")); - BuildPluginFileList(files); - while (!files.empty()) - { - String *pString = files.front(); - snprintf(path, sizeof(path)-1, "%s/%s", - get_localinfo("amxx_configsdir", "addons/amxmodx/configs"), - pString->c_str()); - g_plugins.loadPluginsFromFile(path); - delete pString; - files.pop(); - } + LoadExtraPluginsFromDir(get_localinfo("amxx_configsdir", "addons/amxmodx/configs")); + g_plugins.loadPluginsFromFile(map_pluginsfile_path, false); g_plugins.Finalize(); g_plugins.InvalidateCache();