diff options
author | Petr Mrázek <peterix@gmail.com> | 2013-12-10 20:33:24 +0100 |
---|---|---|
committer | Petr Mrázek <peterix@gmail.com> | 2013-12-10 20:33:24 +0100 |
commit | 10e13df00d618c408d4772920e7bc64efc8df174 (patch) | |
tree | c0e82d74e96a66036792b70e6c87db85c7430988 /logic/LegacyUpdate.cpp | |
parent | 1b185eba41319be846eed07efb1e90d8b6d9e9aa (diff) | |
download | MultiMC-10e13df00d618c408d4772920e7bc64efc8df174.tar MultiMC-10e13df00d618c408d4772920e7bc64efc8df174.tar.gz MultiMC-10e13df00d618c408d4772920e7bc64efc8df174.tar.lz MultiMC-10e13df00d618c408d4772920e7bc64efc8df174.tar.xz MultiMC-10e13df00d618c408d4772920e7bc64efc8df174.zip |
Use metacache for minecraft.jar downloads
Diffstat (limited to 'logic/LegacyUpdate.cpp')
-rw-r--r-- | logic/LegacyUpdate.cpp | 18 |
1 files changed, 11 insertions, 7 deletions
diff --git a/logic/LegacyUpdate.cpp b/logic/LegacyUpdate.cpp index fa3fd240..60dde3e8 100644 --- a/logic/LegacyUpdate.cpp +++ b/logic/LegacyUpdate.cpp @@ -261,16 +261,20 @@ void LegacyUpdate::jarStart() // Build a list of URLs that will need to be downloaded. setStatus("Downloading new minecraft.jar"); - QString urlstr("http://s3.amazonaws.com/Minecraft.Download/versions/"); - QString intended_version_id = inst->intendedVersionId(); - urlstr += intended_version_id + "/" + intended_version_id + ".jar"; + QString version_id = inst->intendedVersionId(); + QString localPath = version_id + "/" + version_id + ".jar"; + QString urlstr = "http://s3.amazonaws.com/Minecraft.Download/versions/" + localPath; - auto dljob = new NetJob("Minecraft.jar for version " + intended_version_id); - dljob->addNetAction(MD5EtagDownload::make(QUrl(urlstr), inst->defaultBaseJar())); - legacyDownloadJob.reset(dljob); + auto dljob = new NetJob("Minecraft.jar for version " + version_id); + + + auto metacache = MMC->metacache(); + auto entry = metacache->resolveEntry("versions", localPath); + dljob->addNetAction(CacheDownload::make(QUrl(urlstr), entry)); connect(dljob, SIGNAL(succeeded()), SLOT(jarFinished())); connect(dljob, SIGNAL(failed()), SLOT(jarFailed())); connect(dljob, SIGNAL(progress(qint64, qint64)), SIGNAL(progress(qint64, qint64))); + legacyDownloadJob.reset(dljob); legacyDownloadJob->start(); } @@ -482,4 +486,4 @@ void LegacyUpdate::ModTheJar() // inst->UpdateVersion(true); emitSucceeded(); return; -}
\ No newline at end of file +} |