diff options
| author | seth <getchoo@tuta.io> | 2023-07-14 00:16:43 -0400 | 
|---|---|---|
| committer | GitHub <noreply@github.com> | 2023-07-14 00:16:43 -0400 | 
| commit | 3099a70edc4a8a928247efd032fdd43988cd1e0a (patch) | |
| tree | 4d6baee58681459a2bab690d028bd6e1c0f50800 | |
| parent | 5d10045cc823037709d33034663d177af6446f43 (diff) | |
| parent | cde85947c7dd4c2508938490789fef60cd464828 (diff) | |
| download | PrismLauncher-3099a70edc4a8a928247efd032fdd43988cd1e0a.tar.gz PrismLauncher-3099a70edc4a8a928247efd032fdd43988cd1e0a.tar.bz2 PrismLauncher-3099a70edc4a8a928247efd032fdd43988cd1e0a.zip | |
Merge pull request #1335 from Ryex/fix/gh-1322-old-zip-mods-in-wrong-place
fix(flame install): don't assume .zip is a resource pack. default to mod
| -rw-r--r-- | launcher/minecraft/mod/tasks/LocalResourceParse.cpp | 9 | ||||
| -rw-r--r-- | launcher/modplatform/flame/FlameInstanceCreationTask.cpp | 8 | ||||
| -rw-r--r-- | launcher/modplatform/flame/PackManifest.cpp | 9 | 
3 files changed, 12 insertions, 14 deletions
| diff --git a/launcher/minecraft/mod/tasks/LocalResourceParse.cpp b/launcher/minecraft/mod/tasks/LocalResourceParse.cpp index 4d760df2..0894049c 100644 --- a/launcher/minecraft/mod/tasks/LocalResourceParse.cpp +++ b/launcher/minecraft/mod/tasks/LocalResourceParse.cpp @@ -44,7 +44,11 @@ static const QMap<PackedResourceType, QString> s_packed_type_names = {  namespace ResourceUtils {  PackedResourceType identify(QFileInfo file){      if (file.exists() && file.isFile()) { -        if (ResourcePackUtils::validate(file)) { +        if (ModUtils::validate(file)) { +            // mods can contain resource and data packs so they must be tested first +            qDebug() << file.fileName() << "is a mod"; +            return PackedResourceType::Mod; +        } else if (ResourcePackUtils::validate(file)) {              qDebug() << file.fileName() << "is a resource pack";              return PackedResourceType::ResourcePack;          } else if (TexturePackUtils::validate(file)) { @@ -53,9 +57,6 @@ PackedResourceType identify(QFileInfo file){          } else if (DataPackUtils::validate(file)) {              qDebug() << file.fileName() << "is a data pack";              return PackedResourceType::DataPack; -        } else if (ModUtils::validate(file)) { -            qDebug() << file.fileName() << "is a mod"; -            return PackedResourceType::Mod;          } else if (WorldSaveUtils::validate(file)) {              qDebug() << file.fileName() << "is a world save";              return PackedResourceType::WorldSave; diff --git a/launcher/modplatform/flame/FlameInstanceCreationTask.cpp b/launcher/modplatform/flame/FlameInstanceCreationTask.cpp index e7641d64..b57db288 100644 --- a/launcher/modplatform/flame/FlameInstanceCreationTask.cpp +++ b/launcher/modplatform/flame/FlameInstanceCreationTask.cpp @@ -563,6 +563,8 @@ void FlameCreationTask::validateZIPResouces()                  if (FS::move(localPath, destPath)) {                      return destPath;                  } +            } else { +                qDebug() << "Target folder of" << fileName << "is correct at" << targetFolder;              }              return localPath;          }; @@ -584,6 +586,9 @@ void FlameCreationTask::validateZIPResouces()          QString worldPath;          switch (type) { +            case PackedResourceType::Mod : +                validatePath(fileName, targetFolder, "mods"); +                break;              case PackedResourceType::ResourcePack :                  validatePath(fileName, targetFolder, "resourcepacks");                  break; @@ -593,9 +598,6 @@ void FlameCreationTask::validateZIPResouces()              case PackedResourceType::DataPack :                  validatePath(fileName, targetFolder, "datapacks");                  break; -            case PackedResourceType::Mod : -                validatePath(fileName, targetFolder, "mods"); -                break;              case PackedResourceType::ShaderPack :                  // in theroy flame API can't do this but who knows, that *may* change ?                  // better to handle it if it *does* occure in the future diff --git a/launcher/modplatform/flame/PackManifest.cpp b/launcher/modplatform/flame/PackManifest.cpp index 22008297..ee4d0766 100644 --- a/launcher/modplatform/flame/PackManifest.cpp +++ b/launcher/modplatform/flame/PackManifest.cpp @@ -76,13 +76,8 @@ bool Flame::File::parseFromObject(const QJsonObject& obj,  bool throw_on_blocked      // It is also optional      type = File::Type::SingleFile; -    if (fileName.endsWith(".zip")) { -        // this is probably a resource pack -        targetFolder = "resourcepacks"; -    } else { -        // this is probably a mod, dunno what else could modpacks download -        targetFolder = "mods"; -    } +    targetFolder = "mods"; +      // get the hash      hash = QString();      auto hashes = Json::ensureArray(obj, "hashes"); | 
