NOISSUE add support for Flame packs with resource packs

And a bunch of undefined things we don't handle intentionally just yet...
This commit is contained in:
Petr Mrázek 2017-09-08 09:02:27 +02:00
parent 32a2cb5a0d
commit 3fb4ce713f
6 changed files with 69 additions and 7 deletions

View File

@ -225,7 +225,7 @@ bool deletePath(QString path)
} }
QString PathCombine(QString path1, QString path2) QString PathCombine(const QString & path1, const QString & path2)
{ {
if(!path1.size()) if(!path1.size())
return path2; return path2;
@ -234,11 +234,16 @@ QString PathCombine(QString path1, QString path2)
return QDir::cleanPath(path1 + QDir::separator() + path2); return QDir::cleanPath(path1 + QDir::separator() + path2);
} }
QString PathCombine(QString path1, QString path2, QString path3) QString PathCombine(const QString & path1, const QString & path2, const QString & path3)
{ {
return PathCombine(PathCombine(path1, path2), path3); return PathCombine(PathCombine(path1, path2), path3);
} }
QString PathCombine(const QString & path1, const QString & path2, const QString & path3, const QString & path4)
{
return PathCombine(PathCombine(path1, path2, path3), path4);
}
QString AbsolutePath(QString path) QString AbsolutePath(QString path)
{ {
return QFileInfo(path).absolutePath(); return QFileInfo(path).absolutePath();

View File

@ -83,8 +83,9 @@ private:
*/ */
MULTIMC_LOGIC_EXPORT bool deletePath(QString path); MULTIMC_LOGIC_EXPORT bool deletePath(QString path);
MULTIMC_LOGIC_EXPORT QString PathCombine(QString path1, QString path2); MULTIMC_LOGIC_EXPORT QString PathCombine(const QString &path1, const QString &path2);
MULTIMC_LOGIC_EXPORT QString PathCombine(QString path1, QString path2, QString path3); MULTIMC_LOGIC_EXPORT QString PathCombine(const QString &path1, const QString &path2, const QString &path3);
MULTIMC_LOGIC_EXPORT QString PathCombine(const QString &path1, const QString &path2, const QString &path3, const QString &path4);
MULTIMC_LOGIC_EXPORT QString AbsolutePath(QString path); MULTIMC_LOGIC_EXPORT QString AbsolutePath(QString path);

View File

@ -297,8 +297,8 @@ void InstanceImportTask::processFlame()
m_filesNetJob.reset(new NetJob(tr("Mod download"))); m_filesNetJob.reset(new NetJob(tr("Mod download")));
for(auto result: results.files) for(auto result: results.files)
{ {
auto path = FS::PathCombine(m_stagingPath, "minecraft/mods", result.fileName); auto path = FS::PathCombine(m_stagingPath ,"minecraft", result.targetFolder, result.fileName);
auto dl = Net::Download::makeFile(result.url,path); auto dl = Net::Download::makeFile(result.url, path);
m_filesNetJob->addNetAction(dl); m_filesNetJob->addNetAction(dl);
} }
m_modIdResolver.reset(); m_modIdResolver.reset();

View File

@ -49,6 +49,51 @@ void Flame::FileResolvingTask::netJobFinished()
} }
out.fileName = Json::requireString(obj, "FileNameOnDisk"); out.fileName = Json::requireString(obj, "FileNameOnDisk");
out.url = Json::requireString(obj, "DownloadURL"); out.url = Json::requireString(obj, "DownloadURL");
// This is a piece of a Flame project JSON pulled out into the file metadata (here) for convenience
// It is also optional
QJsonObject projObj = Json::ensureObject(obj, "_Project", {});
if(!projObj.isEmpty())
{
QString strType = Json::ensureString(projObj, "PackageType", "mod").toLower();
if(strType == "singlefile")
{
out.type = File::Type::SingleFile;
}
// FIXME: what are these?
/*
else if(strType == "ctoc")
{
out.type = File::Type::Ctoc;
}
else if(strType == "cmod2")
{
out.type = File::Type::Cmod2;
}
*/
else if(strType == "mod")
{
out.type = File::Type::Mod;
}
// FIXME: how to handle nested packs and folders?
/*
else if(strType == "folder")
{
out.type = File::Type::Folder;
}
else if(strType == "modpack")
{
out.type = File::Type::Modpack;
}
*/
else
{
qCritical() << "Resolving of" << out.projectId << out.fileId << "failed because of unknown file type:" << strType;
out.type = File::Type::Unknown;
failed = true;
continue;
}
out.targetFolder = Json::ensureString(projObj, "Path", "mods");
}
out.resolved = true; out.resolved = true;
} }
catch(JSONValidationError & e) catch(JSONValidationError & e)

View File

@ -5,7 +5,6 @@ static void loadFileV1(Flame::File & f, QJsonObject & file)
{ {
f.projectId = Json::requireInteger(file, "projectID"); f.projectId = Json::requireInteger(file, "projectID");
f.fileId = Json::requireInteger(file, "fileID"); f.fileId = Json::requireInteger(file, "fileID");
// FIXME: what does this mean?
f.required = Json::ensureBoolean(file, QString("required"), true); f.required = Json::ensureBoolean(file, QString("required"), true);
} }

View File

@ -9,12 +9,24 @@ struct File
{ {
int projectId = 0; int projectId = 0;
int fileId = 0; int fileId = 0;
// NOTE: the opposite to 'optional'. This is at the time of writing unused.
bool required = true; bool required = true;
// our // our
bool resolved = false; bool resolved = false;
QString fileName; QString fileName;
QString url; QString url;
QString targetFolder = QLatin1Literal("mods");
enum class Type
{
Unknown,
Folder,
Ctoc,
SingleFile,
Cmod2,
Modpack,
Mod
} type = Type::Mod;
}; };
struct Modloader struct Modloader