aboutsummaryrefslogtreecommitdiff
path: root/api/logic/modplatform/FtbPackFetchTask.cpp
diff options
context:
space:
mode:
authorPetr Mrázek <peterix@gmail.com>2018-03-16 23:33:58 +0100
committerPetr Mrázek <peterix@gmail.com>2018-03-16 23:33:58 +0100
commit106155dd627d8e333260e2460d4c9c558b49b21f (patch)
treed0678445ccb0881bb10e4bd1b13a3e03eda13d7b /api/logic/modplatform/FtbPackFetchTask.cpp
parent303842a19e4893e4ac6784d60aca990b4276d0ec (diff)
downloadPrismLauncher-106155dd627d8e333260e2460d4c9c558b49b21f.tar.gz
PrismLauncher-106155dd627d8e333260e2460d4c9c558b49b21f.tar.bz2
PrismLauncher-106155dd627d8e333260e2460d4c9c558b49b21f.zip
NOISSUE move modpack platform related files to 'modplatform' subfolders
Diffstat (limited to 'api/logic/modplatform/FtbPackFetchTask.cpp')
-rw-r--r--api/logic/modplatform/FtbPackFetchTask.cpp96
1 files changed, 0 insertions, 96 deletions
diff --git a/api/logic/modplatform/FtbPackFetchTask.cpp b/api/logic/modplatform/FtbPackFetchTask.cpp
deleted file mode 100644
index 9e151186..00000000
--- a/api/logic/modplatform/FtbPackFetchTask.cpp
+++ /dev/null
@@ -1,96 +0,0 @@
-#include "FtbPackFetchTask.h"
-#include <QDomDocument>
-
-FtbPackFetchTask::FtbPackFetchTask() {
-
-}
-
-FtbPackFetchTask::~FtbPackFetchTask() {
-
-}
-
-void FtbPackFetchTask::fetch() {
- NetJob *netJob = new NetJob("FtbModpackFetch");
-
- QUrl url = QUrl("https://ftb.cursecdn.com/FTB2/static/modpacks.xml");
- qDebug() << "Downloading version info from " << url.toString();
-
- netJob->addNetAction(downloadPtr = Net::Download::makeByteArray(url, &modpacksXmlFileData));
-
- QObject::connect(netJob, &NetJob::succeeded, this, &FtbPackFetchTask::fileDownloadFinished);
- QObject::connect(netJob, &NetJob::failed, this, &FtbPackFetchTask::fileDownloadFailed);
-
- jobPtr.reset(netJob);
- netJob->start();
-}
-
-void FtbPackFetchTask::fileDownloadFinished(){
-
- jobPtr.reset();
-
- QDomDocument doc;
-
- QString errorMsg = "Unknown error.";
- int errorLine = -1;
- int errorCol = -1;
-
- if(!doc.setContent(modpacksXmlFileData, false, &errorMsg, &errorLine, &errorCol)){
- auto fullErrMsg = QString("Failed to fetch modpack data: %s %d:%d!").arg(errorMsg, errorLine, errorCol);
- qWarning() << fullErrMsg;
- emit failed(fullErrMsg);
- modpacksXmlFileData.clear();
- return;
- }
-
- modpacksXmlFileData.clear();
-
- FtbModpackList modpackList;
-
- QDomNodeList nodes = doc.elementsByTagName("modpack");
- for(int i = 0; i < nodes.length(); i++) {
- QDomElement element = nodes.at(i).toElement();
-
- FtbModpack modpack;
- modpack.name = element.attribute("name");
- modpack.currentVersion = element.attribute("version");
- modpack.mcVersion = element.attribute("mcVersion");
- modpack.description = element.attribute("description");
- modpack.mods = element.attribute("mods");
- modpack.image = element.attribute("image");
- modpack.oldVersions = element.attribute("oldVersions").split(";");
-
- //remove empty if the xml is bugged
- for(QString curr : modpack.oldVersions) {
- if(curr.isNull() || curr.isEmpty()) {
- modpack.oldVersions.removeAll(curr);
- modpack.bugged = true;
- qWarning() << "Removed some empty versions from" << modpack.name;
- }
- }
-
- if(modpack.oldVersions.size() < 1) {
- if(!modpack.currentVersion.isNull() && !modpack.currentVersion.isEmpty()) {
- modpack.oldVersions.append(modpack.currentVersion);
- qWarning() << "Added current version to oldVersions because oldVersions was empty! (" + modpack.name + ")";
- } else {
- modpack.broken = true;
- qWarning() << "Broken pack:" << modpack.name << " => No valid version!";
- }
- }
-
- modpack.author = element.attribute("author");
-
- modpack.dir = element.attribute("dir");
- modpack.file = element.attribute("url");
-
- modpackList.append(modpack);
- }
-
-
- emit finished(modpackList);
-}
-
-void FtbPackFetchTask::fileDownloadFailed(QString reason){
- qWarning() << "Fetching FtbPacks failed: " << reason;
- emit failed(reason);
-}