1
0
mirror of https://github.com/vcmi/vcmi.git synced 2025-01-24 03:47:18 +02:00

code review

This commit is contained in:
Laserlicht 2023-12-25 22:41:15 +01:00 committed by GitHub
parent 67568b2b48
commit dcf9c78a2e
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
2 changed files with 17 additions and 10 deletions

View File

@ -50,7 +50,14 @@ void CModListView::changeEvent(QEvent *event)
void CModListView::dragEnterEvent(QDragEnterEvent* event) void CModListView::dragEnterEvent(QDragEnterEvent* event)
{ {
event->acceptProposedAction(); if(event->mimeData()->hasUrls())
for(const auto & url : event->mimeData()->urls())
for(const auto & ending : QStringList({".zip", ".h3m", ".h3c", ".vmap", ".vcmp"}))
if(url.fileName().endsWith(ending, Qt::CaseInsensitive))
{
event->acceptProposedAction();
return;
}
} }
void CModListView::dropEvent(QDropEvent* event) void CModListView::dropEvent(QDropEvent* event)
@ -61,7 +68,7 @@ void CModListView::dropEvent(QDropEvent* event)
{ {
const QList<QUrl> urlList = mimeData->urls(); const QList<QUrl> urlList = mimeData->urls();
for (auto & url : urlList) for (const auto & url : urlList)
{ {
QString urlStr = url.toString(); QString urlStr = url.toString();
QString fileName = url.fileName(); QString fileName = url.fileName();
@ -716,11 +723,11 @@ void CModListView::installFiles(QStringList files)
// TODO: some better way to separate zip's with mods and downloaded repository files // TODO: some better way to separate zip's with mods and downloaded repository files
for(QString filename : files) for(QString filename : files)
{ {
if(filename.endsWith(".zip")) if(filename.endsWith(".zip", Qt::CaseInsensitive))
mods.push_back(filename); mods.push_back(filename);
else if(filename.endsWith(".h3m") || filename.endsWith(".h3c") || filename.endsWith(".vmap") || filename.endsWith(".vcmp")) else if(filename.endsWith(".h3m", Qt::CaseInsensitive) || filename.endsWith(".h3c", Qt::CaseInsensitive) || filename.endsWith(".vmap", Qt::CaseInsensitive) || filename.endsWith(".vcmp", Qt::CaseInsensitive))
maps.push_back(filename); maps.push_back(filename);
else if(filename.endsWith(".json")) else if(filename.endsWith(".json", Qt::CaseInsensitive))
{ {
//download and merge additional files //download and merge additional files
auto repoData = JsonUtils::JsonFromFile(filename).toMap(); auto repoData = JsonUtils::JsonFromFile(filename).toMap();
@ -744,7 +751,7 @@ void CModListView::installFiles(QStringList files)
} }
repositories.push_back(repoData); repositories.push_back(repoData);
} }
else if(filename.endsWith(".png")) else if(filename.endsWith(".png", Qt::CaseInsensitive))
images.push_back(filename); images.push_back(filename);
} }
@ -832,13 +839,13 @@ void CModListView::installMods(QStringList archives)
QFile::remove(archive); QFile::remove(archive);
} }
void CModListView::installMaps(QStringList archives) void CModListView::installMaps(QStringList maps)
{ {
QString destDir = CLauncherDirs::get().mapsPath() + "/"; QString destDir = CLauncherDirs::get().mapsPath() + "/";
for(QString archive : archives) for(QString map : maps)
{ {
QFile(archive).rename(destDir + archive.section('/', -1, -1)); QFile(map).rename(destDir + map.section('/', -1, -1));
} }
} }

View File

@ -54,7 +54,7 @@ class CModListView : public QWidget
void downloadFile(QString file, QString url, QString description, qint64 size = 0); void downloadFile(QString file, QString url, QString description, qint64 size = 0);
void installMods(QStringList archives); void installMods(QStringList archives);
void installMaps(QStringList archives); void installMaps(QStringList maps);
void installFiles(QStringList mods); void installFiles(QStringList mods);
QString genChangelogText(CModEntry & mod); QString genChangelogText(CModEntry & mod);