diff options
author | robotbrain <robotbrainify@gmail.com> | 2014-09-29 20:05:44 -0400 |
---|---|---|
committer | robotbrain <robotbrainify@gmail.com> | 2014-09-30 16:22:39 -0400 |
commit | bbdf5c1395752802b6ba62116c9408e14527a5c6 (patch) | |
tree | bd9c5e9e28edaf15ed88a80b0f61b096d85004cc /logic/trans/TranslationDownloader.cpp | |
parent | 382e167d646db75860ac21fabae5d3c1a7d4ddb6 (diff) | |
download | MultiMC-bbdf5c1395752802b6ba62116c9408e14527a5c6.tar MultiMC-bbdf5c1395752802b6ba62116c9408e14527a5c6.tar.gz MultiMC-bbdf5c1395752802b6ba62116c9408e14527a5c6.tar.lz MultiMC-bbdf5c1395752802b6ba62116c9408e14527a5c6.tar.xz MultiMC-bbdf5c1395752802b6ba62116c9408e14527a5c6.zip |
Translation downloading!
Diffstat (limited to 'logic/trans/TranslationDownloader.cpp')
-rw-r--r-- | logic/trans/TranslationDownloader.cpp | 51 |
1 files changed, 51 insertions, 0 deletions
diff --git a/logic/trans/TranslationDownloader.cpp b/logic/trans/TranslationDownloader.cpp new file mode 100644 index 00000000..d533a7a2 --- /dev/null +++ b/logic/trans/TranslationDownloader.cpp @@ -0,0 +1,51 @@ +#include "TranslationDownloader.h" +#include "logic/net/NetJob.h" +#include "logic/net/ByteArrayDownload.h" +#include "logic/net/CacheDownload.h" +#include "logic/net/URLConstants.h" +#include "MultiMC.h" + +TranslationDownloader::TranslationDownloader() +{ +} +void TranslationDownloader::downloadTranslations() +{ + QLOG_DEBUG() << "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() +{ + QLOG_DEBUG() << "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()) + { + CacheDownloadPtr dl = CacheDownload::make( + QUrl(URLConstants::TRANSLATIONS_BASE_URL + line), + MMC->metacache()->resolveEntry("translations", "mmc_" + line)); + 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() +{ + QLOG_ERROR() << "Translations Download Failed!"; +} +void TranslationDownloader::dlGood() +{ + QLOG_DEBUG() << "Got translations!"; +} +void TranslationDownloader::indexFailed() +{ + QLOG_ERROR() << "Translations Index Download Failed!"; +} |