mirror of
https://github.com/minetest/minetest.git
synced 2025-01-11 02:20:21 +01:00
mods.cpp/h: little performance improvement in getModsInPath (+ codestyle) (#7108)
* mods.cpp/h: little performance improvement in getModsInPath
This commit is contained in:
parent
6cfd699b9f
commit
f35236afea
17
src/mods.cpp
17
src/mods.cpp
@ -85,24 +85,31 @@ void parseModContents(ModSpec &spec)
|
||||
}
|
||||
}
|
||||
|
||||
std::map<std::string, ModSpec> getModsInPath(std::string path, bool part_of_modpack)
|
||||
std::map<std::string, ModSpec> getModsInPath(const std::string &path,
|
||||
bool part_of_modpack)
|
||||
{
|
||||
// NOTE: this function works in mutual recursion with parseModContents
|
||||
|
||||
std::map<std::string, ModSpec> result;
|
||||
std::vector<fs::DirListNode> dirlist = fs::GetDirListing(path);
|
||||
std::string modpath;
|
||||
|
||||
for (const fs::DirListNode &dln : dirlist) {
|
||||
if(!dln.dir)
|
||||
if (!dln.dir)
|
||||
continue;
|
||||
|
||||
const std::string &modname = dln.name;
|
||||
// Ignore all directories beginning with a ".", especially
|
||||
// VCS directories like ".git" or ".svn"
|
||||
if (modname[0] == '.')
|
||||
continue;
|
||||
std::string modpath = path + DIR_DELIM + modname;
|
||||
|
||||
ModSpec spec(modname, modpath);
|
||||
spec.part_of_modpack = part_of_modpack;
|
||||
modpath.clear();
|
||||
modpath.append(path)
|
||||
.append(DIR_DELIM)
|
||||
.append(modname);
|
||||
|
||||
ModSpec spec(modname, modpath, part_of_modpack);
|
||||
parseModContents(spec);
|
||||
result.insert(std::make_pair(modname, spec));
|
||||
}
|
||||
|
10
src/mods.h
10
src/mods.h
@ -45,16 +45,22 @@ struct ModSpec
|
||||
bool is_modpack = false;
|
||||
// if modpack:
|
||||
std::map<std::string,ModSpec> modpack_content;
|
||||
ModSpec(const std::string &name_="", const std::string &path_=""):
|
||||
ModSpec(const std::string &name_ = "", const std::string &path_ = ""):
|
||||
name(name_),
|
||||
path(path_)
|
||||
{}
|
||||
ModSpec(const std::string &name_, const std::string &path_, bool part_of_modpack_):
|
||||
name(name_),
|
||||
path(path_),
|
||||
part_of_modpack(part_of_modpack_)
|
||||
{}
|
||||
};
|
||||
|
||||
// Retrieves depends, optdepends, is_modpack and modpack_content
|
||||
void parseModContents(ModSpec &mod);
|
||||
|
||||
std::map<std::string,ModSpec> getModsInPath(std::string path, bool part_of_modpack = false);
|
||||
std::map<std::string,ModSpec> getModsInPath(const std::string &path,
|
||||
bool part_of_modpack = false);
|
||||
|
||||
// replaces modpack Modspecs with their content
|
||||
std::vector<ModSpec> flattenMods(std::map<std::string,ModSpec> mods);
|
||||
|
Loading…
Reference in New Issue
Block a user