Merge pull request #3075 from waddlesplash/no-regexp

FileSearch: Don't use RegExes, just do string comparisons.
This commit is contained in:
Scott Mansell 2015-10-02 04:00:23 +13:00
commit 58d893e56f
10 changed files with 41 additions and 46 deletions

View File

@ -2,13 +2,8 @@
// Licensed under GPLv2+ // Licensed under GPLv2+
// Refer to the license.txt file included. // Refer to the license.txt file included.
#if !__clang__ && __GNUC__ == 4 && __GNUC_MINOR__ < 9
#error <regex> is broken in GCC < 4.9; please upgrade
#endif
#include <algorithm> #include <algorithm>
#include <functional> #include <functional>
#include <regex>
#include "Common/CommonPaths.h" #include "Common/CommonPaths.h"
#include "Common/FileSearch.h" #include "Common/FileSearch.h"
@ -37,20 +32,17 @@ static std::vector<std::string> FileSearchWithTest(const std::vector<std::string
return result; return result;
} }
std::vector<std::string> DoFileSearch(const std::vector<std::string>& globs, const std::vector<std::string>& directories, bool recursive) std::vector<std::string> DoFileSearch(const std::vector<std::string>& exts, const std::vector<std::string>& directories, bool recursive)
{ {
std::string regex_str = "^("; bool accept_all = std::find(exts.begin(), exts.end(), "") != exts.end();
for (const auto& str : globs)
{
if (regex_str.size() != 2)
regex_str += "|";
// convert glob to regex
regex_str += std::regex_replace(std::regex_replace(str, std::regex("\\."), "\\."), std::regex("\\*"), ".*");
}
regex_str += ")$";
std::regex regex(regex_str, std::regex_constants::icase);
return FileSearchWithTest(directories, recursive, [&](const File::FSTEntry& entry) { return FileSearchWithTest(directories, recursive, [&](const File::FSTEntry& entry) {
return std::regex_match(entry.virtualName, regex); if (accept_all)
return true;
std::string name = entry.virtualName;
std::transform(name.begin(), name.end(), name.begin(), ::tolower);
return std::any_of(exts.begin(), exts.end(), [&](const std::string& ext) {
return name.length() >= ext.length() && name.compare(name.length() - ext.length(), ext.length(), ext) == 0;
});
}); });
} }

View File

@ -7,5 +7,5 @@
#include <string> #include <string>
#include <vector> #include <vector>
std::vector<std::string> DoFileSearch(const std::vector<std::string>& globs, const std::vector<std::string>& directories, bool recursive = false); std::vector<std::string> DoFileSearch(const std::vector<std::string>& exts, const std::vector<std::string>& directories, bool recursive = false);
std::vector<std::string> FindSubdirectories(const std::vector<std::string>& directories, bool recursive); std::vector<std::string> FindSubdirectories(const std::vector<std::string>& directories, bool recursive);

View File

