diff options
| author | TheKodeToad <TheKodeToad@proton.me> | 2023-07-10 16:42:38 +0100 | 
|---|---|---|
| committer | GitHub <noreply@github.com> | 2023-07-10 16:42:38 +0100 | 
| commit | 9aedb5afffdda7db1b614f4f17ac5901b467d69d (patch) | |
| tree | d31218b810e5219353137db7615247ba4fde1888 | |
| parent | 91c9082d19b957c3295e7a0b5bc6add71e6459b8 (diff) | |
| parent | d53d58a5d42684c5151680016f38a0f4bd1c0298 (diff) | |
| download | PrismLauncher-9aedb5afffdda7db1b614f4f17ac5901b467d69d.tar.gz PrismLauncher-9aedb5afffdda7db1b614f4f17ac5901b467d69d.tar.bz2 PrismLauncher-9aedb5afffdda7db1b614f4f17ac5901b467d69d.zip | |
Merge pull request #1334 from TheKodeToad/litemod-dl
LiteMod downloading
| -rw-r--r-- | launcher/minecraft/PackProfile.cpp | 3 | ||||
| -rw-r--r-- | launcher/modplatform/flame/FlameAPI.h | 2 | ||||
| -rw-r--r-- | launcher/modplatform/modrinth/ModrinthAPI.h | 6 | ||||
| -rw-r--r-- | launcher/ui/dialogs/ResourceDownloadDialog.cpp | 9 | 
4 files changed, 14 insertions, 6 deletions
| diff --git a/launcher/minecraft/PackProfile.cpp b/launcher/minecraft/PackProfile.cpp index aff05dbc..e8fd2157 100644 --- a/launcher/minecraft/PackProfile.cpp +++ b/launcher/minecraft/PackProfile.cpp @@ -65,7 +65,8 @@  static const QMap<QString, ResourceAPI::ModLoaderType> modloaderMapping{      {"net.minecraftforge", ResourceAPI::Forge},      {"net.fabricmc.fabric-loader", ResourceAPI::Fabric}, -    {"org.quiltmc.quilt-loader", ResourceAPI::Quilt} +    {"org.quiltmc.quilt-loader", ResourceAPI::Quilt}, +    {"com.mumfrey.liteloader", ResourceAPI::LiteLoader}  };  PackProfile::PackProfile(MinecraftInstance * instance) diff --git a/launcher/modplatform/flame/FlameAPI.h b/launcher/modplatform/flame/FlameAPI.h index 0a6dc78f..49bc316f 100644 --- a/launcher/modplatform/flame/FlameAPI.h +++ b/launcher/modplatform/flame/FlameAPI.h @@ -23,6 +23,8 @@ class FlameAPI : public NetworkResourceAPI {      [[nodiscard]] auto getSortingMethods() const -> QList<ResourceAPI::SortingMethod> override; +    static inline auto validateModLoaders(ModLoaderTypes loaders) -> bool { return loaders & (Forge | Fabric | Quilt); } +     private:      static int getClassId(ModPlatform::ResourceType type)      { diff --git a/launcher/modplatform/modrinth/ModrinthAPI.h b/launcher/modplatform/modrinth/ModrinthAPI.h index e83ed2bf..58af14cc 100644 --- a/launcher/modplatform/modrinth/ModrinthAPI.h +++ b/launcher/modplatform/modrinth/ModrinthAPI.h @@ -38,7 +38,7 @@ class ModrinthAPI : public NetworkResourceAPI {      static auto getModLoaderStrings(const ModLoaderTypes types) -> const QStringList      {          QStringList l; -        for (auto loader : { Forge, Fabric, Quilt }) { +        for (auto loader : { Forge, Fabric, Quilt, LiteLoader }) {              if (types & loader) {                  l << getModLoaderString(loader);              } @@ -92,7 +92,7 @@ class ModrinthAPI : public NetworkResourceAPI {      {          if (args.loaders.has_value()) {              if (!validateModLoaders(args.loaders.value())) { -                qWarning() << "Modrinth only have Forge and Fabric-compatible mods!"; +                qWarning() << "Modrinth - or our interface - does not support any the provided mod loaders!";                  return {};              }          } @@ -141,7 +141,7 @@ class ModrinthAPI : public NetworkResourceAPI {          return s.isEmpty() ? QString() : s;      } -    inline auto validateModLoaders(ModLoaderTypes loaders) const -> bool { return loaders & (Forge | Fabric | Quilt); } +    static inline auto validateModLoaders(ModLoaderTypes loaders) -> bool { return loaders & (Forge | Fabric | Quilt | LiteLoader); }      [[nodiscard]] std::optional<QString> getDependencyURL(DependencySearchArgs const& args) const override      { diff --git a/launcher/ui/dialogs/ResourceDownloadDialog.cpp b/launcher/ui/dialogs/ResourceDownloadDialog.cpp index 4f59f560..b17eced3 100644 --- a/launcher/ui/dialogs/ResourceDownloadDialog.cpp +++ b/launcher/ui/dialogs/ResourceDownloadDialog.cpp @@ -43,6 +43,8 @@  #include "ui/pages/modplatform/flame/FlameResourcePages.h"  #include "ui/pages/modplatform/modrinth/ModrinthResourcePages.h" +#include "modplatform/flame/FlameAPI.h" +#include "modplatform/modrinth/ModrinthAPI.h"  #include "ui/widgets/PageContainer.h"  namespace ResourceDownload { @@ -281,8 +283,11 @@ QList<BasePage*> ModDownloadDialog::getPages()  {      QList<BasePage*> pages; -    pages.append(ModrinthModPage::create(this, *m_instance)); -    if (APPLICATION->capabilities() & Application::SupportsFlame) +    auto loaders = static_cast<MinecraftInstance*>(m_instance)->getPackProfile()->getModLoaders().value(); + +    if (ModrinthAPI::validateModLoaders(loaders)) +        pages.append(ModrinthModPage::create(this, *m_instance)); +    if (APPLICATION->capabilities() & Application::SupportsFlame && FlameAPI::validateModLoaders(loaders))          pages.append(FlameModPage::create(this, *m_instance));      m_selectedPage = dynamic_cast<ModPage*>(pages[0]); | 
