From 0d6c83212ab62aeb6105475ff6239f63f409428c Mon Sep 17 00:00:00 2001 From: Marcus Comstedt Date: Tue, 17 Jul 2018 13:00:29 +0200 Subject: DC: Allow plugins to be grouped into subdirectories By letting the user select which group of plugins to load, an out of memory condition can be avoided while still allowing all plugins to be stored on the same disc. --- backends/platform/dc/selector.cpp | 53 +++++++++++++++++++++++++++++++++++++++ 1 file changed, 53 insertions(+) (limited to 'backends/platform/dc/selector.cpp') diff --git a/backends/platform/dc/selector.cpp b/backends/platform/dc/selector.cpp index 914d683334..18528f86e1 100644 --- a/backends/platform/dc/selector.cpp +++ b/backends/platform/dc/selector.cpp @@ -39,6 +39,7 @@ #define MAX_GAMES 100 #define MAX_DIR 100 +#define MAX_PLUGIN_DIRS 100 void draw_solid_quad(float x1, float y1, float x2, float y2, @@ -517,3 +518,55 @@ bool selectGame(char *&ret, char *&dir_ret, Common::Language &lang_ret, Common:: } else return false; } + +#ifdef DYNAMIC_MODULES +static int findPluginDirs(Game *plugin_dirs, int max, const Common::FSNode &base) +{ + Common::FSList fslist; + int curr_dir = 0; + base.getChildren(fslist, Common::FSNode::kListDirectoriesOnly); + for (Common::FSList::const_iterator entry = fslist.begin(); entry != fslist.end(); + ++entry) { + if (entry->isDirectory()) { + if (curr_dir >= max) + break; + strncpy(plugin_dirs[curr_dir].dir, (*entry).getPath().c_str(), 256); + strncpy(plugin_dirs[curr_dir].text, (*entry).getDisplayName().c_str(), 256); + plugin_dirs[curr_dir].icon.load(NULL, 0, 0); + curr_dir++; + } + } + return curr_dir; +} + +bool selectPluginDir(Common::String &selection, const Common::FSNode &base) +{ + Game *plugin_dirs = new Game[MAX_PLUGIN_DIRS]; + int selected, num_plugin_dirs; + + ta_sync(); + void *mark = ta_txmark(); + + num_plugin_dirs = findPluginDirs(plugin_dirs, MAX_PLUGIN_DIRS, base); + + for (int i=0; i= num_plugin_dirs) + selected = -1; + + if (selected >= 0) + selection = plugin_dirs[selected].dir; + + delete[] plugin_dirs; + + return selected >= 0; +} +#endif -- cgit v1.2.3