diff options
Diffstat (limited to 'logic')
-rw-r--r-- | logic/net/URLConstants.cpp | 4 | ||||
-rw-r--r-- | logic/net/URLConstants.h | 1 | ||||
-rw-r--r-- | logic/trans/TranslationDownloader.cpp | 51 | ||||
-rw-r--r-- | logic/trans/TranslationDownloader.h | 30 |
4 files changed, 85 insertions, 1 deletions
diff --git a/logic/net/URLConstants.cpp b/logic/net/URLConstants.cpp index de919448..b6c78610 100644 --- a/logic/net/URLConstants.cpp +++ b/logic/net/URLConstants.cpp @@ -11,11 +11,13 @@ const QString LIBRARY_BASE("libraries.minecraft.net/"); const QString SKINS_BASE("skins.minecraft.net/MinecraftSkins/"); const QString AUTH_BASE("authserver.mojang.com/"); const QString FORGE_LEGACY_URL("http://files.minecraftforge.net/minecraftforge/json"); -const QString FORGE_GRADLE_URL("http://files.minecraftforge.net/maven/net/minecraftforge/forge/json"); +const QString + FORGE_GRADLE_URL("http://files.minecraftforge.net/maven/net/minecraftforge/forge/json"); const QString MOJANG_STATUS_URL("http://status.mojang.com/check"); const QString MOJANG_STATUS_NEWS_URL("http://status.mojang.com/news"); const QString LITELOADER_URL("http://dl.liteloader.com/versions/versions.json"); const QString IMGUR_BASE_URL("https://api.imgur.com/3/"); const QString FMLLIBS_OUR_BASE_URL("http://files.multimc.org/fmllibs/"); const QString FMLLIBS_FORGE_BASE_URL("http://files.minecraftforge.net/fmllibs/"); +const QString TRANSLATIONS_BASE_URL("http://files.multimc.org/translations/"); }
\ No newline at end of file diff --git a/logic/net/URLConstants.h b/logic/net/URLConstants.h index 392d7362..0373ca23 100644 --- a/logic/net/URLConstants.h +++ b/logic/net/URLConstants.h @@ -36,4 +36,5 @@ extern const QString LITELOADER_URL; extern const QString IMGUR_BASE_URL; extern const QString FMLLIBS_OUR_BASE_URL; extern const QString FMLLIBS_FORGE_BASE_URL; +extern const QString TRANSLATIONS_BASE_URL; } 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!"; +} diff --git a/logic/trans/TranslationDownloader.h b/logic/trans/TranslationDownloader.h new file mode 100644 index 00000000..450b714b --- /dev/null +++ b/logic/trans/TranslationDownloader.h @@ -0,0 +1,30 @@ +#pragma once + +#include <QList> +#include <QUrl> +#include <memory> +#include <QObject> + +class ByteArrayDownload; +class NetJob; + +class TranslationDownloader : public QObject +{ + Q_OBJECT + +public: + TranslationDownloader(); + + void downloadTranslations(); + +private slots: + void indexRecieved(); + void indexFailed(); + void dlFailed(); + void dlGood(); + +private: + std::shared_ptr<ByteArrayDownload> m_index_task; + std::shared_ptr<NetJob> m_dl_job; + std::shared_ptr<NetJob> m_index_job; +};
\ No newline at end of file |