1
0
Fork 0
mirror of https://github.com/OpenMW/openmw.git synced 2025-01-16 16:29:55 +00:00

Make the launcher ignore case in bsa names

This commit is contained in:
AnyOldName3 2024-10-21 18:07:13 +01:00
parent cdf7bd74d5
commit 7556ab6f90
4 changed files with 54 additions and 4 deletions

View file

@ -30,6 +30,7 @@
#include <components/navmeshtool/protocol.hpp> #include <components/navmeshtool/protocol.hpp>
#include <components/settings/values.hpp> #include <components/settings/values.hpp>
#include <components/vfs/bsaarchive.hpp> #include <components/vfs/bsaarchive.hpp>
#include <components/vfs/qtconversion.hpp>
#include "utils/profilescombobox.hpp" #include "utils/profilescombobox.hpp"
#include "utils/textinputdialog.hpp" #include "utils/textinputdialog.hpp"
@ -393,7 +394,7 @@ void Launcher::DataFilesPage::populateFileViews(const QString& contentModelName)
int row = 0; int row = 0;
for (const auto& archive : selectedArchives) for (const auto& archive : selectedArchives)
{ {
const auto match = ui.archiveListWidget->findItems(archive.value, Qt::MatchExactly); const auto match = ui.archiveListWidget->findItems(archive.value, Qt::MatchFixedString);
if (match.isEmpty()) if (match.isEmpty())
continue; continue;
const auto name = match[0]->text(); const auto name = match[0]->text();
@ -889,9 +890,9 @@ void Launcher::DataFilesPage::addArchivesFromDir(const QString& path)
QStringList archiveFilter{ "*.bsa", "*.ba2" }; QStringList archiveFilter{ "*.bsa", "*.ba2" };
QDir dir(path); QDir dir(path);
std::unordered_set<QString> archives; std::unordered_set<VFS::Path::Normalized, VFS::Path::Hash> archives;
for (int i = 0; i < ui.archiveListWidget->count(); ++i) for (int i = 0; i < ui.archiveListWidget->count(); ++i)
archives.insert(ui.archiveListWidget->item(i)->text()); archives.insert(VFS::Path::normalizedFromQString(ui.archiveListWidget->item(i)->text()));
for (const auto& fileinfo : dir.entryInfoList(archiveFilter)) for (const auto& fileinfo : dir.entryInfoList(archiveFilter))
{ {
@ -901,7 +902,7 @@ void Launcher::DataFilesPage::addArchivesFromDir(const QString& path)
const auto fileName = fileinfo.fileName(); const auto fileName = fileinfo.fileName();
if (archives.insert(fileName).second) if (archives.insert(VFS::Path::normalizedFromQString(fileName)).second)
addArchive(fileName, Qt::Unchecked); addArchive(fileName, Qt::Unchecked);
} }
} }

View file

@ -554,6 +554,10 @@ if (USE_QT)
application application
) )
add_component_qt_dir (vfs
qtconversion
)
QT_WRAP_UI(ESM_UI_HDR ${ESM_UI}) QT_WRAP_UI(ESM_UI_HDR ${ESM_UI})
endif() endif()

View file

@ -0,0 +1,26 @@
#include "qtconversion.hpp"
#include <components/misc/strings/conversion.hpp>
QString VFS::Path::normalizedToQString(NormalizedView path)
{
return QString::fromUtf8(path.value().data(), path.value().size());
}
QString VFS::Path::normalizedToQString(Normalized&& path)
{
return QString::fromUtf8(path.value().data(), path.value().size());
}
VFS::Path::Normalized VFS::Path::normalizedFromQString(QStringView path)
{
const auto tmp = path.toUtf8();
return Normalized{ tmp };
}
VFS::Path::Normalized VFS::Path::normalizedFromQString(QString&& path)
{
const auto tmp = path.toUtf8();
return Normalized{ tmp };
}

View file

@ -0,0 +1,19 @@
#ifndef COMPONENTS_VFS_QTCONVERSION_HPP
#define COMPONENTS_VFS_QTCONVERSION_HPP
#include <QString>
#include "pathutil.hpp"
namespace VFS::Path
{
QString normalizedToQString(NormalizedView path);
QString normalizedToQString(Normalized&& path);
Normalized normalizedFromQString(QStringView path);
Normalized normalizedFromQString(QString&& path);
}
#endif // COMPONENTS_VFS_QTCONVERSION_HPP