diff --git a/include/aoapplication.h b/include/aoapplication.h index b0ab972..90364db 100644 --- a/include/aoapplication.h +++ b/include/aoapplication.h @@ -554,6 +554,8 @@ private: QVector server_list; QVector favorite_list; QHash asset_lookup_cache; + QHash dir_listing_cache; + QSet dir_listing_exist_cache; private slots: void ms_connect_finished(bool connected, bool will_retry); diff --git a/src/path_functions.cpp b/src/path_functions.cpp index 3f19715..2f5aaec 100644 --- a/src/path_functions.cpp +++ b/src/path_functions.cpp @@ -206,17 +206,15 @@ QString AOApplication::get_case_sensitive_path(QString p_file) return file_parent_dir + "/" + file_basename; // last resort, dirlist parent dir and find case insensitive match - static QHash listing_cache; - static QHash listing_exist_cache; - if (!listing_exist_cache.contains(qHash(file_parent_dir))) { + if (!dir_listing_exist_cache.contains(qHash(file_parent_dir))) { QStringList files = QDir(file_parent_dir).entryList(); for (const QString &file : files) { - listing_cache.insert(qHash(file_parent_dir % QChar('/') % file.toLower()), file); + dir_listing_cache.insert(qHash(file_parent_dir % QChar('/') % file.toLower()), file); } - listing_exist_cache.insert(qHash(file_parent_dir), true); + dir_listing_exist_cache.insert(qHash(file_parent_dir)); } - QString found_file = listing_cache.value( + QString found_file = dir_listing_cache.value( qHash(file_parent_dir % QChar('/') % file_basename.toLower())); if (!found_file.isEmpty()) { @@ -295,4 +293,6 @@ QString AOApplication::get_real_suffixed_path(const VPath &vpath, void AOApplication::invalidate_lookup_cache() { asset_lookup_cache.clear(); + dir_listing_cache.clear(); + dir_listing_exist_cache.clear(); }