fix: improve code readability

Signed-off-by: Sefa Eyeoglu <contact@scrumplex.net>
This commit is contained in:
Sefa Eyeoglu 2022-11-27 18:38:56 +01:00
parent bae0a0530b
commit 236c196e68
No known key found for this signature in database
GPG Key ID: C10411294912A422

View File

@ -1801,39 +1801,37 @@ void MainWindow::on_actionAddInstance_triggered()
void MainWindow::droppedURLs(QList<QUrl> urls) void MainWindow::droppedURLs(QList<QUrl> urls)
{ {
// NOTE: This loop only processes one dropped file!
for (auto& url : urls) { for (auto& url : urls) {
if (url.isLocalFile()) { if (!url.isLocalFile()) { // probably instance/modpack
addInstance(url.toString());
break;
}
auto localFileName = url.toLocalFile(); auto localFileName = url.toLocalFile();
QFileInfo localFileInfo(localFileName); QFileInfo localFileInfo(localFileName);
bool isResourcePack = ResourcePackUtils::validate(localFileInfo);
bool isTexturePack = TexturePackUtils::validate(localFileInfo);
if (!isResourcePack && !isTexturePack) { // probably instance/modpack
addInstance(localFileName);
break;
}
ImportResourcePackDialog dlg(this); ImportResourcePackDialog dlg(this);
if (ResourcePackUtils::validate(localFileInfo)) { if (dlg.exec() != QDialog::Accepted)
dlg.exec(); break;
if (dlg.result() == QDialog::Accepted) { qDebug() << "Adding resource/texture pack" << localFileName << "to" << dlg.selectedInstanceKey;
qDebug() << "Selected instance to import resource pack into: " << dlg.selectedInstanceKey;
auto instance = APPLICATION->instances()->getInstanceById(dlg.selectedInstanceKey);
auto instanceButBuffed = std::dynamic_pointer_cast<MinecraftInstance>(instance);
instanceButBuffed->resourcePackList()->installResource(localFileName);
}
} else if (TexturePackUtils::validate(localFileInfo)) {
dlg.exec();
if (dlg.result() == QDialog::Accepted) { auto inst = APPLICATION->instances()->getInstanceById(dlg.selectedInstanceKey);
qDebug() << "Selected instance to import texture pack into: " << dlg.selectedInstanceKey; auto minecraftInst = std::dynamic_pointer_cast<MinecraftInstance>(inst);
auto instance = APPLICATION->instances()->getInstanceById(dlg.selectedInstanceKey); if (isResourcePack)
auto instanceButBuffed = std::dynamic_pointer_cast<MinecraftInstance>(instance); minecraftInst->resourcePackList()->installResource(localFileName);
instanceButBuffed->texturePackList()->installResource(localFileName); else if (isTexturePack)
} minecraftInst->texturePackList()->installResource(localFileName);
} else {
addInstance(localFileName);
}
} else {
addInstance(url.toString());
}
// Only process one dropped file...
break; break;
} }
} }