@ -153,7 +153,7 @@ GCMemcardDirectory::GCMemcardDirectory(const std::string& directory, int slot, u
hdrfile.ReadBytes(&m_hdr, BLOCK_SIZE); hdrfile.ReadBytes(&m_hdr, BLOCK_SIZE);
} }
std::vector<std::string> rFilenames = DoFileSearch({"*.gci"}, {m_SaveDirectory}); std::vector<std::string> rFilenames = DoFileSearch({".gci"}, {m_SaveDirectory});
if (rFilenames.size() > 112) if (rFilenames.size() > 112)
{ {

View File

@ -91,21 +91,21 @@ void DGameTracker::ScanForGames()
std::vector<std::string> exts; std::vector<std::string> exts;
if (SConfig::GetInstance().m_ListGC) if (SConfig::GetInstance().m_ListGC)
{ {
exts.push_back("*.gcm"); exts.push_back(".gcm");
exts.push_back("*.gcz"); exts.push_back(".gcz");
} }
if (SConfig::GetInstance().m_ListWii || SConfig::GetInstance().m_ListGC) if (SConfig::GetInstance().m_ListWii || SConfig::GetInstance().m_ListGC)
{ {
exts.push_back("*.iso"); exts.push_back(".iso");
exts.push_back("*.ciso"); exts.push_back(".ciso");
exts.push_back("*.wbfs"); exts.push_back(".wbfs");
} }
if (SConfig::GetInstance().m_ListWad) if (SConfig::GetInstance().m_ListWad)
exts.push_back("*.wad"); exts.push_back(".wad");
if (SConfig::GetInstance().m_ListElfDol) if (SConfig::GetInstance().m_ListElfDol)
{ {
exts.push_back("*.dol"); exts.push_back(".dol");
exts.push_back("*.elf"); exts.push_back(".elf");
} }
auto rFilenames = DoFileSearch(exts, SConfig::GetInstance().m_ISOFolder, SConfig::GetInstance().m_RecursiveISOFolder); auto rFilenames = DoFileSearch(exts, SConfig::GetInstance().m_ISOFolder, SConfig::GetInstance().m_RecursiveISOFolder);

View File

@ -162,7 +162,7 @@ void InterfaceConfigPane::LoadGUIValues()
void InterfaceConfigPane::LoadThemes() void InterfaceConfigPane::LoadThemes()
{ {
auto sv = DoFileSearch({"*"}, { auto sv = DoFileSearch({""}, {
File::GetUserPath(D_THEMES_IDX), File::GetUserPath(D_THEMES_IDX),
File::GetSysDirectory() + THEMES_DIR File::GetSysDirectory() + THEMES_DIR
}, /*recursive*/ false); }, /*recursive*/ false);

View File

@ -1956,7 +1956,7 @@ void CFrame::GameListChanged(wxCommandEvent& event)
SConfig::GetInstance().m_ListDrives = event.IsChecked(); SConfig::GetInstance().m_ListDrives = event.IsChecked();
break; break;
case IDM_PURGE_CACHE: case IDM_PURGE_CACHE:
std::vector<std::string> rFilenames = DoFileSearch({"*.cache"}, {File::GetUserPath(D_CACHE_IDX)}); std::vector<std::string> rFilenames = DoFileSearch({".cache"}, {File::GetUserPath(D_CACHE_IDX)});
for (const std::string& rFilename : rFilenames) for (const std::string& rFilename : rFilenames)
{ {

View File

@ -465,20 +465,20 @@ void CGameListCtrl::ScanForISOs()
std::vector<std::string> Extensions; std::vector<std::string> Extensions;
if (SConfig::GetInstance().m_ListGC) if (SConfig::GetInstance().m_ListGC)
Extensions.push_back("*.gcm"); Extensions.push_back(".gcm");
if (SConfig::GetInstance().m_ListWii || SConfig::GetInstance().m_ListGC) if (SConfig::GetInstance().m_ListWii || SConfig::GetInstance().m_ListGC)
{ {
Extensions.push_back("*.iso"); Extensions.push_back(".iso");
Extensions.push_back("*.ciso"); Extensions.push_back(".ciso");
Extensions.push_back("*.gcz"); Extensions.push_back(".gcz");
Extensions.push_back("*.wbfs"); Extensions.push_back(".wbfs");
} }
if (SConfig::GetInstance().m_ListWad) if (SConfig::GetInstance().m_ListWad)
Extensions.push_back("*.wad"); Extensions.push_back(".wad");
if (SConfig::GetInstance().m_ListElfDol) if (SConfig::GetInstance().m_ListElfDol)
{ {
Extensions.push_back("*.dol"); Extensions.push_back(".dol");
Extensions.push_back("*.elf"); Extensions.push_back(".elf");
} }
auto rFilenames = DoFileSearch(Extensions, SConfig::GetInstance().m_ISOFolder, SConfig::GetInstance().m_RecursiveISOFolder); auto rFilenames = DoFileSearch(Extensions, SConfig::GetInstance().m_ISOFolder, SConfig::GetInstance().m_RecursiveISOFolder);

View File

@ -172,7 +172,7 @@ void InputConfigDialog::UpdateProfileComboBox()
pname += PROFILES_PATH; pname += PROFILES_PATH;
pname += m_config.profile_name; pname += m_config.profile_name;
std::vector<std::string> sv = DoFileSearch({"*.ini"}, {pname}); std::vector<std::string> sv = DoFileSearch({".ini"}, {pname});
wxArrayString strs; wxArrayString strs;
for (const std::string& filename : sv) for (const std::string& filename : sv)

View File

@ -38,7 +38,6 @@ Make AA apply instantly during gameplay if possible
#include <algorithm> #include <algorithm>
#include <cstdarg> #include <cstdarg>
#include <regex>
#include "Common/Atomic.h" #include "Common/Atomic.h"
#include "Common/CommonPaths.h" #include "Common/CommonPaths.h"
@ -105,13 +104,17 @@ std::string VideoBackend::GetDisplayName() const
static std::vector<std::string> GetShaders(const std::string &sub_dir = "") static std::vector<std::string> GetShaders(const std::string &sub_dir = "")
{ {
std::vector<std::string> paths = DoFileSearch({"*.glsl"}, { std::vector<std::string> paths = DoFileSearch({".glsl"}, {
File::GetUserPath(D_SHADERS_IDX) + sub_dir, File::GetUserPath(D_SHADERS_IDX) + sub_dir,
File::GetSysDirectory() + SHADERS_DIR DIR_SEP + sub_dir File::GetSysDirectory() + SHADERS_DIR DIR_SEP + sub_dir
}); });
std::vector<std::string> result; std::vector<std::string> result;
for (std::string path : paths) for (std::string path : paths)
result.push_back(std::regex_replace(path, std::regex("^.*/(.*)\\.glsl$"), "$1")); {
std::string name;
SplitPath(path, nullptr, &name, nullptr);
result.push_back(name);
}
return result; return result;
} }

View File

@ -84,11 +84,11 @@ void HiresTexture::Update()
std::string szDir = StringFromFormat("%s%s", File::GetUserPath(D_HIRESTEXTURES_IDX).c_str(), gameCode.c_str()); std::string szDir = StringFromFormat("%s%s", File::GetUserPath(D_HIRESTEXTURES_IDX).c_str(), gameCode.c_str());
std::vector<std::string> Extensions { std::vector<std::string> Extensions {
"*.png", ".png",
"*.bmp", ".bmp",
"*.tga", ".tga",
"*.dds", ".dds",
"*.jpg" // Why not? Could be useful for large photo-like textures ".jpg" // Why not? Could be useful for large photo-like textures
}; };
auto rFilenames = DoFileSearch(Extensions, {szDir}, /*recursive*/ true); auto rFilenames = DoFileSearch(Extensions, {szDir}, /*recursive*/ true);