summaryrefslogtreecommitdiffstats
path: root/api/logic/trans
diff options
context:
space:
mode:
authorPetr Mrázek <peterix@gmail.com>2016-04-10 15:53:05 +0200
committerPetr Mrázek <peterix@gmail.com>2016-05-01 00:00:14 +0200
commitb6d455a02bd338e9dc0faa09d4d8177ecd8d569a (patch)
tree41982bca1ede50049f2f8c7109dd18edeefde6d0 /api/logic/trans
parent47e37635f50c09b4f9a9ee7699e3120bab3e4088 (diff)
downloadMultiMC-b6d455a02bd338e9dc0faa09d4d8177ecd8d569a.tar
MultiMC-b6d455a02bd338e9dc0faa09d4d8177ecd8d569a.tar.gz
MultiMC-b6d455a02bd338e9dc0faa09d4d8177ecd8d569a.tar.lz
MultiMC-b6d455a02bd338e9dc0faa09d4d8177ecd8d569a.tar.xz
MultiMC-b6d455a02bd338e9dc0faa09d4d8177ecd8d569a.zip
NOISSUE reorganize and document libraries
Diffstat (limited to 'api/logic/trans')
-rw-r--r--api/logic/trans/TranslationDownloader.cpp53
-rw-r--r--api/logic/trans/TranslationDownloader.h32
2 files changed, 85 insertions, 0 deletions
diff --git a/api/logic/trans/TranslationDownloader.cpp b/api/logic/trans/TranslationDownloader.cpp
new file mode 100644
index 00000000..ee5c1fd2
--- /dev/null
+++ b/api/logic/trans/TranslationDownloader.cpp
@@ -0,0 +1,53 @@
+#include "TranslationDownloader.h"
+#include "net/NetJob.h"
+#include "net/CacheDownload.h"
+#include "net/URLConstants.h"
+#include "Env.h"
+#include <QDebug>
+
+TranslationDownloader::TranslationDownloader()
+{
+}
+void TranslationDownloader::downloadTranslations()
+{
+ qDebug() << "Downloading Translations Index...";
+ m_index_job.reset(new NetJob("Translations Index"));
+ m_index_task = ByteArrayDownload::make(QUrl("http://files.multimc.org/translations/index"));
+ m_index_job->addNetAction(m_index_task);
+ connect(m_index_job.get(), &NetJob::failed, this, &TranslationDownloader::indexFailed);
+ connect(m_index_job.get(), &NetJob::succeeded, this, &TranslationDownloader::indexRecieved);
+ m_index_job->start();
+}
+void TranslationDownloader::indexRecieved()
+{
+ qDebug() << "Got translations index!";
+ m_dl_job.reset(new NetJob("Translations"));
+ QList<QByteArray> lines = m_index_task->m_data.split('\n');
+ for (const auto line : lines)
+ {
+ if (!line.isEmpty())
+ {
+ MetaEntryPtr entry = ENV.metacache()->resolveEntry("translations", "mmc_" + line);
+ entry->setStale(true);
+ CacheDownloadPtr dl = CacheDownload::make(
+ QUrl(URLConstants::TRANSLATIONS_BASE_URL + line),
+ entry);
+ m_dl_job->addNetAction(dl);
+ }
+ }
+ connect(m_dl_job.get(), &NetJob::succeeded, this, &TranslationDownloader::dlGood);
+ connect(m_dl_job.get(), &NetJob::failed, this, &TranslationDownloader::dlFailed);
+ m_dl_job->start();
+}
+void TranslationDownloader::dlFailed(QString reason)
+{
+ qCritical() << "Translations Download Failed:" << reason;
+}
+void TranslationDownloader::dlGood()
+{
+ qDebug() << "Got translations!";
+}
+void TranslationDownloader::indexFailed(QString reason)
+{
+ qCritical() << "Translations Index Download Failed:" << reason;
+}
diff --git a/api/logic/trans/TranslationDownloader.h b/api/logic/trans/TranslationDownloader.h
new file mode 100644
index 00000000..e7893805
--- /dev/null
+++ b/api/logic/trans/TranslationDownloader.h
@@ -0,0 +1,32 @@
+#pragma once
+
+#include <QList>
+#include <QUrl>
+#include <memory>
+#include <QObject>
+#include <net/NetJob.h>
+#include "multimc_logic_export.h"
+
+class ByteArrayDownload;
+class NetJob;
+
+class MULTIMC_LOGIC_EXPORT TranslationDownloader : public QObject
+{
+ Q_OBJECT
+
+public:
+ TranslationDownloader();
+
+ void downloadTranslations();
+
+private slots:
+ void indexRecieved();
+ void indexFailed(QString reason);
+ void dlFailed(QString reason);
+ void dlGood();
+
+private:
+ std::shared_ptr<ByteArrayDownload> m_index_task;
+ NetJobPtr m_dl_job;
+ NetJobPtr m_index_job;
+};