diff options
author | Petr Mrázek <peterix@gmail.com> | 2016-04-10 15:53:05 +0200 |
---|---|---|
committer | Petr Mrázek <peterix@gmail.com> | 2016-05-01 00:00:14 +0200 |
commit | b6d455a02bd338e9dc0faa09d4d8177ecd8d569a (patch) | |
tree | 41982bca1ede50049f2f8c7109dd18edeefde6d0 /api/logic/trans | |
parent | 47e37635f50c09b4f9a9ee7699e3120bab3e4088 (diff) | |
download | MultiMC-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.cpp | 53 | ||||
-rw-r--r-- | api/logic/trans/TranslationDownloader.h | 32 |
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; +}; |