Use metacache for minecraft.jar downloads

This commit is contained in:
Petr Mrázek 2013-12-10 20:33:24 +01:00
parent 1b185eba41
commit 10e13df00d
2 changed files with 24 additions and 15 deletions

View File

@ -261,16 +261,20 @@ void LegacyUpdate::jarStart()
// Build a list of URLs that will need to be downloaded. // Build a list of URLs that will need to be downloaded.
setStatus("Downloading new minecraft.jar"); setStatus("Downloading new minecraft.jar");
QString urlstr("http://s3.amazonaws.com/Minecraft.Download/versions/"); QString version_id = inst->intendedVersionId();
QString intended_version_id = inst->intendedVersionId(); QString localPath = version_id + "/" + version_id + ".jar";
urlstr += intended_version_id + "/" + intended_version_id + ".jar"; QString urlstr = "http://s3.amazonaws.com/Minecraft.Download/versions/" + localPath;
auto dljob = new NetJob("Minecraft.jar for version " + intended_version_id); auto dljob = new NetJob("Minecraft.jar for version " + version_id);
dljob->addNetAction(MD5EtagDownload::make(QUrl(urlstr), inst->defaultBaseJar()));
legacyDownloadJob.reset(dljob);
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(succeeded()), SLOT(jarFinished()));
connect(dljob, SIGNAL(failed()), SLOT(jarFailed())); connect(dljob, SIGNAL(failed()), SLOT(jarFailed()));
connect(dljob, SIGNAL(progress(qint64, qint64)), SIGNAL(progress(qint64, qint64))); connect(dljob, SIGNAL(progress(qint64, qint64)), SIGNAL(progress(qint64, qint64)));
legacyDownloadJob.reset(dljob);
legacyDownloadJob->start(); legacyDownloadJob->start();
} }

View File

@ -290,17 +290,22 @@ void OneSixUpdate::jarlibStart()
return; return;
} }
// Build a list of URLs that will need to be downloaded.
std::shared_ptr<OneSixVersion> version = inst->getFullVersion(); std::shared_ptr<OneSixVersion> version = inst->getFullVersion();
// minecraft.jar for this version
// download the right jar, save it in versions/$version/$version.jar {
QString urlstr("http://s3.amazonaws.com/Minecraft.Download/versions/"); QString version_id = version->id;
urlstr += version->id + "/" + version->id + ".jar"; QString localPath = version_id + "/" + version_id + ".jar";
QString targetstr("versions/"); QString urlstr = "http://s3.amazonaws.com/Minecraft.Download/versions/" + localPath;
targetstr += version->id + "/" + version->id + ".jar";
auto job = new NetJob("Libraries for instance " + inst->name()); auto job = new NetJob("Libraries for instance " + inst->name());
job->addNetAction(MD5EtagDownload::make(QUrl(urlstr), targetstr));
auto metacache = MMC->metacache();
auto entry = metacache->resolveEntry("versions", localPath);
job->addNetAction(CacheDownload::make(QUrl(urlstr), entry));
jarlibDownloadJob.reset(job); jarlibDownloadJob.reset(job);
}
auto libs = version->getActiveNativeLibs(); auto libs = version->getActiveNativeLibs();
libs.append(version->getActiveNormalLibs()); libs.append(version->getActiveNormalLibs());